contract_service.go 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. /*
  2. * @description: 合同数据相关操作
  3. * @Author: CP
  4. * @Date: 2020-10-27 11:28:24
  5. * @FilePath: \design_quantity\services\contract_service.go
  6. */
  7. package services
  8. import (
  9. "errors"
  10. "fmt"
  11. "html"
  12. "log"
  13. "strconv"
  14. "time"
  15. "github.com/kataras/iris/v12"
  16. "go.mod/comm"
  17. "go.mod/conf"
  18. "go.mod/dao"
  19. "go.mod/datasource"
  20. "go.mod/models"
  21. "go.mod/web/viewmodels"
  22. )
  23. //定义项目用户Service接口
  24. type ContractService interface {
  25. ValidRuleDepth(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  26. ValidRuleTemplate(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  27. ValidRuleSectionAdd(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  28. ValidRuleSectionDelete(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  29. ValidRuleSectionNot(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  30. ValidRuleGet(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  31. ValidRuleUpdateFile(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  32. ValidRuleSerial(ctx iris.Context) (*viewmodels.TreeSectionContract, error)
  33. // 项目节
  34. GetSecionTree(operation string) *viewmodels.TreeSectionContract
  35. SetSection() error
  36. GetSection(id int) (string, *viewmodels.TreeSectionDetail, *viewmodels.TreeSectionDetail)
  37. SectionAdd(sectionData *viewmodels.TreeSectionContract) (*models.CmTreeContracts, error)
  38. SectionSave(sectionData *viewmodels.TreeSectionContract) error
  39. UpdateSerial(sectionData *viewmodels.TreeSectionContract) error
  40. SectionDelete(treeId int) error
  41. MoveDepth(sectionData *viewmodels.TreeSectionContract) error
  42. MoveSerial(sectionData *viewmodels.TreeSectionContract) error
  43. UpdateContractId(id int, contractId int) error
  44. SaveUpload(Location string, Filename string, ext string) (string, error)
  45. }
  46. //返回service操作类
  47. type contractService struct {
  48. treeContractDao *dao.TreeContractDao
  49. contractDao *dao.ContractDao
  50. contractReturnDao *dao.ContractReturnDao
  51. contractPaidDao *dao.ContractPaidDao
  52. treeDao *dao.TreeDao
  53. annexDao *dao.AnnexDao
  54. uploadDao *dao.UploadDao
  55. }
  56. //创建项目用户service
  57. func NewContractService() ContractService {
  58. return &contractService{
  59. treeContractDao: dao.NewTreeContractDao(datasource.InstanceDbMaster()),
  60. contractDao: dao.NewContractDao(datasource.InstanceDbMaster()),
  61. contractReturnDao: dao.NewContractReturnDao(datasource.InstanceDbMaster()),
  62. contractPaidDao: dao.NewContractPaidDao(datasource.InstanceDbMaster()),
  63. treeDao: dao.NewTreeDao(datasource.InstanceDbMaster()),
  64. annexDao: dao.NewAnnexDao(datasource.InstanceDbMaster()),
  65. uploadDao: dao.NewUploadDao(datasource.InstanceDbMaster()),
  66. }
  67. }
  68. // 升级降级规则验证
  69. func (s *contractService) ValidRuleDepth(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  70. treeSectionVaild := &viewmodels.TreeSectionContract{}
  71. err := ctx.ReadJSON(treeSectionVaild)
  72. if err != nil {
  73. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  74. return treeSectionVaild, err
  75. }
  76. err = treeSectionVaild.ValidateDepth()
  77. if err != nil {
  78. log.Println("参数验证错误, error=", err)
  79. return treeSectionVaild, err
  80. }
  81. return treeSectionVaild, nil
  82. }
  83. // 模板规则验证
  84. func (s *contractService) ValidRuleTemplate(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  85. treeSectionVaild := &viewmodels.TreeSectionContract{}
  86. err := ctx.ReadJSON(treeSectionVaild)
  87. if err != nil {
  88. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  89. return treeSectionVaild, err
  90. }
  91. err = treeSectionVaild.ValidateTemplate()
  92. if err != nil {
  93. log.Println("参数验证错误, error=", err)
  94. return treeSectionVaild, err
  95. }
  96. return treeSectionVaild, nil
  97. }
  98. // 模板规则新增项目节
  99. func (s *contractService) ValidRuleSectionAdd(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  100. treeSectionVaild := &viewmodels.TreeSectionContract{}
  101. err := ctx.ReadJSON(treeSectionVaild)
  102. if err != nil {
  103. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  104. return treeSectionVaild, err
  105. }
  106. err = treeSectionVaild.ValidateSectionAdd()
  107. if err != nil {
  108. log.Println("参数验证错误, error=", err)
  109. return treeSectionVaild, err
  110. }
  111. return treeSectionVaild, nil
  112. }
  113. // 模板规则新增项目节
  114. func (s *contractService) ValidRuleSectionDelete(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  115. treeSectionVaild := &viewmodels.TreeSectionContract{}
  116. err := ctx.ReadJSON(treeSectionVaild)
  117. if err != nil {
  118. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  119. return treeSectionVaild, err
  120. }
  121. err = treeSectionVaild.ValidateSectionDelete()
  122. if err != nil {
  123. log.Println("参数验证错误, error=", err)
  124. return treeSectionVaild, err
  125. }
  126. return treeSectionVaild, nil
  127. }
  128. func (s *contractService) ValidRuleSectionNot(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  129. treeSectionVaild := &viewmodels.TreeSectionContract{}
  130. err := ctx.ReadForm(treeSectionVaild)
  131. if err != nil {
  132. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  133. return treeSectionVaild, err
  134. }
  135. err = treeSectionVaild.ValidateSectionNot()
  136. if err != nil {
  137. log.Println("参数验证错误, error=", err)
  138. return treeSectionVaild, err
  139. }
  140. return treeSectionVaild, nil
  141. }
  142. func (s *contractService) ValidRuleGet(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  143. treeSectionVaild := &viewmodels.TreeSectionContract{}
  144. err := ctx.ReadForm(treeSectionVaild)
  145. if err != nil {
  146. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  147. return treeSectionVaild, err
  148. }
  149. err = treeSectionVaild.ValidateSectionDelete()
  150. if err != nil {
  151. log.Println("参数验证错误, error=", err)
  152. return treeSectionVaild, err
  153. }
  154. return treeSectionVaild, nil
  155. }
  156. // 验证序号相关
  157. func (s *contractService) ValidRuleSerial(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  158. treeSectionVaild := &viewmodels.TreeSectionContract{}
  159. err := ctx.ReadJSON(treeSectionVaild)
  160. if err != nil {
  161. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  162. return treeSectionVaild, err
  163. }
  164. err = treeSectionVaild.ValidateSectionSerial()
  165. if err != nil {
  166. log.Println("参数验证错误, error=", err)
  167. return treeSectionVaild, err
  168. }
  169. return treeSectionVaild, nil
  170. }
  171. // 验证更新附件相关
  172. func (s *contractService) ValidRuleUpdateFile(ctx iris.Context) (*viewmodels.TreeSectionContract, error) {
  173. treeSectionVaild := &viewmodels.TreeSectionContract{}
  174. err := ctx.ReadJSON(treeSectionVaild)
  175. if err != nil {
  176. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  177. return treeSectionVaild, err
  178. }
  179. err = treeSectionVaild.ValidateFile()
  180. if err != nil {
  181. log.Println("参数验证错误, error=", err)
  182. return treeSectionVaild, err
  183. }
  184. return treeSectionVaild, nil
  185. }
  186. // 新增合同参数验证
  187. func (s *contractService) ValidRuleContractAdd(ctx iris.Context) (*viewmodels.Contracts, error) {
  188. // 创建一个存放前端传过来参数
  189. contractsVaild := &viewmodels.Contracts{}
  190. // 存放raw的值,放入到contractsVaild
  191. err := ctx.ReadJSON(contractsVaild)
  192. if err != nil {
  193. log.Println("folder-ValidRule-ReadForm转换异常, error=", err)
  194. return contractsVaild, err
  195. }
  196. // 验证合同传参
  197. err = contractsVaild.ValidateAdd()
  198. if err != nil {
  199. log.Println("参数验证错误, error=", err)
  200. return contractsVaild, err
  201. }
  202. // xss
  203. contractsVaild.Code = html.EscapeString(contractsVaild.Code)
  204. contractsVaild.Name = html.EscapeString(contractsVaild.Name)
  205. contractsVaild.Price = html.EscapeString(contractsVaild.Price)
  206. return contractsVaild, nil
  207. }
  208. // 新增合同
  209. func (s *contractService) Add(contractData *viewmodels.Contracts, treeId int) error {
  210. // 1. 项目节存在
  211. contracts := s.treeContractDao.Get(treeId)
  212. if contracts.Id == 0 {
  213. return errors.New("未找到项目节")
  214. }
  215. // 2.项目节是没有合同
  216. if contracts.ContractId != 0 {
  217. return errors.New("该项目节上已经存在合同")
  218. }
  219. // 3.新增合同 --合计标段上的金额
  220. contractsCm := &models.CmContracts{}
  221. contractsCm.Code = contractData.Code
  222. contractsCm.Name = contractData.Name
  223. contractsCm.ContractsType = 1
  224. contractsCm.Price = contractData.Price
  225. contractsCm.Returned = "0"
  226. contractsCm.Paid = "0"
  227. contractsCm.TreeId = treeId
  228. contractsCm.Status = 0
  229. contractsCm.CreateTime = time.Now()
  230. contractsCm.UpdateTime = time.Now()
  231. err := s.contractDao.Add(contractsCm)
  232. if err != nil {
  233. return err
  234. }
  235. return nil
  236. }
  237. // 保存上传文件
  238. func (s *contractService) SaveUpload(Location string, Filename string, ext string) (string, error) {
  239. // 文件保存
  240. uploadCm := &models.CmUpload{}
  241. uploadCm.Name = Filename
  242. uploadCm.Path = Location
  243. uploadCm.Ext = ext
  244. _, err := s.uploadDao.Add(uploadCm)
  245. if err != nil {
  246. fmt.Println(err)
  247. return "0", err
  248. }
  249. id, _ := comm.AesEncrypt(strconv.Itoa(uploadCm.Id), conf.SignSecret)
  250. return id, nil
  251. }