work_flow.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. package workflow
  2. import (
  3. "context"
  4. "dashoo.cn/opms_libary/myerrors"
  5. "dashoo.cn/opms_libary/plugin/dingtalk"
  6. "dashoo.cn/opms_libary/plugin/dingtalk/message"
  7. "dashoo.cn/opms_libary/plugin/dingtalk/workflow"
  8. "dashoo.cn/opms_libary/utils"
  9. dao "dashoo.cn/opms_parent/app/dao/workflow"
  10. model "dashoo.cn/opms_parent/app/model/workflo
  11. "github.com/gogf/gf/frame/g"
  12. "github.com/gogf/gf/os/gtime"
  13. "github.com/gogf/gf/util/gconv"
  14. "time"
  15. )
  16. type workflowService struct {
  17. *service.ContextService
  18. Dao *dao.PlatWorkflowDao
  19. }
  20. func NewFlowService(ctx context.Context) (svc *workflowService, err error) {
  21. svc = new(workflowService)
  22. if svc.ContextService, err = svc.Init(ctx); err != nil {
  23. return nil, err
  24. }
  25. svc.Dao = dao.NewPlatWorkflowDao(svc.Tenant)
  26. return svc, nil
  27. }
  28. // GetSchemaByProcessCode 获取表单 schema(钉钉接口)
  29. func (s *workflowService) GetSchemaByProcessCode(processCode string) (*workflow.QuerySchemaByProcessCodeResponse, error) {
  30. g.Log().Info("搜索值", processCode)
  31. // 调用钉钉接口
  32. client := dingtalk.NewClient()
  33. w := client.GetWorkflow()
  34. resp, err := w.QuerySchemaByProcessCode(processCode)
  35. if err != nil {
  36. return nil, err
  37. }
  38. return &resp, nil
  39. }
  40. // GetProcessInstanceDetail 获取审批实例详情(钉钉接口)
  41. func (s *workflowService) GetProcessInstanceDetail(instId string) (*workflow.QueryProcessInstanceResponse, error) {
  42. g.Log().Info("搜索值", instId)
  43. // 调用钉钉接口
  44. client := dingtalk.NewClient()
  45. w := client.GetWorkflow()
  46. resp, err := w.QueryProcessInstanceDetail(instId)
  47. if err != nil {
  48. return nil, err
  49. }
  50. return &resp, nil
  51. }
  52. // StartProcessInstance 发起一个新的审批流(钉钉接口,并回填到本地系统)
  53. // OriginatorUserId = utils.String("当前用户的钉钉中的Id")
  54. // ProcessCode = utils.String("每种审批对应固定的code")
  55. // bizType:业务类型(10领用20项目创建30合同创建
  56. // 详情参照文档:https://open.dingtalk.com/document/orgapp/create-an-approval-instance
  57. func (s *workflowService) StartProcessInstance(bizCode, bizType, remark string, flow *workflow.StartProcessInstanceRequest) (instanceId string, err error) {
  58. // 参数调整
  59. if flow.OriginatorUserId == nil {
  60. flow.OriginatorUserId = utils.String(s.GetCxtUserDingtalkUid())
  61. }
  62. if flow.DeptId == nil {
  63. flow.DeptId = utils.Int64(gconv.Int64(s.GetCxtUserDeptId()))
  64. }
  65. g.Log().Info("搜索值", flow)
  66. // 调用钉钉接口
  67. client := dingtalk.NewClient()
  68. w := client.GetWorkflow()
  69. resp, err := w.StartProcessInstance(flow)
  70. if err != nil {
  71. return "", err
  72. }
  73. _, err = s.saveWorkflowInstance(bizCode, bizType, remark, resp.InstanceId)
  74. return resp.InstanceId, err
  75. }
  76. // RevokeProcessInstance 撤销审批实例(钉钉接口)
  77. func (s *workflowService) RevokeProcessInstance(instId, remark string) (string, error) {
  78. g.Log().Info("搜索值instId, remark:", instId, remark)
  79. // 调用钉钉接口
  80. client := dingtalk.NewClient()
  81. w := client.GetWorkflow()
  82. resp, err := w.RevokeProcessInstance(instId, remark, s.GetCxtUserDingtalkUid())
  83. if err != nil {
  84. return "", err
  85. }
  86. return resp.InstanceId, nil
  87. }
  88. // 将审批实例同步到数据库中
  89. func (s *workflowService) saveWorkflowInstance(bizCode, bizType, remark, instanceId string) (insertId int64, err error) {
  90. now := gtime.Now()
  91. // 构造基础数据
  92. var instance model.PlatWorkflow
  93. instance.BizCode = bizCode
  94. instance.BizType = bizType
  95. instance.CurrentNode = "create"
  96. instance.CurrentNodeTime = now.Format("Y-m-d H:i:s")
  97. instance.ProcessInstId = instanceId
  98. instance.Remark = remark
  99. // 填充创建信息
  100. service.SetCreatedInfo(&instance, s.GetCxtUserId(), s.GetCxtUserName())
  101. // 保存数据并返回
  102. return s.Dao.InsertAndGetId(instance)
  103. }
  104. // GetWorkflowInstance 获取实例(本地数据)
  105. func (s *workflowService) GetWorkflowInstance(instanceId string) (*model.PlatWorkflow, error) {
  106. // 查询日程实例
  107. return s.Dao.Where("process_inst_id", instanceId).FindOne()
  108. }
  109. // Update 更新(本地数据)
  110. func (s *workflowService) Update(instance *model.PlatWorkflow, msg *message.MixMessage) (err error) {
  111. // 保存实例
  112. instance.CurrentNode = msg.ProcessType
  113. instance.CurrentNodeTime = time.Unix(gconv.Int64(msg.FinishTime), 0).Format("2006-01-02 15:04:05")
  114. instance.ApprovalResult = msg.Result
  115. _, err = s.Dao.Save(instance)
  116. return
  117. }
  118. // GetList 任务信息列表(本地数据)
  119. func (s *workflowService) GetList(req *model.SearchWorkflowReq) (total int, flowList []*model.PlatWorkflow, err error) {
  120. flowModel := s.Dao.M
  121. if req.BizCode != "" {
  122. flowModel = flowModel.Where("biz_code", req.BizCode)
  123. }
  124. if req.BizType != "" {
  125. flowModel = flowModel.Where("biz_type", req.BizType)
  126. }
  127. if req.MySelf != "0" {
  128. flowModel = flowModel.Where("created_by", s.GetCxtUserId())
  129. }
  130. total, err = flowModel.Count()
  131. if err != nil {
  132. g.Log().Error(err)
  133. err = myerrors.DbError("获取总行数失败。")
  134. return
  135. }
  136. err = flowModel.Page(req.GetPage()).Order("plat_task.created_time DESC").Scan(&flowList)
  137. return
  138. }