HrmRequest.cs 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. using Admin.NET.Plugin.DingTalk.RequestProxy.HRM.DTO;
  7. using NewLife;
  8. namespace Admin.NET.Plugin.DingTalk.RequestProxy.HRM;
  9. public class HrmRequest : IScoped
  10. {
  11. private readonly IHrmRequestProxy _request;
  12. public HrmRequest(IHrmRequestProxy request)
  13. {
  14. _request = request;
  15. }
  16. /// <summary>
  17. /// 获取在职员工列表
  18. /// </summary>
  19. /// <param name="accessToken"></param>
  20. /// <param name="statusList">在职员工状态筛选,可以查询多个状态。2:试用期、3:正式、5:待离职、-1:无状态</param>
  21. /// <param name="size">分页大小,最大50</param>
  22. /// <param name="offset">分页游标,从0开始。根据返回结果里的next_cursor是否为空来判断是否还有下一页,且再次调用时offset设置成next_cursor的值</param>
  23. /// <returns></returns>
  24. public async Task<EmployeeQueryOnJobResponse> EmployeeQueryOnJob(string accessToken, List<string> statusList, int size = 50, int offset = 0)
  25. {
  26. var resStr = await _request.EmployeeQueryonjob(accessToken, new EmployeeQueryOnJobRequest
  27. {
  28. StatusList = statusList.Join(),
  29. Size = size,
  30. Offset = offset
  31. });
  32. return resStr.ToObject<EmployeeQueryOnJobResponse>();
  33. }
  34. /// <summary>
  35. /// 获取员工花名册字段信息
  36. /// </summary>
  37. /// <param name="accessToken"></param>
  38. /// <param name="useridList">员工的 userId 列表,一次最多支持传100个值</param>
  39. /// <param name="fieldFilterList">需要获取的花名册字段field_code值列表,一次最多支持传100个值</param>
  40. /// <param name="agentId">应用的AgentId</param>
  41. /// <returns></returns>
  42. public async Task<RosterListsQueryResponse> RosterListsQuery(string accessToken, List<string> useridList, List<string> fieldFilterList, long agentId)
  43. {
  44. var resStr = await _request.RosterListsQuery(accessToken, new RosterListsQueryRequest
  45. {
  46. UserIdList = useridList.Join(),
  47. FieldFilterList = fieldFilterList.Join(),
  48. AgentId = agentId
  49. });
  50. return resStr.ToObject<RosterListsQueryResponse>();
  51. }
  52. /// <summary>
  53. /// 获取花名册元数据
  54. /// </summary>
  55. /// <param name="accessToken"></param>
  56. /// <param name="agentId"></param>
  57. /// <returns></returns>
  58. public async Task<GetRosterMetaResponse> GetRosterMeta(string accessToken, long agentId)
  59. {
  60. var resStr = await _request.GetRosterMeta(accessToken, new GetRosterMetaRequest { AgentId = agentId });
  61. return resStr.ToObject<GetRosterMetaResponse>();
  62. }
  63. }