thjNtf.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. package service
  2. import (
  3. "encoding/hex"
  4. "fmt"
  5. "mtp20_assisted/global"
  6. "mtp20_assisted/model"
  7. "mtp20_assisted/res/pb"
  8. "mtp20_assisted/utils"
  9. "os"
  10. "strconv"
  11. "strings"
  12. "time"
  13. "github.com/gofrs/uuid"
  14. "github.com/nguyenthenguyen/docx"
  15. "go.uber.org/zap"
  16. "google.golang.org/protobuf/proto"
  17. )
  18. // THJNtf 铁合通知处理模型
  19. type THJNtf struct{}
  20. func (t *THJNtf) Process(msg *[]byte) {
  21. // 分解总线包信息
  22. funcode := utils.BytesToUint32((*msg)[0:4])
  23. sessionId := utils.BytesToUint32((*msg)[4:8])
  24. bytes := (*msg)[8:]
  25. global.M2A_LOG.Info("[S->C]", zap.Any("funcode", funcode), zap.Any("sessionId", sessionId), zap.Any("count", len(bytes)))
  26. switch funcode {
  27. case uint32(global.THJPurchaseTradeNtf):
  28. // 等待两秒
  29. <-time.After(2 * time.Second)
  30. onTHJPurchaseTradeNtf(&bytes)
  31. }
  32. }
  33. // onTHJPurchaseTradeNtf 铁合金成交通知
  34. func onTHJPurchaseTradeNtf(bytes *[]byte) {
  35. // Read from docx file
  36. r, err := docx.ReadDocxFile("./static/产能预售合同.docx")
  37. if err != nil {
  38. global.M2A_LOG.Error("读取合同文件失败", zap.Error(err))
  39. return
  40. }
  41. var p pb.THJPurchaseTradeNtf
  42. if err := proto.Unmarshal(*bytes, &p); err != nil {
  43. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  44. return
  45. }
  46. // 铁合金采购成交扩展信息
  47. thjpurchasetradedetail := model.Thjpurchasetradedetail{WRTRADEDETAILID: int64(p.GetWRTradeDetailID())}
  48. if has, err := thjpurchasetradedetail.Get(); err != nil || !has {
  49. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取铁合金采购成交扩展信息失败", zap.Error(err))
  50. return
  51. }
  52. // 交割方式
  53. thjdeliverymode := "否"
  54. if thjpurchasetradedetail.THJDELIVERYMODE == 1 {
  55. thjdeliverymode = "是"
  56. }
  57. // 现货商品信息
  58. wrstandard := model.Wrstandard{WRSTANDARDID: int64(thjpurchasetradedetail.WRSTANDARDID)}
  59. if has, err := wrstandard.Get(); err != nil || !has {
  60. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取现货商品信息失败", zap.Error(err))
  61. return
  62. }
  63. // 仓单预售信息
  64. wrpresaleinfo := model.Wrpresaleinfo{PRESALEAPPLYID: thjpurchasetradedetail.PRESALEAPPLYID}
  65. if has, err := wrpresaleinfo.Get(); err != nil || !has {
  66. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取仓单预售信息失败", zap.Error(err))
  67. return
  68. }
  69. // 甲方信息
  70. userinfo := model.Userinfo{USERID: thjpurchasetradedetail.BUYUSERID}
  71. if has, err := userinfo.Get(); err != nil || !has {
  72. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取甲方信息失败", zap.Error(err))
  73. return
  74. }
  75. division := model.Division{AUTOID: int64(userinfo.DISTRICTID)}
  76. totalAddress, err := division.GetTotalAddressByDistrictID(userinfo.ADDRESS)
  77. if err != nil {
  78. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取甲方地址信息失败", zap.Error(err))
  79. return
  80. }
  81. // 证件号码解密
  82. key, _ := hex.DecodeString(utils.AESSecretKey)
  83. if len(userinfo.CARDNUM) > 0 {
  84. if cardnum, err := hex.DecodeString(userinfo.CARDNUM); err == nil { // hex -> []byte
  85. if c, err := utils.AESDecrypt(cardnum, key); err == nil {
  86. userinfo.CARDNUM = string(c)
  87. }
  88. }
  89. }
  90. // 手机号码解密
  91. if len(userinfo.MOBILE) > 0 {
  92. if phonenum, err := hex.DecodeString(userinfo.MOBILE); err == nil { // hex -> []byte
  93. if mobile, err := utils.AESDecrypt(phonenum, key); err == nil {
  94. userinfo.MOBILE = string(mobile)
  95. }
  96. }
  97. }
  98. // 甲方签约信息
  99. bankaccountsign := model.Bankaccountsign{}
  100. if has, err := bankaccountsign.GetByUserID(uint64(thjpurchasetradedetail.BUYUSERID)); err != nil || !has {
  101. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取甲方签约信息失败", zap.Error(err))
  102. return
  103. }
  104. // 账号解密
  105. if len(bankaccountsign.BANKACCOUNTNO) > 0 {
  106. if tt, err := hex.DecodeString(bankaccountsign.BANKACCOUNTNO); err == nil { // hex -> []byte
  107. if dd, err := utils.AESDecrypt(tt, key); err == nil {
  108. bankaccountsign.BANKACCOUNTNO = string(dd)
  109. }
  110. }
  111. }
  112. // 银行信息
  113. bankinfo := model.Bankbankinfo{BANKID: bankaccountsign.BANKID}
  114. if has, err := bankinfo.Get(); err != nil || !has {
  115. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取银行信息失败", zap.Error(err))
  116. return
  117. }
  118. // 生产厂家信息
  119. selluserinfo := model.Userinfo{USERID: thjpurchasetradedetail.SELLUSERID}
  120. if has, err := selluserinfo.Get(); err != nil || !has {
  121. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 获取生产厂家信息失败", zap.Error(err))
  122. return
  123. }
  124. docx1 := r.Editable()
  125. // global.M2A_LOG.Info(docx1.GetContent())
  126. docx1.Replace("${WRTRADEDETAILID}", strconv.Itoa(int(thjpurchasetradedetail.WRTRADEDETAILID)), -1)
  127. docx1.Replace("${TRADETIME}", thjpurchasetradedetail.TRADETIME.Format("2006年01月02日"), -1)
  128. docx1.Replace("${DESADDRESS}", totalAddress, -1)
  129. // 判断是公司还是个人
  130. if userinfo.USERINFOTYPE == 1 {
  131. // 个人
  132. docx1.Replace("COMPANY", "", -1)
  133. docx1.Replace("${LEGALPERSONNAME}", userinfo.CUSTOMERNAME, -1)
  134. } else {
  135. // 公司
  136. docx1.Replace("COMPANY", userinfo.CUSTOMERNAME, -1)
  137. docx1.Replace("${LEGALPERSONNAME}", userinfo.LEGALPERSONNAME, -1)
  138. }
  139. docx1.Replace("CARDNUM", userinfo.CARDNUM, -1)
  140. docx1.Replace("${MOBILE}", userinfo.MOBILE, -1)
  141. docx1.Replace("${BANK}", bankinfo.BANKNAME, -1)
  142. docx1.Replace("${BANKACCOUNTNO}", bankaccountsign.BANKACCOUNTNO, -1)
  143. docx1.Replace("${WRSTANDARDNAME}", wrstandard.WRSTANDARDNAME, -1)
  144. docx1.Replace("${SELLUSER}", selluserinfo.CUSTOMERNAME, -1)
  145. docx1.Replace("${LASTAMOUNT}", strconv.FormatFloat(thjpurchasetradedetail.LASTAMOUNT, 'f', -1, 64), -1)
  146. docx1.Replace("${DEPOSITRATE}", strconv.FormatFloat(thjpurchasetradedetail.DEPOSITRATE*100, 'f', -1, 64)+"%", -1)
  147. docx1.Replace("${TRADEQTY}", strconv.Itoa(int(thjpurchasetradedetail.TRADEQTY)), -1)
  148. docx1.Replace("${TRADEPRICE}", strconv.FormatFloat(thjpurchasetradedetail.TRADEPRICE, 'f', -1, 64), -1)
  149. docx1.Replace("${ENDDATEMONTH}", strconv.Itoa(int(wrpresaleinfo.ENDDATE.Local().Month())), -1)
  150. docx1.Replace("${THJDELIVERYMODE}", thjdeliverymode, -1)
  151. docx1.Replace("${ENDDATE}", wrpresaleinfo.ENDDATE.Format("200601"), -1)
  152. docx1.Replace("${STORAGEFEE}", strconv.FormatFloat(wrstandard.STORAGEFEE, 'f', -1, 64), -1)
  153. // 暂存docx文件
  154. if exist, _ := utils.PathExists("./.tmp"); !exist {
  155. os.Mkdir("./.tmp", os.ModePerm)
  156. }
  157. uid, _ := uuid.NewV4()
  158. docxFilename := fmt.Sprintf("%v_%v.docx", strconv.Itoa(int(thjpurchasetradedetail.WRTRADEDETAILID)), uid.String())
  159. pdfFilename := strings.Replace(docxFilename, "docx", "pdf", -1)
  160. docx1.WriteToFile("./.tmp/" + docxFilename)
  161. r.Close()
  162. // 导出pdf到目标目录
  163. folderPath := "Purchase_Contract/" + time.Now().Format("20060102")
  164. savePath := global.M2A_CONFIG.System.StorePath + "/" + folderPath
  165. if exist, _ := utils.PathExists(savePath); !exist {
  166. os.MkdirAll(savePath, os.ModePerm)
  167. }
  168. success := utils.ConvertToPDF("./.tmp/"+docxFilename, savePath)
  169. if !success {
  170. // 转换失败
  171. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] docx转换pdf失败", zap.Error(err))
  172. return
  173. }
  174. // 更新数据库
  175. // pdfFilename = docxFilename // 临时代码
  176. thjpurchasetradedetail.CONTRACTADDRBUY = fmt.Sprintf("./uploadFile/%v/%v", folderPath, pdfFilename)
  177. if err = thjpurchasetradedetail.UpdateContractAddrBuy(); err != nil {
  178. global.M2A_LOG.Error("[onTHJPurchaseTradeNtf] 更新数据库失败", zap.Error(err))
  179. return
  180. }
  181. global.M2A_LOG.Info("[onTHJPurchaseTradeNtf] 合同生成成功", zap.Any("file", savePath+pdfFilename))
  182. }