wechat_send_msg.go 16 KB

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