SyncDingTalkDeptJob.cs 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. using Admin.NET.Plugin.DingTalk;
  7. using Furion.Schedule;
  8. using Microsoft.Extensions.DependencyInjection;
  9. using Microsoft.Extensions.Logging;
  10. namespace Admin.NET.Plugin.Job;
  11. /// <summary>
  12. /// 同步钉钉角色job,自动同步触发器请在web页面按需求设置
  13. /// </summary>
  14. [JobDetail("SyncDingTalkDeptJob", Description = "同步钉钉部门", GroupName = "default", Concurrent = false)]
  15. [Daily(TriggerId = "SyncDingTalkDeptTrigger", Description = "同步钉钉部门")]
  16. public class SyncDingTalkDeptJob : IJob
  17. {
  18. private readonly IServiceScopeFactory _scopeFactory;
  19. private readonly IDingTalkApi _dingTalkApi;
  20. private readonly ILogger _logger;
  21. private readonly SqlSugarRepository<DingTalkDept> 部门信息;
  22. public SyncDingTalkDeptJob(
  23. IServiceScopeFactory scopeFactory,
  24. IDingTalkApi dingTalkApi,
  25. SqlSugarRepository<DingTalkDept> _部门信息,
  26. ILoggerFactory loggerFactory)
  27. {
  28. _scopeFactory = scopeFactory;
  29. _dingTalkApi = dingTalkApi;
  30. 部门信息 = _部门信息;
  31. _logger = loggerFactory.CreateLogger(CommonConst.SysLogCategoryName);
  32. }
  33. public async Task ExecuteAsync(JobExecutingContext context, CancellationToken stoppingToken)
  34. {
  35. using var serviceScope = _scopeFactory.CreateScope();
  36. var _dingTalkOptions = serviceScope.ServiceProvider.GetRequiredService<IOptions<DingTalkOptions>>();
  37. // 获取Token
  38. var tokenRes = await _dingTalkApi.GetDingTalkToken(_dingTalkOptions.Value.ClientId, _dingTalkOptions.Value.ClientSecret);
  39. if (tokenRes.ErrCode != 0)
  40. throw Oops.Oh(tokenRes.ErrMsg);
  41. var dingTalkDeptList = new List<DingTalkDept>();
  42. // 获取部门列表
  43. var deptIdsRes = await _dingTalkApi.GetDingTalkDept(tokenRes.AccessToken, new GetDingTalkDeptInput
  44. { dept_id = 1 });
  45. if (deptIdsRes.ErrCode != 0)
  46. {
  47. _logger.LogError(deptIdsRes.ErrMsg);
  48. throw Oops.Oh(deptIdsRes.ErrMsg);
  49. }
  50. dingTalkDeptList.AddRange(deptIdsRes.Result.Select(d => new DingTalkDept
  51. {
  52. dept_id = d.dept_id,
  53. name = d.name,
  54. parent_id = d.parent_id
  55. }));
  56. foreach (var item in deptIdsRes.Result)
  57. {
  58. dingTalkDeptList.AddRange(await 获取部门列表(tokenRes.AccessToken, item.dept_id));
  59. }
  60. 部门信息.InsertOrUpdateAsync(dingTalkDeptList);
  61. var originColor = Console.ForegroundColor;
  62. Console.ForegroundColor = ConsoleColor.Blue;
  63. Console.WriteLine("【" + DateTime.Now + "】同步钉钉部门");
  64. Console.ForegroundColor = originColor;
  65. }
  66. private async Task<List<DingTalkDept>> 获取部门列表(string token, long dept_id)
  67. {
  68. List<DingTalkDept> listTemp = new List<DingTalkDept>();
  69. var deptIdsRes = await _dingTalkApi.GetDingTalkDept(token, new GetDingTalkDeptInput
  70. {dept_id= dept_id });
  71. if (deptIdsRes.ErrCode != 0)
  72. {
  73. return null;
  74. }
  75. listTemp.AddRange(deptIdsRes.Result.Select(x => new DingTalkDept
  76. {
  77. dept_id = x.dept_id,
  78. name = x.name,
  79. parent_id = x.parent_id
  80. }));
  81. foreach (var item in deptIdsRes.Result)
  82. {
  83. listTemp.AddRange(await 获取部门列表(token, item.dept_id));
  84. }
  85. return listTemp;
  86. }
  87. }