safe_audit.service.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. /*
  2. * @description: 安全巡检审批相关
  3. * @Author: LanJianRong
  4. * @Date: 2020-12-18
  5. * @FilePath: \construction_management\web\api\safe_rpc_api.go
  6. */
  7. package services
  8. import (
  9. "errors"
  10. "log"
  11. "github.com/kataras/iris/v12"
  12. "go.mod/dao"
  13. "go.mod/datasource"
  14. "go.mod/web/viewmodels"
  15. )
  16. type SafeAuditService interface {
  17. ValidRule(ctx iris.Context) (viewmodels.SafeAudit, error)
  18. ValidStart(ctx iris.Context) (viewmodels.AuditStart, error)
  19. // AddAuditor(safeId int, bId int, auditId int, times int) error
  20. CloseAudit(id int, opinion string, curUid int, saveId int) error
  21. BackAudit(id int, opinion string, curUid int, saveId int, auditId int) error
  22. PassAudit(id int, uid int, auditId int, opinion string, rectifiedInfo string) error
  23. StartAudit(safeId int, bidsectionId int, auditors []int, reAuditors []int, uid int, pid int) error
  24. }
  25. type safeAuditService struct {
  26. validAdd string
  27. validPass string
  28. validClose string
  29. validBack string
  30. daoSafeAudit *dao.SafeAuditDao
  31. daoSafe *dao.SafeDao
  32. daoApprover *dao.ApproverDao
  33. }
  34. //创建项目用户service
  35. func NewSafeAuditService() SafeAuditService {
  36. return &safeAuditService{
  37. validBack: "/api/safe_audit/back",
  38. validAdd: "/api/safe_audit/add",
  39. validClose: "/api/safe_audit/close",
  40. validPass: "/api/safe_audit/pass",
  41. daoSafeAudit: dao.NewSafeAuditDao(datasource.InstanceDbMaster()),
  42. daoSafe: dao.NewSafeDao(datasource.InstanceDbMaster()),
  43. daoApprover: dao.NewApproverDao(datasource.InstanceDbMaster()),
  44. }
  45. }
  46. // 关闭审批流程
  47. func (s *safeAuditService) CloseAudit(id int, opinion string, curUid int, saveId int) error {
  48. auditor, err := s.daoApprover.FindApproverById(id)
  49. if auditor.AuditId != curUid {
  50. return errors.New("该用户没有审批权限!")
  51. }
  52. safe := s.daoSafe.FindById(auditor.DataId)
  53. // 增加审批日志记录
  54. err = s.daoSafeAudit.AddAuditRecord(auditor.DataId, auditor.BidsectionId, auditor.AuditId, safe.Times, 2, auditor.Progress, "")
  55. // 更改cm_safe的记录
  56. err = s.daoSafe.ChangeStatus(saveId, 5)
  57. // 更改cm_approver的记录
  58. err = s.daoApprover.ChangeStatus(id, 3)
  59. return err
  60. }
  61. // 审批退回
  62. func (s *safeAuditService) BackAudit(id int, opinion string, curUid int, saveId int, auditId int) error {
  63. auditor, err := s.daoApprover.FindApproverById(id)
  64. if auditor.AuditId != curUid {
  65. return errors.New("该用户没有审批权限!")
  66. }
  67. safe := s.daoSafe.FindById(saveId)
  68. // 增加审批日志
  69. err = s.daoSafeAudit.AddAuditRecord(auditor.DataId, auditor.BidsectionId, auditor.AuditId, safe.Times, 1, auditor.Progress, "")
  70. if err != nil {
  71. return err
  72. }
  73. // 退回到了检查人
  74. if auditId == 0 {
  75. // 初始化审批流程
  76. err = s.daoApprover.InitStatus(auditor.BidsectionId, auditor.DataType, auditor.DataId)
  77. } else {
  78. // 退回到审批流程中的某一个人
  79. err = s.daoApprover.BackHandlerWithId(auditId)
  80. }
  81. safeData := s.daoSafe.FindById(saveId)
  82. err = s.daoSafeAudit.CopyAuditors(saveId, safeData.Times, auditId)
  83. return err
  84. }
  85. // 审批通过
  86. func (s *safeAuditService) PassAudit(id int, uid int, auditId int, opinion string, rectifiedInfo string) error {
  87. auditor, err := s.daoApprover.FindApproverById(id)
  88. if err != nil {
  89. return err
  90. }
  91. // 获取安全巡检记录
  92. safe := s.daoSafe.FindById(auditor.DataId)
  93. if auditor.AuditId != uid {
  94. return errors.New("该用户没有审批权限!")
  95. }
  96. // 增加审批日志
  97. err = s.daoSafeAudit.AddAuditRecord(auditor.DataId, auditor.BidsectionId, auditor.AuditId, safe.Times, 0, auditor.Progress, rectifiedInfo)
  98. // 改变审批流程中当前审批人以及下一个审批人的审批流程状态
  99. err = s.daoApprover.ChangeStatus(id, 2)
  100. err = s.daoApprover.ChangeNextStatus(id, 1)
  101. // 审批人选择了整改人
  102. if auditId != 0 {
  103. // 修改cm_safe表的status状态为待整改
  104. err = s.daoSafe.ChangeStatus(auditor.DataId, 2)
  105. // 改变审批流程中的整改人id
  106. err = s.daoApprover.ChangeAuditId(auditor.BidsectionId, auditor.DataType, auditor.DataId, auditor.AuditOrder+1, auditId)
  107. } else {
  108. if auditor.Progress == 1 {
  109. // 整改人审批流程
  110. // 修改cm_safe表的status状态为待复查
  111. err = s.daoSafe.ChangeStatus(auditor.DataId, 3)
  112. } else {
  113. // 复查流程
  114. // 查找最后一个审批人
  115. lastAuditor, err := s.daoApprover.GetLastAuditor(auditor.BidsectionId, auditor.DataType, auditor.DataId)
  116. if err != nil {
  117. return err
  118. }
  119. if lastAuditor.AuditId == auditor.Id {
  120. // 说明审批流程已经走完
  121. err = s.daoSafe.ChangeStatus(auditor.DataId, 4)
  122. }
  123. }
  124. }
  125. return err
  126. }
  127. func (s *safeAuditService) StartAudit(safeId int, bidsectionId int, auditors []int, reAuditors []int, uid int, pid int) error {
  128. safe := s.daoSafe.FindById(safeId)
  129. if safe.Uid != uid {
  130. return errors.New("该用户没有操作权限!")
  131. }
  132. // 清除可能有的旧的审批流程
  133. err := s.daoApprover.DeleteOldAuditors(bidsectionId, 1, safeId)
  134. // 增加审批日志
  135. err = s.daoSafeAudit.AddAuditRecord(safeId, bidsectionId, uid, safe.Times, 0, 0, "")
  136. // 改变安全巡检表的状态
  137. err = s.daoSafe.ChangeStatus(safeId, 1)
  138. // 创建审批流程
  139. err = s.daoApprover.InsertData(safe.Times, bidsectionId, pid, 1, safeId, auditors, reAuditors)
  140. return err
  141. }
  142. // 规则校验
  143. func (s *safeAuditService) ValidRule(ctx iris.Context) (viewmodels.SafeAudit, error) {
  144. safeAuditVaild := viewmodels.SafeAudit{}
  145. if ctx.Method() == "POST" {
  146. err := ctx.ReadJSON(&safeAuditVaild)
  147. if err != nil {
  148. log.Println("safe-ValidRule-ReadJson转换异常, error=", err)
  149. return safeAuditVaild, err
  150. }
  151. if ctx.Path() == s.validAdd {
  152. err = safeAuditVaild.ValidateAddAuditor()
  153. return safeAuditVaild, err
  154. } else if ctx.Path() == s.validClose {
  155. err = safeAuditVaild.ValidateClose()
  156. return safeAuditVaild, err
  157. } else if ctx.Path() == s.validBack {
  158. err = safeAuditVaild.ValidateBack()
  159. return safeAuditVaild, err
  160. } else if ctx.Path() == s.validPass {
  161. err = safeAuditVaild.ValidatePass()
  162. return safeAuditVaild, err
  163. }
  164. return safeAuditVaild, err
  165. }
  166. return safeAuditVaild, nil
  167. }
  168. // 校验审批开始
  169. func (s *safeAuditService) ValidStart(ctx iris.Context) (viewmodels.AuditStart, error) {
  170. startAuditValid := viewmodels.AuditStart{}
  171. err := ctx.ReadJSON(&startAuditValid)
  172. if err != nil {
  173. log.Println("safe-ValidRule-ReadJson转换异常, error=", err)
  174. return startAuditValid, err
  175. }
  176. err = startAuditValid.ValidateStart()
  177. return startAuditValid, err
  178. }