quality_audit.service.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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. "time"
  12. "github.com/kataras/iris/v12"
  13. "go.mod/dao"
  14. "go.mod/datasource"
  15. "go.mod/web/viewmodels"
  16. )
  17. type QualityAuditService interface {
  18. ValidRule(ctx iris.Context) (viewmodels.QualityAudit, error)
  19. ValidStart(ctx iris.Context) (viewmodels.QualityAuditStart, error)
  20. // AddAuditor(safeId int, bId int, auditId int, times int) error
  21. CloseAudit(id int, opinion string, curUid int, saveId int) error
  22. BackAudit(id int, opinion string, curUid int, saveId int, auditId int) error
  23. PassAudit(id int, uid int, auditId int, opinion string, rectifiedInfo string) error
  24. StartAudit(safeId int, bidsectionId int, auditors []int, reAuditors []int, uid int, pid int, inspection string, inspectionDetail string, demand string, createTime time.Time) error
  25. }
  26. type qualityAuditService struct {
  27. validAdd string
  28. validPass string
  29. validClose string
  30. validBack string
  31. daoQualityAudit *dao.QualityAuditDao
  32. daoQuality *dao.QualityDao
  33. daoApprover *dao.ApproverDao
  34. }
  35. //创建项目用户service
  36. func NewQualityAuditService() QualityAuditService {
  37. return &qualityAuditService{
  38. validBack: "/api/quality_audit/back",
  39. validAdd: "/api/quality_audit/add",
  40. validClose: "/api/quality_audit/close",
  41. validPass: "/api/quality_audit/pass",
  42. daoQualityAudit: dao.NewQualityAuditDao(datasource.InstanceDbMaster()),
  43. daoQuality: dao.NewQualityDao(datasource.InstanceDbMaster()),
  44. daoApprover: dao.NewApproverDao(datasource.InstanceDbMaster()),
  45. }
  46. }
  47. // 关闭审批流程
  48. func (s *qualityAuditService) CloseAudit(id int, opinion string, curUid int, saveId int) error {
  49. err := s.daoApprover.CloseHandler("quality", id, opinion, curUid, saveId)
  50. return err
  51. }
  52. // 审批退回
  53. func (s *qualityAuditService) BackAudit(id int, opinion string, curUid int, saveId int, auditId int) error {
  54. auditor, err := s.daoApprover.FindApproverById(id)
  55. if auditor.AuditId != curUid {
  56. return errors.New("该用户没有审批权限")
  57. }
  58. safe := s.daoQuality.FindById(saveId)
  59. // 退回到了检查人
  60. if auditId == 0 {
  61. // 初始化审批流程
  62. err = s.daoApprover.InitStatus("quality", auditor.BidsectionId, auditor.DataType, auditor.DataId, auditor.AuditId, safe.Times, auditor.Progress+1, opinion)
  63. } else {
  64. // 退回到审批流程中的某一个人
  65. err = s.daoApprover.BackHandlerWithId("quality", auditId, auditor.AuditId, safe.Times, auditor.Progress+1, opinion)
  66. }
  67. return err
  68. }
  69. // 审批通过
  70. func (s *qualityAuditService) PassAudit(id int, uid int, auditId int, opinion string, rectifiedInfo string) error {
  71. err := s.daoApprover.PassHandler("quality", id, uid, auditId, opinion, rectifiedInfo)
  72. return err
  73. }
  74. func (s *qualityAuditService) StartAudit(qualityId int, bidsectionId int, auditors []int, reAuditors []int, uid int, pid int, inspection string, inspectionDetail string, demand string, createTime time.Time) error {
  75. quality := s.daoQuality.FindById(qualityId)
  76. if quality.Uid != uid {
  77. return errors.New("该用户没有操作权限")
  78. }
  79. // 清除可能有的旧的审批流程
  80. err := s.daoApprover.DeleteOldAuditors(bidsectionId, 1, qualityId)
  81. if err != nil {
  82. return err
  83. }
  84. // 增加审批日志
  85. err = s.daoQualityAudit.AddAuditRecord(qualityId, bidsectionId, uid, quality.Times, 0, 0, "", "")
  86. if err != nil {
  87. return err
  88. }
  89. // 改变安全巡检表的状态
  90. err = s.daoQuality.ChangeStatus(qualityId, 1, inspection, inspectionDetail, demand, createTime)
  91. if err != nil {
  92. return err
  93. }
  94. // 创建审批流程
  95. err = s.daoApprover.InsertData(uid, bidsectionId, pid, 1, qualityId, auditors, reAuditors)
  96. if err != nil {
  97. return err
  98. }
  99. return err
  100. }
  101. // 规则校验
  102. func (s *qualityAuditService) ValidRule(ctx iris.Context) (viewmodels.QualityAudit, error) {
  103. qualityAuditVaild := viewmodels.QualityAudit{}
  104. if ctx.Method() == "POST" {
  105. err := ctx.ReadJSON(&qualityAuditVaild)
  106. if err != nil {
  107. log.Println("quality-ValidRule-ReadJson转换异常, error=", err)
  108. return qualityAuditVaild, err
  109. }
  110. if ctx.Path() == s.validAdd {
  111. err = qualityAuditVaild.ValidateQualityAddAuditor()
  112. return qualityAuditVaild, err
  113. } else if ctx.Path() == s.validClose {
  114. err = qualityAuditVaild.ValidateQualityClose()
  115. return qualityAuditVaild, err
  116. } else if ctx.Path() == s.validBack {
  117. err = qualityAuditVaild.ValidateQualityBack()
  118. return qualityAuditVaild, err
  119. } else if ctx.Path() == s.validPass {
  120. err = qualityAuditVaild.ValidateQualityPass()
  121. return qualityAuditVaild, err
  122. }
  123. return qualityAuditVaild, err
  124. }
  125. return qualityAuditVaild, nil
  126. }
  127. // 校验审批开始
  128. func (s *qualityAuditService) ValidStart(ctx iris.Context) (viewmodels.QualityAuditStart, error) {
  129. startAuditValid := viewmodels.QualityAuditStart{}
  130. err := ctx.ReadJSON(&startAuditValid)
  131. if err != nil {
  132. log.Println("safe-ValidRule-ReadJson转换异常, error=", err)
  133. return startAuditValid, err
  134. }
  135. err = startAuditValid.ValidateQualityStart()
  136. return startAuditValid, err
  137. }