safe_service.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. package services
  2. import (
  3. "errors"
  4. "fmt"
  5. "log"
  6. "strconv"
  7. "time"
  8. "github.com/kataras/iris/v12"
  9. "go.mod/comm"
  10. "go.mod/conf"
  11. "go.mod/dao"
  12. "go.mod/datasource"
  13. "go.mod/models"
  14. "go.mod/web/viewmodels"
  15. )
  16. type SafeService interface {
  17. Get(id int, pid int, pageNo int, pageSize int) ([]viewmodels.SafeList, int64)
  18. Post(data models.CmSafe) error
  19. Del(id int) error
  20. GetDetail(id int, pid int) viewmodels.SafeDetail
  21. GetSurvey(projectId int, bidsectionId int) map[string]interface{}
  22. ValidRule(ctx iris.Context) (viewmodels.Safe, error)
  23. }
  24. // //返回service操作类
  25. type safeService struct {
  26. daoSafe *dao.SafeDao
  27. daoSafeAudit *dao.SafeAuditDao
  28. daoProjectAccount *dao.ProjectAccountDao
  29. daoAnnex *dao.AnnexDao
  30. daoRule *dao.RuleDao
  31. validDetail string
  32. }
  33. //创建项目用户service
  34. func NewSafeService() SafeService {
  35. return &safeService{
  36. validDetail: "/api/safe/detail",
  37. daoSafe: dao.NewSafeDao(datasource.InstanceDbMaster()),
  38. daoAnnex: dao.NewAnnexDao(datasource.InstanceDbMaster()),
  39. daoSafeAudit: dao.NewSafeAuditDao(datasource.InstanceDbMaster()),
  40. daoProjectAccount: dao.NewProjectAccountDao(datasource.InstanceDbMaster()),
  41. }
  42. }
  43. func (s *safeService) Get(id int, pid int, pageNo int, pageSize int) ([]viewmodels.SafeList, int64) {
  44. datalist, total := s.daoSafe.GetListByBid(id, pageNo, pageSize)
  45. safeList := make([]viewmodels.SafeList, 0)
  46. for _, item := range datalist {
  47. safeVM := viewmodels.SafeList{}
  48. safeVM.Code = item.Code
  49. account := s.daoProjectAccount.Get(item.Uid, pid)
  50. safeVM.AuditName = account.Name
  51. safeVM.CreateTime = item.CreateTime.Format(conf.SysTimeform)
  52. safeVM.Demand = item.Demand
  53. id, _ := comm.AesEncrypt(strconv.Itoa(item.Id), conf.SignSecret)
  54. safeVM.Id = id
  55. safeVM.Inspection = item.Inspection
  56. safeVM.InspectionDetail = item.InspectionDetail
  57. safeVM.Position = item.Position
  58. safeVM.Status = item.Status
  59. counts, _ := s.daoAnnex.GetCount(3, item.Id)
  60. safeVM.FileCounts = counts
  61. safeList = append(safeList, safeVM)
  62. }
  63. return safeList, total
  64. }
  65. // post请求,插入单条数据
  66. func (s *safeService) Post(data models.CmSafe) error {
  67. has := s.daoSafe.FindByCode(data.Code)
  68. if has {
  69. return errors.New("该编号已存在!")
  70. }
  71. Inserted, err := s.daoSafe.InsertRecord(data)
  72. if Inserted == true {
  73. return nil
  74. }
  75. return err
  76. }
  77. // delete请求,删除数据
  78. func (s *safeService) Del(id int) error {
  79. Deleted, err := s.daoSafe.DeleteRecord(id)
  80. if Deleted == true {
  81. return nil
  82. }
  83. return err
  84. }
  85. // 详情页数据拼装
  86. func (s *safeService) GetDetail(id int, pid int) viewmodels.SafeDetail {
  87. safeData := s.daoSafe.FindById(id)
  88. // fmt.Println(safeData)
  89. safeId, _ := comm.AesEncrypt(strconv.Itoa(safeData.Id), conf.SignSecret)
  90. bid, _ := comm.AesEncrypt(strconv.Itoa(safeData.BidsectionId), conf.SignSecret)
  91. data := viewmodels.SafeDetail{}
  92. data.Id = string(safeId)
  93. data.BidsectionId = string(bid)
  94. data.Code = safeData.Code
  95. data.Inspection = safeData.Inspection
  96. data.InspectionDetail = safeData.InspectionDetail
  97. data.Demand = safeData.Demand
  98. account := s.daoProjectAccount.Get(safeData.Uid, pid)
  99. data.AuditName = account.Name
  100. data.CreateTime = safeData.CreateTime
  101. data.Times = safeData.Times
  102. data.Status = safeData.Status
  103. fileList, total := s.daoAnnex.GetList(3, safeData.Id, 1, conf.PageSize)
  104. // 加密id
  105. fileArr := make([]viewmodels.AnnexListView, 0)
  106. for _, item := range fileList {
  107. fileListVM := viewmodels.AnnexListView{}
  108. fileId, _ := comm.AesEncrypt(item.Id, conf.SignSecret)
  109. fileListVM.Id = fileId
  110. uid, _ := comm.AesEncrypt(item.AccountId, conf.SignSecret)
  111. fileListVM.AccountId = uid
  112. fileListVM.AccountName = item.AccountName
  113. fileListVM.CreateTime = item.CreateTime
  114. fileListVM.FileName = item.FileName
  115. fileListVM.FilePath = item.FilePath
  116. fileArr = append(fileArr, fileListVM)
  117. }
  118. fileVM := viewmodels.FileStruct{}
  119. fileVM.FileList = fileArr
  120. fileVM.Total = total
  121. data.File = fileVM
  122. auditors := s.daoSafeAudit.GetAuditorsWithOwner(safeData.Id, safeData.Times, account.Id)
  123. encryptAuditors := make([]viewmodels.Auditors, 0)
  124. for i, item := range auditors {
  125. auditorVM := viewmodels.Auditors{}
  126. auditId, _ := comm.AesEncrypt(item.AuditId, conf.SignSecret)
  127. if i == 0 {
  128. auditorVM.Id = ""
  129. } else {
  130. id, _ := comm.AesEncrypt(item.Id, conf.SignSecret)
  131. auditorVM.Id = id
  132. }
  133. auditorVM.AuditId = auditId
  134. auditorVM.Name = item.Name
  135. auditorVM.Position = item.Position
  136. auditorVM.Mobile = item.Mobile
  137. auditorVM.AuditOrder = item.AuditOrder
  138. auditorVM.AccountGroup = item.AccountGroup
  139. auditorVM.Progress = item.Progress
  140. auditorVM.Company = item.Company
  141. auditorVM.Status = item.Status
  142. encryptAuditors = append(encryptAuditors, auditorVM)
  143. }
  144. auditHistory := s.daoSafeAudit.GetAuditHistory(safeData.Id, safeData.Times)
  145. data.AuditHistory = auditHistory
  146. // 整改单
  147. rectifiedInfo, _ := s.daoSafeAudit.GetLastedOrder(safeData.Id)
  148. data.RectifiedInfo = rectifiedInfo
  149. // 最新审批人信息
  150. latestAuditor, _ := s.daoSafeAudit.GetLastedAuditor(safeData.Times, safeData.Id)
  151. data.LatestdAuditor = latestAuditor
  152. data.Auditors = encryptAuditors
  153. return data
  154. }
  155. // 安全概况
  156. func (s *safeService) GetSurvey(projectId int, bidsectionId int) map[string]interface{} {
  157. // 1.获得安全巡检
  158. year := time.Now().Year()
  159. safelist := s.daoSafe.GetTypeYear(bidsectionId, year)
  160. // 2.初始化
  161. rectifylist := make([]models.CmSafe, 0)
  162. rectifyTotal := 0
  163. approvalTotal := 0
  164. rectifyedTotal := 0
  165. // 3.当年数据初始化
  166. submitData := map[string]float64{
  167. fmt.Sprintf("%d-01", year): 0,
  168. fmt.Sprintf("%d-02", year): 0,
  169. fmt.Sprintf("%d-03", year): 0,
  170. fmt.Sprintf("%d-04", year): 0,
  171. fmt.Sprintf("%d-05", year): 0,
  172. fmt.Sprintf("%d-06", year): 0,
  173. fmt.Sprintf("%d-07", year): 0,
  174. fmt.Sprintf("%d-08", year): 0,
  175. fmt.Sprintf("%d-09", year): 0,
  176. fmt.Sprintf("%d-10", year): 0,
  177. fmt.Sprintf("%d-11", year): 0,
  178. fmt.Sprintf("%d-12", year): 0,
  179. }
  180. rectifyedData := submitData
  181. for _, item := range safelist {
  182. if item.Status == 2 {
  183. rectifylist = append(rectifylist, item)
  184. rectifyTotal++
  185. }
  186. if item.Status == 1 {
  187. approvalTotal++
  188. }
  189. if item.Status == 4 {
  190. rectifyedTotal++
  191. }
  192. if item.Status == 0 {
  193. submitData[item.CreateTime.Format(conf.SysTimeformMonth)] = submitData[item.CreateTime.Format(conf.SysTimeformMonth)] + 1
  194. }
  195. if item.Status == 4 {
  196. rectifyedData[item.CreateTime.Format(conf.SysTimeformMonth)] = rectifyedData[item.CreateTime.Format(conf.SysTimeformMonth)] + 1
  197. }
  198. }
  199. // 整改占总数比例 - 完成整改/提交巡检
  200. surveryData := map[string]interface{}{
  201. "rectifylist": rectifylist,
  202. "rectifyTotal": rectifyTotal,
  203. "approvalTotal": approvalTotal,
  204. "rectifyedTotal": rectifyedTotal,
  205. "submitData": submitData,
  206. "rectifyedData": rectifyedData,
  207. }
  208. return surveryData
  209. }
  210. // 规则校验
  211. func (s *safeService) ValidRule(ctx iris.Context) (viewmodels.Safe, error) {
  212. safeVaild := viewmodels.Safe{}
  213. // fmt.Println("---------------------------safeVaild", safeVaild)
  214. if ctx.Method() == "GET" {
  215. err := ctx.ReadForm(&safeVaild)
  216. if err != nil {
  217. log.Println("safe-ValidRule-ReadForm转换异常, error=", err)
  218. return safeVaild, err
  219. }
  220. if ctx.Path() == s.validDetail {
  221. // 一样要传id,所以用delete的方法判断
  222. err = safeVaild.ValidateDelete()
  223. } else {
  224. err = safeVaild.ValidateList()
  225. }
  226. return safeVaild, err
  227. }
  228. if ctx.Method() == "POST" {
  229. err := ctx.ReadJSON(&safeVaild)
  230. if err != nil {
  231. log.Println("safe-ValidRule-ReadJson转换异常, error=", err)
  232. return safeVaild, err
  233. }
  234. err = safeVaild.ValidateCreate()
  235. return safeVaild, err
  236. // if ctx.Path() == s.validCreate {
  237. // }
  238. // if ctx.Path() == s.validFile {
  239. // err = safeVaild.ValidateFile()
  240. // return safeVaild, err
  241. // }
  242. }
  243. if ctx.Method() == "PUT" {
  244. err := ctx.ReadForm(&safeVaild)
  245. if err != nil {
  246. log.Println("safe-ValidRule-ReadForm转换异常, error=", err)
  247. return safeVaild, err
  248. }
  249. err = safeVaild.ValidateDelete()
  250. return safeVaild, err
  251. }
  252. return safeVaild, nil
  253. }