IQiYeWeChatApiService.cs 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. using OASystem.Domain.Dtos.QiYeWeChat;
  2. using OASystem.Domain.ViewModels.QiYeWeChat;
  3. namespace OASystem.API.OAMethodLib.QiYeWeChatAPI
  4. {
  5. /// <summary>
  6. /// 企业微信Api 服务
  7. /// </summary>
  8. public interface IQiYeWeChatApiService
  9. {
  10. ///// <summary>
  11. ///// 获取access_token
  12. ///// </summary>
  13. ///// <param name="applicationType">
  14. ///// 1:人事助手
  15. ///// 2:打卡
  16. ///// 3:邮件
  17. ///// 6:团组状态通知
  18. ///// </param>
  19. ///// <returns></returns>
  20. //Task<Access_TokenView> GetToken(int applicationType);
  21. /// <summary>
  22. /// 创建员工
  23. /// </summary>
  24. /// <param name="create_Request"></param>
  25. /// <returns></returns>
  26. Task<ResponseBase> CreateAsync(Create_Request create_Request);
  27. /// <summary>
  28. /// 获取成员ID列表
  29. /// </summary>
  30. /// <returns></returns>
  31. Task<UserIdListView> GetUserIdListAsync();
  32. /// <summary>
  33. /// 获取成员信息
  34. /// </summary>
  35. /// <returns></returns>
  36. Task<QYWX_UserInfosView> GetUserInfosAsync();
  37. /// <summary>
  38. /// 获取企业所有打卡规则
  39. /// </summary>
  40. /// <returns></returns>
  41. Task<CorpCheckInRuleView> GetCheckIn_CorpCheckInOptionAsync();
  42. /// <summary>
  43. /// 获取月打卡数据
  44. /// </summary>
  45. /// <param name="startDt"></param>
  46. /// <param name="endDt"></param>
  47. /// <returns></returns>
  48. Task<CheckInView> GetCheckin_MonthDataAsync(DateTime startDt, DateTime endDt);
  49. /// <summary>
  50. /// 获取月打卡数据 Redis
  51. /// </summary>
  52. /// <param name="startDt"></param>
  53. /// <param name="endDt"></param>
  54. /// <returns></returns>
  55. Task<CheckInView> GetCheckin_MonthDataRedisAsync(DateTime startDt, DateTime endDt);
  56. /// <summary>
  57. /// 获取打卡记录数据
  58. /// </summary>
  59. /// <param name="useridlist">需要获取打卡记录的用户列表</param>
  60. /// <param name="opencheckindatatype">打卡类型。1:上下班打卡;2:外出打卡;3:全部打卡</param>
  61. /// <param name="startDt">获取打卡记录的开始时间。Unix时间戳</param>
  62. /// <param name="endDt">获取打卡记录的结束时间。Unix时间戳</param>
  63. /// <returns></returns>
  64. Task<CheckInDataView> GetCheckinDataAsync(List<string> useridlist, int opencheckindatatype, DateTime startDt, DateTime endDt);
  65. /// <summary>
  66. /// 获取打卡日报数据
  67. /// </summary>
  68. /// <param name="useridlist"></param>
  69. /// <param name="startDt"></param>
  70. /// <param name="endDt"></param>
  71. /// <returns></returns>
  72. Task<CheckInDayDataView> GetCheckInDayDataAsync(List<string> useridlist, DateTime startDt, DateTime endDt);
  73. /// <summary>
  74. /// 获取审批数据(旧)
  75. /// </summary>
  76. /// <param name="startDt"></param>
  77. /// <param name="endDt"></param>
  78. /// <returns></returns>
  79. Task<ApprovalDataView> GetApprovalDataAsync(DateTime startDt, DateTime endDt);
  80. /// <summary>
  81. /// 获取审批数据(旧)
  82. /// </summary>
  83. /// <param name="startDt"></param>
  84. /// <param name="endDt"></param>
  85. /// <returns></returns>
  86. Task<List<Sp_Info>> GetApprovalDatasAsync(DateTime startDt, DateTime endDt);
  87. /// <summary>
  88. /// 获取审批数据(旧)(redis缓存)
  89. /// </summary>
  90. /// <param name="startDt"></param>
  91. /// <param name="endDt"></param>
  92. /// <returns></returns>
  93. Task<List<Sp_Info>> GetApprovalDatasRedisAsync(DateTime startDt, DateTime endDt);
  94. ///// <summary>
  95. ///// 批量获取审批单号
  96. ///// </summary>
  97. ///// <param name="startDt"></param>
  98. ///// <param name="endDt"></param>
  99. ///// <param name="record_type">
  100. ///// sp_status-审批单状态(1-审批中;2-已通过;3-已驳回;4-已撤销;6-通过后撤销;7-已删除;10-已支付)
  101. ///// </param>
  102. ///// <returns></returns>
  103. //Task<ApprovalInfoView> GetApprovalInfoAsync(DateTime startDt, DateTime endDt, int record_type);
  104. //// <summary>
  105. /// 批量获取审批详情
  106. /// <param name="startDt"></param>
  107. /// <param name="endDt"></param>
  108. /// <param name="creator">
  109. /// 申请人
  110. /// </param>
  111. /// <param name="sp_status">
  112. /// sp_status-审批单状态(1-审批中;2-已通过;3-已驳回;4-已撤销;6-通过后撤销;7-已删除;10-已支付)
  113. /// </param>
  114. /// <param name="record_type">
  115. /// record_type - 审批单类型属性,1-请假;2-打卡补卡;3-出差;4-外出;5-加班; 6- 调班;7-会议室预定;8-退款审批;9-红包报销审批
  116. /// </param>
  117. /// <returns></returns>
  118. Task<List<Sp_Detail>> GetApprovalDetailsAsync(DateTime startDt, DateTime endDt, string creator, int sp_status, int record_type);
  119. /// <summary>
  120. /// 获取审批模板详情
  121. /// </summary>
  122. /// <param name="template_id">模板Id</param>
  123. /// <returns></returns>
  124. Task<TemplateDetailView> GetTemplateDetailAsync(string template_id);
  125. /// <summary>
  126. /// 获取审批详情
  127. /// </summary>
  128. /// <param name="spNo">审批No</param>
  129. /// <returns></returns>
  130. Task<ApprovalDetailView> GetApprovalDetailAsync(string spNo);
  131. /// <summary>
  132. /// hook 发送团组出发信息给财务群
  133. /// </summary>
  134. /// <param name="msg"></param>
  135. /// <returns></returns>
  136. Task<ResponseBase> RobotSendMsg_GroupInfo(string msg);
  137. #region 团组状态通知
  138. /// <summary>
  139. /// 获取部门成员
  140. /// </summary>
  141. /// <returns></returns>
  142. Task<GroupStatus_UserSimplelistView> GroupStatus_GetUserList(int departmentId = 8402038);
  143. /// <summary>
  144. /// 创建群聊
  145. /// </summary>
  146. /// <returns></returns>
  147. Task<GroupStatus_CreateChatView> GroupStatus_CreateChat(string chatName, string owner, List<string> userList, string chatId);
  148. /// <summary>
  149. /// 向群聊发送消息
  150. /// </summary>
  151. /// <param name="chatId"></param>
  152. /// <param name="msgContent"></param>
  153. /// <returns></returns>
  154. Task<ResponseBase> GroupStatus_SendChatMsg_Markdown(string chatId, string msgContent, string msgType = "markdown");
  155. /// <summary>
  156. /// 向用户发送信息
  157. /// </summary>
  158. /// <param name="toUser"></param>
  159. /// <param name="msgContent"></param>
  160. /// <param name="msgType"></param>
  161. /// <returns></returns>
  162. Task<GroupStatus_SendMessageView> GroupStatus_SendMessage_ToUser(string toUser, string msgContent, string msgType = "markdown");
  163. #endregion
  164. }
  165. }