DingTalkService.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Plugin.DingTalk.Service;
  7. /// <summary>
  8. /// 钉钉服务 🧩
  9. /// </summary>
  10. [ApiDescriptionSettings(DingTalkConst.GroupName, Order = 100)]
  11. public class DingTalkService : IDynamicApiController, IScoped
  12. {
  13. private readonly IDingTalkApi _dingTalkApi;
  14. private readonly DingTalkOptions _dingTalkOptions;
  15. private readonly SqlSugarRepository<DingTalkWokerflowLog> _dingTalkWokerflowLogRep;
  16. public DingTalkService(
  17. IDingTalkApi dingTalkApi,
  18. IOptions<DingTalkOptions> dingTalkOptions,
  19. SqlSugarRepository<DingTalkWokerflowLog> dingTalkWokerflowLogRep
  20. )
  21. {
  22. _dingTalkApi = dingTalkApi;
  23. _dingTalkOptions = dingTalkOptions.Value;
  24. _dingTalkWokerflowLogRep = dingTalkWokerflowLogRep;
  25. }
  26. /// <summary>
  27. /// 获取企业内部应用的access_token
  28. /// </summary>
  29. /// <returns></returns>
  30. [DisplayName("获取企业内部应用的access_token")]
  31. public async Task<GetDingTalkTokenOutput> GetDingTalkToken()
  32. {
  33. var tokenRes = await _dingTalkApi.GetDingTalkToken(
  34. _dingTalkOptions.ClientId,
  35. _dingTalkOptions.ClientSecret
  36. );
  37. if (tokenRes.ErrCode != 0)
  38. {
  39. throw Oops.Oh(tokenRes.ErrMsg);
  40. }
  41. return tokenRes;
  42. }
  43. /// <summary>
  44. /// 获取在职员工列表 🔖
  45. /// </summary>
  46. /// <param name="access_token"></param>
  47. /// <param name="input"></param>
  48. /// <returns></returns>
  49. [HttpPost, DisplayName("获取在职员工列表")]
  50. public async Task<
  51. DingTalkBaseResponse<GetDingTalkCurrentEmployeesListOutput>
  52. > GetDingTalkCurrentEmployeesList(
  53. string access_token,
  54. [Required] GetDingTalkCurrentEmployeesListInput input
  55. )
  56. {
  57. return await _dingTalkApi.GetDingTalkCurrentEmployeesList(access_token, input);
  58. }
  59. /// <summary>
  60. /// 获取员工花名册字段信息 🔖
  61. /// </summary>
  62. /// <param name="access_token"></param>
  63. /// <param name="input"></param>
  64. /// <returns></returns>
  65. [HttpPost, DisplayName("获取员工花名册字段信息")]
  66. public async Task<
  67. DingTalkBaseResponse<List<DingTalkEmpRosterFieldVo>>
  68. > GetDingTalkCurrentEmployeesRosterList(
  69. string access_token,
  70. [Required] GetDingTalkCurrentEmployeesRosterListInput input
  71. )
  72. {
  73. return await _dingTalkApi.GetDingTalkCurrentEmployeesRosterList(access_token, input);
  74. }
  75. /// <summary>
  76. /// 发送钉钉互动卡片 🔖
  77. /// </summary>
  78. /// <param name="token"></param>
  79. /// <param name="input"></param>
  80. /// <returns></returns>
  81. [DisplayName("给指定用户发送钉钉互动卡片")]
  82. [Obsolete]
  83. public async Task<DingTalkSendInteractiveCardsOutput> DingTalkSendInteractiveCards(
  84. string token,
  85. DingTalkSendInteractiveCardsInput input
  86. )
  87. {
  88. return await _dingTalkApi.DingTalkSendInteractiveCards(token, input);
  89. }
  90. /// <summary>
  91. /// 创建并投放钉钉消息卡片 🔖
  92. /// </summary>
  93. /// <param name="token"></param>
  94. /// <param name="input"></param>
  95. /// <returns></returns>
  96. [DisplayName("给指定用户发送钉钉消息卡片")]
  97. public async Task<DingTalkCreateAndDeliverOutput> DingTalkCreateAndDeliver(
  98. string token,
  99. DingTalkCreateAndDeliverInput input
  100. )
  101. {
  102. return await _dingTalkApi.DingTalkCreateAndDeliver(token, input);
  103. }
  104. [DisplayName("用于发起OA审批实例")]
  105. public async Task<DingTalkWorkflowProcessInstancesOutput> DingTalkWorkflowProcessInstances(
  106. string token,
  107. DingTalkWorkflowProcessInstancesInput input
  108. )
  109. {
  110. var temp = await _dingTalkApi.DingTalkWorkflowProcessInstances(token, input);
  111. return temp;
  112. }
  113. [DisplayName("查询审批实例")]
  114. public async Task<DingTalkGetProcessInstancesOutput> DingTalkWorkflowProcessInstances(
  115. string token,
  116. string input
  117. )
  118. {
  119. var temp = await _dingTalkApi.GetProcessInstances(token, input);
  120. DingTalkWokerflowLog flow = await _dingTalkWokerflowLogRep.GetFirstAsync(t =>
  121. t.Status == "RUNNING" && t.instanceId == input
  122. );
  123. if ((flow != null) && (temp.Result.Status != flow.Status))
  124. {
  125. flow.Status = temp.Result.Status;
  126. flow.UpdateTime = DateTime.Now;
  127. flow.WorkflowId = temp.Result.BusinessId;
  128. flow.Result = temp.Result.Result;
  129. flow.taskId = temp.Result.Tasks.FirstOrDefault(t => t.Status == "RUNNING")?.TaskId;
  130. await _dingTalkWokerflowLogRep.UpdateAsync(flow);
  131. }
  132. return temp;
  133. }
  134. }