123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- package services
- import (
- "bytes"
- "encoding/json"
- "fmt"
- "hongze/hongze_mobile_admin/models/tables/report"
- "hongze/hongze_mobile_admin/models/tables/wx_user"
- "hongze/hongze_mobile_admin/utils"
- "io/ioutil"
- "net/http"
- "strconv"
- "time"
- )
- func SendWxTemplateMsg(reportId int) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送模版消息失败,Err:%s,%s", err.Error(), msg)
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- utils.FileLog.Info("%s", "services SendMsg")
- report, err := report.GetReportById(reportId)
- if err != nil {
- msg = "GetReportInfo Err:" + err.Error()
- return
- }
- if report == nil {
- utils.FileLog.Info("报告信息不存在")
- return
- }
- accessToken, err := WxGetAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- //获取openid列表
- openIdStr := WxUsersGet()
- openIdList, err := wx_user.GetOpenIdList(openIdStr)
- if err != nil {
- msg = "get openIdList err:" + err.Error()
- return
- }
- fmt.Println("openIdListCount:", len(openIdList))
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- fmt.Println("send start")
- utils.FileLog.Info("send start")
- //if report.MsgIsSend == 0 {
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- redirectUrl := utils.TemplateRedirectUrl + strconv.Itoa(reportId)
- keyword1 := "弘则日度点评"
- first := "Hi,最新一期日度点评已上线,欢迎查看"
- keyword2 := report.Title
- //keyword3 := report.PublishTime.Format(utils.FormatDateTime)
- keyword3 := report.PublishTime
- keyword4 := report.Abstract
- sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
- sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": "#173177"}
- sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": "#173177"}
- sendMap["template_id"] = utils.TemplateIdByProduct
- sendMap["url"] = redirectUrl
- sendMap["data"] = sendData
- sendTemplateMsg(sendUrl, sendMap, openIdList)
- //}
- fmt.Println("send end")
- utils.FileLog.Info("send end")
- return
- }
- func sendTemplateMsg(sendUrl string, sendMap map[string]interface{}, items []*wx_user.OpenIdList) (err error) {
- for _, v := range items {
- sendMap["touser"] = v.OpenId
- data, err := json.Marshal(sendMap)
- if err != nil {
- fmt.Println("SendTemplateMsgOne Marshal Err:", err.Error())
- utils.FileLog.Info("SendTemplateMsgOne Marshal Err:%s", err.Error())
- return err
- }
- err = toSendTemplateMsg(sendUrl, data)
- if err != nil {
- fmt.Println("send err:", err.Error())
- utils.FileLog.Info("ToSendTemplateMsg Err:%s", err.Error())
- }
- }
- return
- }
- func toSendTemplateMsg(sendUrl string, data []byte) (err error) {
- utils.FileLog.Info("Send:%s", string(data))
- client := http.Client{}
- resp, err := client.Post(sendUrl, "application/json", bytes.NewBuffer(data))
- if err != nil {
- return
- }
- defer resp.Body.Close()
- body, _ := ioutil.ReadAll(resp.Body)
- utils.FileLog.Info("SendResult:%s", string(body))
- var templateResponse SendTemplateResponse
- err = json.Unmarshal(body, &templateResponse)
- if err != nil {
- utils.FileLog.Info("SendResult Unmarshal Err:%s", err.Error())
- return err
- }
- return
- }
- type SendTemplateResponse struct {
- Errcode int `json:"errcode"`
- Errmsg string `json:"errmsg"`
- MsgID int `json:"msgid"`
- }
- // SendCompanyApplyWxTemplateMsg 发送待办消息
- func SendCompanyApplyWxTemplateMsg(mobile, redirectUrl, wxAppPath string, wxMsgMap map[int]string) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送模版消息失败,Err:%s,%s", err.Error(), msg)
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- utils.FileLog.Info("%s", "services SendMsg")
- accessToken, err := WxGetAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- utils.FileLog.Info("mobile:%s", mobile)
- //获取openid列表
- openIdStr := WxUsersGet()
- openIdList, err := wx_user.GetOpenIdListByMobile(mobile, openIdStr)
- if err != nil {
- msg = "get openIdList err:" + err.Error()
- return
- }
- utils.FileLog.Info("openIdListCount:%s", len(openIdList))
- //fmt.Println("openIdListCount:", len(openIdList))
- if len(openIdList) > 0 && utils.TemplateIdByCompanyApply != "" {
- utils.FileLog.Info("start send")
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- fmt.Println("send start")
- utils.FileLog.Info("send start")
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- var first, keyword1, keyword2, keyword3, remark string
- if tmpStr, ok := wxMsgMap[0]; ok {
- first = tmpStr
- } else {
- first = "Hi,有新的订单需要审批"
- }
- if tmpStr, ok := wxMsgMap[1]; ok {
- keyword1 = tmpStr
- }
- if tmpStr, ok := wxMsgMap[2]; ok {
- keyword2 = tmpStr
- }
- if tmpStr, ok := wxMsgMap[3]; ok {
- keyword3 = tmpStr
- }
- if tmpStr, ok := wxMsgMap[4]; ok {
- remark = tmpStr
- }
- sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
- sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": "#173177"}
- sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
- sendMap["template_id"] = utils.TemplateIdByCompanyApply
- sendMap["url"] = redirectUrl
- sendMap["data"] = sendData
- //小程序信息
- if wxAppPath != "" {
- sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId2, "pagepath": wxAppPath}
- }
- sendTemplateMsg(sendUrl, sendMap, openIdList)
- }
- utils.FileLog.Info("send end")
- return
- }
|