wx_template_msg.go 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. package services
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "hongze/hongze_clpt/models"
  7. "hongze/hongze_clpt/utils"
  8. "io/ioutil"
  9. "net/http"
  10. "strconv"
  11. "time"
  12. )
  13. //发送报告提问消息提醒
  14. func SendWxMsgWithAsk(name, askTime, askMsg, title string, openIdList []*models.OpenIdList, articleId int) (err error) {
  15. var msg string
  16. defer func() {
  17. if err != nil {
  18. go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  19. go utils.SendAlarmMsg(fmt.Sprint("发送报告提问消息提醒模版消息失败,用户名", name, "文章ID:", articleId), 2)
  20. utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
  21. }
  22. fmt.Println("line 21", err, msg)
  23. }()
  24. utils.FileLog.Info("%s", "services SendMsg")
  25. //accessToken, err := models.GetWxAccessToken()
  26. accessToken, err := models.GetWxAccessTokenByXzs()
  27. if err != nil {
  28. msg = "GetWxAccessToken Err:" + err.Error()
  29. return
  30. }
  31. if accessToken == "" {
  32. msg = "accessToken is empty"
  33. return
  34. }
  35. var first string
  36. var keyword1 string
  37. var keyword3 string
  38. var keyword4 string
  39. var remark string
  40. first = "研选报告有新的提问,请及时处理"
  41. keyword1 = name
  42. keyword3 = askTime
  43. keyword4 = askMsg
  44. remark = title
  45. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  46. //templateId := utils.WxMsgTemplateIdAskMsg
  47. templateId := utils.WxMsgTemplateIdAskMsgXzs
  48. sendMap := make(map[string]interface{})
  49. sendData := make(map[string]interface{})
  50. sendMap["template_id"] = templateId
  51. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "pages/reportDetail/reportDetail?id=" + strconv.Itoa(articleId)}
  52. //sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "path": "article/detail?ArticleId=1000001"}
  53. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  54. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  55. sendData["keyword2"] = map[string]interface{}{"value": "", "color": "#173177"}
  56. sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": "#173177"}
  57. sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": "#173177"}
  58. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  59. sendMap["data"] = sendData
  60. WxSendTemplateMsg(sendUrl, sendMap, openIdList, strconv.Itoa(articleId), utils.TEMPLATE_MSG_CYGX_ARTICLE_ADD)
  61. return
  62. }
  63. func WxSendTemplateMsg(sendUrl string, sendMap map[string]interface{}, items []*models.OpenIdList, resource string, sendType int) (err error) {
  64. for _, v := range items {
  65. sendMap["touser"] = v.OpenId
  66. data, err := json.Marshal(sendMap)
  67. if err != nil {
  68. fmt.Println("SendTemplateMsgOne Marshal Err:", err.Error())
  69. return err
  70. }
  71. utils.FileLog.Info("One SendData:%s", string(data))
  72. fmt.Println(string(data))
  73. err = SendTemplateMsg(sendUrl, data, resource, sendType, v)
  74. if err != nil {
  75. fmt.Println("send err:", err.Error())
  76. return err
  77. }
  78. }
  79. return
  80. }
  81. func SendTemplateMsg(sendUrl string, data []byte, resource string, sendType int, dataItem *models.OpenIdList) (err error) {
  82. client := http.Client{}
  83. resp, err := client.Post(sendUrl, "application/json", bytes.NewBuffer(data))
  84. if err != nil {
  85. return
  86. }
  87. defer resp.Body.Close()
  88. body, _ := ioutil.ReadAll(resp.Body)
  89. utils.FileLog.Info("SendResult:%s", string(body))
  90. var templateResponse SendTemplateResponse
  91. err = json.Unmarshal(body, &templateResponse)
  92. fmt.Println(templateResponse.Errcode)
  93. fmt.Println(templateResponse.Errmsg)
  94. if err != nil {
  95. return err
  96. }
  97. //新增模板消息推送记录
  98. {
  99. tr := new(models.UserTemplateRecord)
  100. tr.UserId = dataItem.UserId
  101. tr.OpenId = dataItem.OpenId
  102. tr.Resource = resource
  103. tr.SendData = string(data)
  104. tr.Result = string(body)
  105. tr.CreateDate = time.Now().Format(utils.FormatDate)
  106. tr.CreateTime = time.Now().Format(utils.FormatDateTime)
  107. if templateResponse.Errcode == 0 {
  108. tr.SendStatus = 1
  109. } else {
  110. tr.SendStatus = 0
  111. }
  112. tr.SendType = sendType
  113. go func() {
  114. err = models.AddUserTemplateRecord(tr)
  115. if err != nil {
  116. utils.FileLog.Info(fmt.Sprintf("AddUserTemplateRecord Err:%s", err.Error()))
  117. }
  118. }()
  119. }
  120. return
  121. }
  122. //活动带问提醒
  123. func SendActivityAskApplyTemplateMsgV2(keyword1, keyword2, keyword3, keyword4, remark string, itemOpenid *models.OpenIdList, itemAct *models.ActivityDetail) (err error) {
  124. var msg string
  125. defer func() {
  126. if err != nil {
  127. go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  128. go utils.SendAlarmMsg("活动带问提醒发送模版消息失败"+remark, 2)
  129. }
  130. if msg != "" {
  131. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  132. }
  133. }()
  134. var accessToken string
  135. accessToken, err = models.GetWxAccessTokenByXzs()
  136. if err != nil {
  137. msg = "GetWxAccessToken Err:" + err.Error()
  138. return
  139. }
  140. if accessToken == "" {
  141. msg = "accessToken is empty"
  142. return
  143. }
  144. activityId := itemAct.ArticleId
  145. //fmt.Println("itemAct.Host", itemAct.Host)
  146. if itemAct.ChartPermissionId != utils.CHART_PERMISSION_ID_YANXUAN && itemAct.Host != "" {
  147. keyword2 += ",会议主持人:" + itemAct.Host
  148. }
  149. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  150. sendMap := make(map[string]interface{})
  151. sendData := make(map[string]interface{})
  152. first := "有新的客户提问"
  153. //keyword1 := applyName
  154. //keyword2 := "-"
  155. //keyword3 := applyTime
  156. //keyword4 := askContent
  157. //remark := activityName
  158. fontColor := "#D9001B"
  159. sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
  160. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
  161. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
  162. sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
  163. sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
  164. sendData["remark"] = map[string]interface{}{"value": remark, "color": fontColor}
  165. if utils.RunMode == "release" {
  166. sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
  167. } else {
  168. sendMap["template_id"] = utils.WxMsgTemplateIdApply
  169. }
  170. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "activityPages/activityDetail/activityDetail?id=" + strconv.Itoa(activityId)}
  171. sendMap["data"] = sendData
  172. sendTemplateMsg(sendUrl, sendMap, itemOpenid, strconv.Itoa(activityId), utils.TEMPLATE_MSG_CYGX_ACTIVITY_ADD)
  173. fmt.Println("send end")
  174. return
  175. }