ding_event.go 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. package dingtalk
  2. import (
  3. "context"
  4. model "dashoo.cn/micro/app/model/workflow"
  5. contractSrv "dashoo.cn/micro/app/service/contract"
  6. custServer "dashoo.cn/micro/app/service/cust"
  7. "dashoo.cn/micro/app/service/dingtalk_log"
  8. platServer "dashoo.cn/micro/app/service/plat"
  9. projService "dashoo.cn/micro/app/service/proj"
  10. workflowServer "dashoo.cn/micro/app/service/workflow"
  11. "dashoo.cn/opms_libary/plugin/dingtalk"
  12. dingContext "dashoo.cn/opms_libary/plugin/dingtalk/context"
  13. "dashoo.cn/opms_libary/plugin/dingtalk/message"
  14. "database/sql"
  15. "fmt"
  16. "github.com/gogf/gf/os/glog"
  17. "github.com/gogf/gf/util/gconv"
  18. )
  19. type DingHandler struct{}
  20. // CallBack 钉钉事件回调
  21. // 日程相关详情参照文档:https://open.dingtalk.com/document/orgapp/schedule-event
  22. // 审批相关详情参照文档:https://open.dingtalk.com/document/orgapp/approval-events
  23. func (h *DingHandler) CallBack(ctx context.Context, req *message.SubsMessage, rsp *message.Reply) error {
  24. req.Ctx = ctx
  25. handler := dingtalk.Client.GetDingTalkHandler(req)
  26. //设置接收消息的处理方法
  27. handler.SetHandleMessageFunc(func(msg *message.MixMessage) string {
  28. // 记录日志
  29. dingtalk_log.Create(handler.Context.SubsMessage.Ctx, "20", gconv.String(msg))
  30. switch msg.EventType {
  31. case message.EventCheckUrl:
  32. return h.handleCheckUrl(msg)
  33. case message.EventCalendarChange:
  34. return h.handleCalendarChange(msg, handler.Context)
  35. case message.BpmsInstanceChange:
  36. return h.handleBpmsInstanceChange(msg, handler.Context)
  37. case message.BpmsTaskChange:
  38. return h.handleBpmsTaskChange(msg, handler.Context)
  39. }
  40. return ""
  41. })
  42. result, _ := handler.Handle()
  43. *rsp = result
  44. return nil
  45. }
  46. // 验证回调参数
  47. func (h *DingHandler) handleCheckUrl(msg *message.MixMessage) string {
  48. fmt.Println(msg)
  49. return "success"
  50. }
  51. // 处理日程回调
  52. func (h *DingHandler) handleCalendarChange(msg *message.MixMessage, ctx *dingContext.Context) string {
  53. fmt.Println(msg)
  54. // 本系统数据库操作
  55. s, err := platServer.NewScheduleService(ctx.SubsMessage.Ctx)
  56. if err != nil {
  57. glog.Error(err)
  58. return err.Error()
  59. }
  60. // 回填数据
  61. err = s.SaveByDingEvent(msg)
  62. if err != nil {
  63. glog.Error(err)
  64. return err.Error()
  65. }
  66. return "success"
  67. }
  68. // 处理审批实例回调
  69. func (h *DingHandler) handleBpmsInstanceChange(msg *message.MixMessage, ctx *dingContext.Context) string {
  70. fmt.Println(msg)
  71. // 构造访问服务
  72. s, err := workflowServer.NewFlowService(ctx.SubsMessage.Ctx)
  73. if err != nil {
  74. glog.Error(err)
  75. return err.Error()
  76. }
  77. // 获取审批实例数据
  78. instance, err := s.GetWorkflowInstance(msg.ProcessInstanceId)
  79. if err != nil {
  80. if err == sql.ErrNoRows {
  81. glog.Error("无匹配的审批实例")
  82. return "无匹配的审批实例"
  83. }
  84. glog.Error(err)
  85. return err.Error()
  86. }
  87. if instance == nil {
  88. return "无匹配的审批实例"
  89. }
  90. // 处理实例数据(不需要钉钉审批实例参数)
  91. switch instance.BizType {
  92. case model.CustomerReceive:
  93. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  94. srv, err := custServer.NewCustomerService(ctx.SubsMessage.Ctx)
  95. if err != nil {
  96. glog.Error(err)
  97. return err.Error()
  98. }
  99. err = srv.AssignCustomerRequestApproval(instance, msg)
  100. if err != nil {
  101. glog.Error(err)
  102. return err.Error()
  103. }
  104. }
  105. err = s.Update(instance, msg)
  106. if err != nil {
  107. glog.Error(err)
  108. return err.Error()
  109. }
  110. return "success"
  111. case model.CustomerPublic:
  112. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  113. srv, err := custServer.NewCustomerService(ctx.SubsMessage.Ctx)
  114. if err != nil {
  115. glog.Error(err)
  116. return err.Error()
  117. }
  118. err = srv.MoveToPublicApproval(instance, msg)
  119. if err != nil {
  120. glog.Error(err)
  121. return err.Error()
  122. }
  123. }
  124. err = s.Update(instance, msg)
  125. if err != nil {
  126. glog.Error(err)
  127. return err.Error()
  128. }
  129. return "success"
  130. case model.CustomerTrans:
  131. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  132. srv, err := custServer.NewCustomerService(ctx.SubsMessage.Ctx)
  133. if err != nil {
  134. glog.Error(err)
  135. return err.Error()
  136. }
  137. err = srv.TransCustomerApproval(instance, msg)
  138. if err != nil {
  139. glog.Error(err)
  140. return err.Error()
  141. }
  142. }
  143. err = s.Update(instance, msg)
  144. if err != nil {
  145. glog.Error(err)
  146. return err.Error()
  147. }
  148. return "success"
  149. case model.ContractInvoice:
  150. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  151. err = contractSrv.InvoiceApplyApproval(ctx.SubsMessage.Ctx, instance, msg)
  152. if err != nil {
  153. glog.Error(err)
  154. return err.Error()
  155. }
  156. }
  157. err = s.Update(instance, msg)
  158. if err != nil {
  159. glog.Error(err)
  160. return err.Error()
  161. }
  162. return "success"
  163. case model.ContractCreate:
  164. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  165. err = contractSrv.ContractApplyApproval(ctx.SubsMessage.Ctx, instance, msg)
  166. if err != nil {
  167. glog.Error(err)
  168. return err.Error()
  169. }
  170. }
  171. err = s.Update(instance, msg)
  172. if err != nil {
  173. glog.Error(err)
  174. return err.Error()
  175. }
  176. return "success"
  177. case model.ProjectUpGrade:
  178. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  179. srv, err := projService.NewBusinessService(ctx.SubsMessage.Ctx)
  180. if err != nil {
  181. glog.Error(err)
  182. return err.Error()
  183. }
  184. err = srv.BusinessUpgradeNotify(instance, msg)
  185. if err != nil {
  186. glog.Error(err)
  187. return err.Error()
  188. }
  189. }
  190. err = s.Update(instance, msg)
  191. if err != nil {
  192. glog.Error(err)
  193. return err.Error()
  194. }
  195. return "success"
  196. case model.ProjectDownGrade:
  197. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  198. srv, err := projService.NewBusinessService(ctx.SubsMessage.Ctx)
  199. if err != nil {
  200. glog.Error(err)
  201. return err.Error()
  202. }
  203. err = srv.BusinessDowngradeNotify(instance, msg)
  204. if err != nil {
  205. glog.Error(err)
  206. return err.Error()
  207. }
  208. }
  209. err = s.Update(instance, msg)
  210. if err != nil {
  211. glog.Error(err)
  212. return err.Error()
  213. }
  214. return "success"
  215. case model.ProjectTransfer:
  216. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  217. srv, err := projService.NewBusinessService(ctx.SubsMessage.Ctx)
  218. if err != nil {
  219. glog.Error(err)
  220. return err.Error()
  221. }
  222. err = srv.BusinessTransferNotify(instance, msg)
  223. if err != nil {
  224. glog.Error(err)
  225. return err.Error()
  226. }
  227. }
  228. err = s.Update(instance, msg)
  229. if err != nil {
  230. glog.Error(err)
  231. return err.Error()
  232. }
  233. return "success"
  234. case model.ProjectToReserve:
  235. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  236. srv, err := projService.NewBusinessService(ctx.SubsMessage.Ctx)
  237. if err != nil {
  238. glog.Error(err)
  239. return err.Error()
  240. }
  241. err = srv.ConvertToReserveNotify(instance, msg)
  242. if err != nil {
  243. glog.Error(err)
  244. return err.Error()
  245. }
  246. }
  247. err = s.Update(instance, msg)
  248. if err != nil {
  249. glog.Error(err)
  250. return err.Error()
  251. }
  252. return "success"
  253. case model.PlatTaskApproval:
  254. if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  255. srv, err := platServer.NewTaskService(ctx.SubsMessage.Ctx)
  256. if err != nil {
  257. glog.Error(err)
  258. return err.Error()
  259. }
  260. err = srv.AddTaskApproval(instance, msg)
  261. if err != nil {
  262. glog.Error(err)
  263. return err.Error()
  264. }
  265. }
  266. err = s.Update(instance, msg)
  267. if err != nil {
  268. glog.Error(err)
  269. return err.Error()
  270. }
  271. return "success"
  272. }
  273. // 以下的代码需要调用钉钉接口查询数据,并且以下接口需要审批实例的数据
  274. //// 获取钉钉数据
  275. //resp, err := s.GetProcessInstanceDetail(msg.ProcessInstanceId)
  276. //if err != nil {
  277. // glog.Error(err)
  278. // return err.Error()
  279. //}
  280. //if resp.Success == "false" {
  281. // return "fail"
  282. //}
  283. ////按照类型处理数据(不需要钉钉审批实例参数)
  284. //switch instance.BizType {
  285. //case model.CustomerReceive:
  286. // if msg.ProcessType == "finish" || msg.ProcessType == "terminate" {
  287. // //srv.Handle(instance, msg, resp)
  288. // }
  289. return "success"
  290. }
  291. // 处理审批任务回调
  292. func (h *DingHandler) handleBpmsTaskChange(msg *message.MixMessage, ctx *dingContext.Context) string {
  293. fmt.Println(msg)
  294. // TODO 目前审批任务无处理逻辑
  295. //// 本系统数据库操作
  296. //s, err := platServer.NewScheduleService(ctx.SubsMessage.Ctx)
  297. //if err != nil {
  298. // glog.Error(err)
  299. // return err.Error()
  300. //}
  301. //// 回填数据
  302. //err = s.SaveByDingEvent(msg)
  303. //if err != nil {
  304. // glog.Error(err)
  305. // return err.Error()
  306. //}
  307. return "success"
  308. }