DingTalkService.cs 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. // 大名科技(天津)有限公司 版权所有
  2. //
  3. // 此源代码遵循位于源代码树根目录中的 LICENSE 文件的许可证
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动
  6. //
  7. // 任何基于本项目二次开发而产生的一切法律纠纷和责任,均与作者无关
  8. namespace Admin.NET.Plugin.DingTalk.Service;
  9. /// <summary>
  10. /// 钉钉服务 🧩
  11. /// </summary>
  12. [ApiDescriptionSettings(DingTalkConst.GroupName, Module = "DingTalk", Order = 100)]
  13. public class DingTalkService : IDynamicApiController, IScoped
  14. {
  15. private readonly IDingTalkApi _dingTalkApi;
  16. private readonly DingTalkOptions _dingTalkOptions;
  17. public DingTalkService(IDingTalkApi dingTalkApi,
  18. IOptions<DingTalkOptions> dingTalkOptions)
  19. {
  20. _dingTalkApi = dingTalkApi;
  21. _dingTalkOptions = dingTalkOptions.Value;
  22. }
  23. /// <summary>
  24. /// 获取企业内部应用的access_token
  25. /// </summary>
  26. /// <returns></returns>
  27. [DisplayName("获取企业内部应用的access_token")]
  28. public async Task<GetDingTalkTokenOutput> GetDingTalkToken()
  29. {
  30. var tokenRes = await _dingTalkApi.GetDingTalkToken(_dingTalkOptions.ClientId, _dingTalkOptions.ClientSecret);
  31. if (tokenRes.ErrCode != 0)
  32. {
  33. throw Oops.Oh(tokenRes.ErrMsg);
  34. }
  35. return tokenRes;
  36. }
  37. /// <summary>
  38. /// 获取在职员工列表 🔖
  39. /// </summary>
  40. /// <param name="access_token"></param>
  41. /// <param name="input"></param>
  42. /// <returns></returns>
  43. [DisplayName("获取在职员工列表")]
  44. public async Task<DingTalkBaseResponse<GetDingTalkCurrentEmployeesListOutput>> GetDingTalkCurrentEmployeesList(string access_token, [Required] GetDingTalkCurrentEmployeesListInput input)
  45. {
  46. return await _dingTalkApi.GetDingTalkCurrentEmployeesList(access_token, input);
  47. }
  48. /// <summary>
  49. /// 获取员工花名册字段信息 🔖
  50. /// </summary>
  51. /// <param name="access_token"></param>
  52. /// <param name="input"></param>
  53. /// <returns></returns>
  54. [DisplayName("获取员工花名册字段信息")]
  55. public async Task<DingTalkBaseResponse<List<DingTalkEmpRosterFieldVo>>> GetDingTalkCurrentEmployeesRosterList(string access_token, [Required] GetDingTalkCurrentEmployeesRosterListInput input)
  56. {
  57. return await _dingTalkApi.GetDingTalkCurrentEmployeesRosterList(access_token, input);
  58. }
  59. /// <summary>
  60. /// 发送钉钉互动卡片 🔖
  61. /// </summary>
  62. /// <param name="token"></param>
  63. /// <param name="input"></param>
  64. /// <returns></returns>
  65. [DisplayName("给指定用户发送钉钉互动卡片")]
  66. public async Task<DingTalkSendInteractiveCardsOutput> DingTalkSendInteractiveCards(string token, DingTalkSendInteractiveCardsInput input)
  67. {
  68. return await _dingTalkApi.DingTalkSendInteractiveCards(token, input);
  69. }
  70. }