wechat_send_msg.go 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. package services
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "hongze/hongze_cygx/models"
  7. "hongze/hongze_cygx/utils"
  8. "io/ioutil"
  9. "net/http"
  10. "time"
  11. )
  12. //访谈申请
  13. func SendInterviewApplyTemplateMsg(realName, companyName, mobile, articleTitle string, itemOpenid *models.OpenIdList) (err error) {
  14. var msg string
  15. defer func() {
  16. if err != nil {
  17. go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  18. go utils.SendAlarmMsg(fmt.Sprint("访谈申请模板消息推送消息失败,手机号", mobile, "公司:", companyName, "手机号:", mobile), 2)
  19. }
  20. if msg != "" {
  21. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  22. }
  23. }()
  24. accessToken, err := models.GetWxAccessTokenByXzs()
  25. if err != nil {
  26. msg = "GetWxAccessToken Err:" + err.Error()
  27. return
  28. }
  29. if accessToken == "" {
  30. msg = "accessToken is empty"
  31. return
  32. }
  33. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  34. sendMap := make(map[string]interface{})
  35. sendData := make(map[string]interface{})
  36. keyword1 := realName + "【" + companyName + "】"
  37. first := "您有一条新的访谈申请,请及时处理。"
  38. keyword2 := mobile
  39. keyword3 := time.Now().Format(utils.FormatDateTime)
  40. keyword4 := articleTitle
  41. fontColor := "#D9001B"
  42. sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
  43. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
  44. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
  45. sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
  46. sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
  47. sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
  48. sendMap["data"] = sendData
  49. sendTemplateMsg(sendUrl, sendMap, itemOpenid, mobile, utils.TEMPLATE_MSG_CYGX_APPLY)
  50. fmt.Println("send end")
  51. return
  52. }
  53. //访谈申请取消
  54. func SendInterviewApplyCancelTemplateMsg(realName, companyName, mobile, articleTitle string, itemOpenid *models.OpenIdList) (err error) {
  55. var msg string
  56. defer func() {
  57. if err != nil {
  58. go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  59. go utils.SendAlarmMsg(fmt.Sprint("访谈申请取消模板消息推送消息失败,手机号", mobile, "公司:", companyName, "手机号:", mobile), 2)
  60. }
  61. if msg != "" {
  62. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  63. }
  64. }()
  65. accessToken, err := models.GetWxAccessTokenByXzs()
  66. if err != nil {
  67. msg = "GetWxAccessToken Err:" + err.Error()
  68. return
  69. }
  70. if accessToken == "" {
  71. msg = "accessToken is empty"
  72. return
  73. }
  74. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  75. sendMap := make(map[string]interface{})
  76. sendData := make(map[string]interface{})
  77. first := realName + "-" + mobile + "【" + companyName + "】的访谈申请已取消,请留意。"
  78. keyword1 := articleTitle
  79. keyword2 := time.Now().Format(utils.FormatDateTime)
  80. fontColor := "#D9001B"
  81. sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
  82. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
  83. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
  84. sendMap["template_id"] = utils.WxMsgTemplateIdApplyCancelXzs
  85. sendMap["data"] = sendData
  86. sendTemplateMsg(sendUrl, sendMap, itemOpenid, mobile, utils.TEMPLATE_MSG_CYGX_APPLY)
  87. fmt.Println("send end")
  88. return
  89. }
  90. //权限申请
  91. func SendPermissionApplyTemplateMsg(realName, companyName, mobile, applyMethod string, itemOpenid *models.OpenIdList) (err error) {
  92. var msg string
  93. defer func() {
  94. if err != nil {
  95. go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  96. go utils.SendAlarmMsg(fmt.Sprint("权限申请模板消息推送消息失败,手机号", mobile, "公司:", companyName, "手机号:", mobile), 2)
  97. }
  98. if msg != "" {
  99. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  100. }
  101. }()
  102. var accessToken string
  103. if utils.RunMode == "release" {
  104. accessToken, err = models.GetWxAccessTokenByXzs()
  105. if err != nil {
  106. msg = "GetWxAccessToken Err:" + err.Error()
  107. return
  108. }
  109. if accessToken == "" {
  110. msg = "accessToken is empty"
  111. return
  112. }
  113. } else {
  114. accessToken, err = models.GetWxAccessToken()
  115. if err != nil {
  116. msg = "GetWxAccessToken Err:" + err.Error()
  117. return
  118. }
  119. if accessToken == "" {
  120. msg = "accessToken is empty"
  121. return
  122. }
  123. }
  124. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  125. sendMap := make(map[string]interface{})
  126. sendData := make(map[string]interface{})
  127. keyword1 := realName + "【" + companyName + "】"
  128. first := "查研观向有一条新的权限申请,请及时处理。"
  129. keyword2 := mobile
  130. keyword3 := time.Now().Format(utils.FormatDateTime)
  131. keyword4 := applyMethod
  132. fontColor := "#D9001B"
  133. sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
  134. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
  135. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
  136. sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
  137. sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
  138. if utils.RunMode == "release" {
  139. sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
  140. } else {
  141. sendMap["template_id"] = utils.WxMsgTemplateIdApply
  142. }
  143. sendMap["data"] = sendData
  144. sendTemplateMsg(sendUrl, sendMap, itemOpenid, mobile, utils.TEMPLATE_MSG_CYGX_APPLY)
  145. fmt.Println("send end")
  146. return
  147. }
  148. func sendTemplateMsg(sendUrl string, sendMap map[string]interface{}, itemOpenid *models.OpenIdList, resource string, sendType int) (err error) {
  149. sendMap["touser"] = itemOpenid.OpenId
  150. data, err := json.Marshal(sendMap)
  151. if err != nil {
  152. fmt.Println("SendTemplateMsgOne Marshal Err:", err.Error())
  153. return err
  154. }
  155. err = toSendTemplateMsg(sendUrl, data, resource, sendType, itemOpenid)
  156. if err != nil {
  157. fmt.Println("send err:", err.Error())
  158. }
  159. return
  160. }
  161. func toSendTemplateMsg(sendUrl string, data []byte, resource string, sendType int, dataItem *models.OpenIdList) (err error) {
  162. client := http.Client{}
  163. resp, err := client.Post(sendUrl, "application/json", bytes.NewBuffer(data))
  164. if err != nil {
  165. return
  166. }
  167. defer resp.Body.Close()
  168. body, _ := ioutil.ReadAll(resp.Body)
  169. var templateResponse SendTemplateResponse
  170. err = json.Unmarshal(body, &templateResponse)
  171. fmt.Println(templateResponse)
  172. utils.FileLog.Info("SendResult %s:", string(body))
  173. if err != nil {
  174. utils.FileLog.Info("SendResult Unmarshal Err:%s", err.Error())
  175. return err
  176. }
  177. //新增模板消息推送记录
  178. {
  179. tr := new(models.UserTemplateRecord)
  180. tr.UserId = dataItem.UserId
  181. tr.OpenId = dataItem.OpenId
  182. tr.Resource = resource
  183. tr.SendData = string(data)
  184. tr.Result = string(body)
  185. tr.CreateDate = time.Now().Format(utils.FormatDate)
  186. tr.CreateTime = time.Now().Format(utils.FormatDateTime)
  187. if templateResponse.Errcode == 0 {
  188. tr.SendStatus = 1
  189. } else {
  190. tr.SendStatus = 0
  191. }
  192. tr.SendType = sendType
  193. go func() {
  194. err = models.AddUserTemplateRecord(tr)
  195. if err != nil {
  196. utils.FileLog.Info(fmt.Sprintf("AddUserTemplateRecord Err:%s", err.Error()))
  197. }
  198. }()
  199. }
  200. return
  201. }
  202. type SendTemplateResponse struct {
  203. Errcode int `json:"errcode"`
  204. Errmsg string `json:"errmsg"`
  205. MsgID int `json:"msgid"`
  206. }