wechat_send_msg.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463
  1. package services
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "hongze/hongze_mobile_admin/models/tables/admin"
  7. "hongze/hongze_mobile_admin/models/tables/user_template_record"
  8. "hongze/hongze_mobile_admin/services/alarm_msg"
  9. "hongze/hongze_mobile_admin/utils"
  10. "io/ioutil"
  11. "net/http"
  12. "time"
  13. )
  14. func sendTemplateMsg(wxAppId string,sendUrl string, sendMap map[string]interface{}, items []*admin.OpenIdList, resource string, sendType int) (err error) {
  15. for _, v := range items {
  16. sendMap["touser"] = v.OpenId
  17. data, err := json.Marshal(sendMap)
  18. if err != nil {
  19. fmt.Println("SendTemplateMsgOne Marshal Err:", err.Error())
  20. utils.FileLog.Info(fmt.Sprintf("SendTemplateMsgOne Marshal Err:%s", err.Error()))
  21. return err
  22. }
  23. err = toSendTemplateMsg(wxAppId, sendUrl, data, resource, sendType, v)
  24. if err != nil {
  25. fmt.Println("send err:", err.Error())
  26. utils.FileLog.Info(fmt.Sprintf("ToSendTemplateMsg Err:%s", err.Error()))
  27. }
  28. }
  29. return
  30. }
  31. func toSendTemplateMsg(wxAppId string,sendUrl string, data []byte, resource string, sendType int, dataItem *admin.OpenIdList) (err error) {
  32. utils.FileLog.Info("Send:" + string(data))
  33. client := http.Client{}
  34. resp, err := client.Post(sendUrl, "application/json", bytes.NewBuffer(data))
  35. if err != nil {
  36. return
  37. }
  38. defer resp.Body.Close()
  39. body, _ := ioutil.ReadAll(resp.Body)
  40. utils.FileLog.Info("SendResult:" + string(body))
  41. var templateResponse SendTemplateResponse
  42. err = json.Unmarshal(body, &templateResponse)
  43. if err != nil {
  44. utils.FileLog.Info("SendResult Unmarshal Err:%s", err.Error())
  45. return err
  46. }
  47. //新增模板消息推送记录
  48. {
  49. sendStatus := 0
  50. if templateResponse.Errcode == 0 {
  51. sendStatus = 1
  52. } else {
  53. sendStatus = 0
  54. }
  55. tr := &user_template_record.UserTemplateRecord{
  56. Id: 0,
  57. // UserId: dataItem.UserId,
  58. OpenId: dataItem.OpenId,
  59. Resource: resource,
  60. SendData: string(data),
  61. Result: string(body),
  62. CreateDate: time.Now().Format(utils.FormatDate),
  63. CreateTime: time.Now().Format(utils.FormatDateTime),
  64. SendStatus: sendStatus,
  65. SendType: sendType,
  66. WxAppId: wxAppId,
  67. }
  68. go func() {
  69. err = user_template_record.AddUserTemplateRecord(tr)
  70. if err != nil {
  71. utils.FileLog.Info(fmt.Sprintf("AddUserTemplateRecord Err:%s", err.Error()))
  72. }
  73. }()
  74. }
  75. return
  76. }
  77. type SendTemplateResponse struct {
  78. Errcode int `json:"errcode"`
  79. Errmsg string `json:"errmsg"`
  80. MsgID int `json:"msgid"`
  81. }
  82. // SendCompanyApplyWxTemplateMsg 发送待办消息
  83. func SendCompanyApplyWxTemplateMsg(mobile, redirectUrl, wxAppPath string, wxMsgMap map[int]string) (err error) {
  84. var msg string
  85. defer func() {
  86. if err != nil {
  87. go alarm_msg.SendAlarmMsg(fmt.Sprintf("发送模版消息失败,Err:%s,%s", err.Error(), msg), 3)
  88. //go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  89. utils.FileLog.Info("发送模版消息失败,Err:%s,%s", err.Error(), msg)
  90. }
  91. if msg != "" {
  92. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  93. }
  94. }()
  95. utils.FileLog.Info("%s", "services SendMsg")
  96. accessToken, err := WxGetRedisAccessToken(utils.AdminWxAppId, utils.AdminWxAppSecret)
  97. if err != nil {
  98. msg = "GetWxAccessToken Err:" + err.Error()
  99. return
  100. }
  101. if accessToken == "" {
  102. msg = "accessToken is empty"
  103. return
  104. }
  105. utils.FileLog.Info("mobile:%s", mobile)
  106. //获取openid列表
  107. openIdStr := WxAdminOpenIdGet()
  108. openIdList, err := admin.GetOpenIdListByMobile(mobile, openIdStr)
  109. if err != nil {
  110. msg = "get openIdList err:" + err.Error()
  111. return
  112. }
  113. utils.FileLog.Info("openIdListCount:%s", len(openIdList))
  114. //fmt.Println("openIdListCount:", len(openIdList))
  115. if len(openIdList) > 0 && utils.TemplateIdByCompanyApply != "" {
  116. utils.FileLog.Info("start send")
  117. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  118. fmt.Println("send start")
  119. utils.FileLog.Info("send start")
  120. sendMap := make(map[string]interface{})
  121. sendData := make(map[string]interface{})
  122. var first, keyword1, keyword2, keyword3, remark string
  123. if tmpStr, ok := wxMsgMap[0]; ok {
  124. first = tmpStr
  125. } else {
  126. first = "Hi,有新的订单需要审批"
  127. }
  128. if tmpStr, ok := wxMsgMap[1]; ok {
  129. keyword1 = tmpStr
  130. }
  131. if tmpStr, ok := wxMsgMap[2]; ok {
  132. keyword2 = tmpStr
  133. }
  134. if tmpStr, ok := wxMsgMap[3]; ok {
  135. keyword3 = tmpStr
  136. }
  137. if tmpStr, ok := wxMsgMap[4]; ok {
  138. remark = tmpStr
  139. }
  140. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  141. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  142. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
  143. sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": "#173177"}
  144. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  145. sendMap["template_id"] = utils.TemplateIdByCompanyApply
  146. sendMap["url"] = redirectUrl
  147. sendMap["data"] = sendData
  148. //小程序信息
  149. if wxAppPath != "" {
  150. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId2, "pagepath": wxAppPath}
  151. }
  152. sendTemplateMsg(utils.AdminWxAppId, sendUrl, sendMap, openIdList, mobile, utils.TEMPLATE_MSG_APPLY)
  153. }
  154. utils.FileLog.Info("send end")
  155. return
  156. }
  157. // SendWxMsgWithRoadshowDetailResult 路演->销售收到处理结果
  158. func SendWxMsgWithRoadshowDetailResult(first, keyword1, keyword2, remark, mobile, redirectUrl, wxAppPath string) (err error) {
  159. var msg string
  160. defer func() {
  161. if err != nil {
  162. go alarm_msg.SendAlarmMsg(fmt.Sprintf("发送模版消息失败,Err:%s,%s", err.Error(), msg), 3)
  163. //go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  164. utils.FileLog.Info("发送模版消息失败,Err:%s,%s", err.Error(), msg)
  165. }
  166. if msg != "" {
  167. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  168. }
  169. }()
  170. utils.FileLog.Info("%s", "services SendMsg")
  171. accessToken, err := WxGetRedisAccessToken(utils.AdminWxAppId, utils.AdminWxAppSecret)
  172. if err != nil {
  173. msg = "GetWxAccessToken Err:" + err.Error()
  174. return
  175. }
  176. if accessToken == "" {
  177. msg = "accessToken is empty"
  178. return
  179. }
  180. utils.FileLog.Info("mobile:%s", mobile)
  181. //获取openid列表
  182. openIdStr := WxAdminOpenIdGet()
  183. openIdList, err := admin.GetOpenIdListByMobile(mobile, openIdStr)
  184. if err != nil {
  185. msg = "get openIdList err:" + err.Error()
  186. return
  187. }
  188. utils.FileLog.Info("openIdListCount:%s", len(openIdList))
  189. //fmt.Println("openIdListCount:", len(openIdList))
  190. if len(openIdList) > 0 && utils.TemplateIdByCompanyApply != "" {
  191. utils.FileLog.Info("start send")
  192. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  193. fmt.Println("send start")
  194. utils.FileLog.Info("send start")
  195. sendMap := make(map[string]interface{})
  196. sendData := make(map[string]interface{})
  197. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  198. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  199. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
  200. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  201. sendMap["template_id"] = utils.WxMsgTemplateIdWithRoadshowDetailResult
  202. sendMap["url"] = redirectUrl
  203. sendMap["data"] = sendData
  204. //小程序信息
  205. if wxAppPath != "" {
  206. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId2, "pagepath": wxAppPath}
  207. }
  208. sendTemplateMsg(utils.AdminWxAppId, sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT)
  209. }
  210. utils.FileLog.Info("send end")
  211. return
  212. }
  213. // SendWxMsgWithRoadshowPending 路演->研究员收到待处理的申请
  214. func SendWxMsgWithRoadshowPending(first, keyword1, keyword2, keyword3, keyword4, remark, wxAppPath, mobile string) (err error) {
  215. //utils.WxMsgTemplateIdWithRoadshowPending
  216. var msg string
  217. defer func() {
  218. if err != nil {
  219. //go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  220. go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+msg, 3)
  221. utils.FileLog.Info("发送模版消息失败,Err:" + err.Error() + msg)
  222. }
  223. if msg != "" {
  224. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  225. }
  226. }()
  227. utils.FileLog.Info("%s", "services SendMsg")
  228. accessToken, err := WxGetRedisAccessToken(utils.AdminWxAppId, utils.AdminWxAppSecret)
  229. if err != nil {
  230. msg = "GetWxAccessToken Err:" + err.Error()
  231. return
  232. }
  233. if accessToken == "" {
  234. msg = "accessToken is empty"
  235. return
  236. }
  237. //获取openid列表
  238. openIdStr := WxAdminOpenIdGet()
  239. openIdList, err := admin.GetOpenIdListByMobile(mobile, openIdStr)
  240. if err != nil {
  241. msg = "get openIdList err:" + err.Error()
  242. return
  243. }
  244. utils.FileLog.Info("openIdListCount:%s", len(openIdList))
  245. //fmt.Println("openIdListCount:", len(openIdList))
  246. if len(openIdList) > 0 && utils.TemplateIdByCompanyApply != "" {
  247. utils.FileLog.Info("start send")
  248. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  249. fmt.Println("send start")
  250. utils.FileLog.Info("send start")
  251. sendMap := make(map[string]interface{})
  252. sendData := make(map[string]interface{})
  253. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  254. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  255. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
  256. sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": "#173177"}
  257. sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": "#173177"}
  258. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  259. sendMap["template_id"] = utils.WxMsgTemplateIdWithRoadshowPending
  260. sendMap["data"] = sendData
  261. //小程序信息
  262. if wxAppPath != "" {
  263. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId2, "pagepath": wxAppPath}
  264. }
  265. sendTemplateMsg(utils.AdminWxAppId, sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT)
  266. }
  267. utils.FileLog.Info("send end")
  268. return
  269. }
  270. // SendWxMsgWithRoadshowDeleteNotice 路演->研究员收到活动删除通知
  271. func SendWxMsgWithRoadshowDeleteNotice(first, keyword1, keyword2, remark, wxAppPath, mobile string) (err error) {
  272. var msg string
  273. defer func() {
  274. if err != nil {
  275. //go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
  276. go alarm_msg.SendAlarmMsg("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05")+";Msg:"+msg+";Err:"+err.Error(), 3)
  277. utils.FileLog.Info("发送模版消息失败,Err:%s,%s", err.Error(), msg)
  278. }
  279. if msg != "" {
  280. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  281. }
  282. }()
  283. utils.FileLog.Info("%s", "services SendMsg")
  284. accessToken, err := WxGetRedisAccessToken(utils.AdminWxAppId, utils.AdminWxAppSecret)
  285. if err != nil {
  286. msg = "GetWxAccessToken Err:" + err.Error()
  287. return
  288. }
  289. if accessToken == "" {
  290. msg = "accessToken is empty"
  291. return
  292. }
  293. //获取openid列表
  294. openIdStr := WxAdminOpenIdGet()
  295. openIdList, err := admin.GetOpenIdListByMobile(mobile, openIdStr)
  296. if err != nil {
  297. msg = "get openIdList err:" + err.Error()
  298. return
  299. }
  300. utils.FileLog.Info("openIdListCount:%s", len(openIdList))
  301. //fmt.Println("openIdListCount:", len(openIdList))
  302. if len(openIdList) > 0 && utils.TemplateIdByCompanyApply != "" {
  303. utils.FileLog.Info("start send")
  304. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  305. sendMap := make(map[string]interface{})
  306. sendData := make(map[string]interface{})
  307. sendMap["template_id"] = utils.WxMsgTemplateIdWithRoadshowDeleteNotice
  308. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  309. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  310. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
  311. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  312. //小程序信息
  313. if wxAppPath != "" {
  314. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId2, "pagepath": wxAppPath}
  315. }
  316. sendMap["data"] = sendData
  317. sendTemplateMsg(utils.AdminWxAppId, sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT)
  318. }
  319. utils.FileLog.Info("send end")
  320. return
  321. }
  322. // SendSealFinishedWxTemplateMsg 给销售发送 用印申请已签回的模版消息
  323. func SendSealFinishedWxTemplateMsg(mobile string, companyName string, sealId int) (err error) {
  324. var msg string
  325. defer func() {
  326. if err != nil {
  327. fmt.Println("err:", err)
  328. go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+";msg:"+msg, 3)
  329. utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,Err:%s,%s", err.Error(), msg))
  330. }
  331. if msg != "" {
  332. utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
  333. }
  334. }()
  335. utils.FileLog.Info("%s", "services SendMsg")
  336. accessToken, err := WxGetRedisAccessToken(utils.AdminWxAppId, utils.AdminWxAppSecret)
  337. if err != nil {
  338. msg = "GetWxAccessToken Err:" + err.Error()
  339. return
  340. }
  341. if accessToken == "" {
  342. msg = "accessToken is empty"
  343. return
  344. }
  345. utils.FileLog.Info("mobile:%s", mobile)
  346. openIdStr := WxAdminOpenIdGet()
  347. openIdList, err := admin.GetOpenIdListByMobile(mobile, openIdStr)
  348. if err != nil {
  349. msg = "get openIdList err:" + err.Error()
  350. return
  351. }
  352. utils.FileLog.Info("openIdListCount:%s", len(openIdList))
  353. if len(openIdList) > 0 && utils.WxMsgTemplateIdWithSealApplyFinished != "" {
  354. utils.FileLog.Info("start send")
  355. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  356. fmt.Println("send start")
  357. utils.FileLog.Info("send start")
  358. sendMap := make(map[string]interface{})
  359. sendData := make(map[string]interface{})
  360. first := "您的用印申请已签回,可前往提交转正/续约申请"
  361. keyword1 := companyName
  362. keyword2 := "已签回"
  363. remark := "点击查看用印详情"
  364. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  365. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  366. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
  367. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  368. sendMap["template_id"] = utils.WxMsgTemplateIdWithSealApplyFinished
  369. sendMap["url"] = "" //跳转地址
  370. sendMap["data"] = sendData
  371. // TODO 随手办公小程序的跳转地址
  372. wxAppPath := fmt.Sprintf("pages-approve/seal/detail?SealId=%d", sealId)
  373. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId2, "pagepath": wxAppPath}
  374. err = sendTemplateMsg(utils.AdminWxAppId, sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_SEAL_FINISHED)
  375. }
  376. utils.FileLog.Info("send end")
  377. return
  378. }
  379. // SendYbQuestionDistributeWxMsg 推送研报小程序模板消息-问答社区分配
  380. func SendYbQuestionDistributeWxMsg(questionId, adminId int, openid, questionTitle string) (err error) {
  381. var errMsg string
  382. defer func() {
  383. if err != nil {
  384. alarmMsg := fmt.Sprintf("SendMiniProgramReportWxMsg-推送问答社区分配模版消息失败; QuestionId: %d; Err: %s; Msg: %s", questionId, err.Error(), errMsg)
  385. utils.FileLog.Error(alarmMsg)
  386. go alarm_msg.SendAlarmMsg(alarmMsg, 3)
  387. }
  388. }()
  389. // todo 修改openID
  390. accessToken, err := WxGetRedisAccessToken(utils.AdminWxAppId, utils.AdminWxAppSecret)
  391. if err != nil {
  392. errMsg = "GetWxAccessToken Err:" + err.Error()
  393. return
  394. }
  395. if accessToken == "" {
  396. errMsg = "accessToken is empty"
  397. return
  398. }
  399. openIdList := make([]*admin.OpenIdList, 0)
  400. openIdList = append(openIdList, &admin.OpenIdList{
  401. OpenId: openid,
  402. AdminId: adminId,
  403. })
  404. sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
  405. sendMap := make(map[string]interface{})
  406. sendData := make(map[string]interface{})
  407. first := "您好,有新的提问待回复"
  408. keyword1 := questionTitle
  409. keyword2 := "待回复"
  410. remark := "请点击详情尽快处理"
  411. sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
  412. sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
  413. sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
  414. sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
  415. sendMap["template_id"] = utils.WxMsgTemplateIdWithYbCommunityQuestion
  416. sendMap["data"] = sendData
  417. wxAppPath := fmt.Sprintf("pages-question/answerDetail?id=%d", questionId)
  418. if wxAppPath != "" {
  419. sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxYbAppId, "pagepath": wxAppPath}
  420. }
  421. err = sendTemplateMsg(utils.AdminWxAppId, sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_YB_COMMUNITY_QUESTION)
  422. return
  423. }