123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384 |
- package services
- import (
- "bytes"
- "encoding/json"
- "fmt"
- "hongze/hongze_cygx/models"
- "hongze/hongze_cygx/utils"
- "io/ioutil"
- "net/http"
- "strconv"
- "time"
- )
- func SendWxMsgWithFrequency(first, activityName, reserveResults, activityTime, activityAddress, remark string, openIdList []*models.OpenIdList, activityId int) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
- }
- fmt.Println("line 21", err, msg)
- }()
- utils.FileLog.Info("%s", "services SendMsg")
- accessToken, err := models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- templateId := utils.WxMsgTemplateIdActivityApplyXzs
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- sendMap["template_id"] = templateId
- sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "activityPages/activityDetail/activityDetail?id=" + strconv.Itoa(activityId)}
- //sendMap["miniprogram"] = map[string]interface{}{"appid": "wx4a844c734d8c8e56", "path": "pages/index/index"}
- sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
- sendData["activity_name"] = map[string]interface{}{"value": activityName, "color": "#173177"}
- sendData["reserve_results"] = map[string]interface{}{"value": reserveResults, "color": "#173177"}
- sendData["activity_time"] = map[string]interface{}{"value": activityTime, "color": "#173177"}
- sendData["activity_address"] = map[string]interface{}{"value": activityAddress, "color": "#173177"}
- sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
- sendMap["data"] = sendData
- WxSendTemplateMsg(sendUrl, sendMap, openIdList, strconv.Itoa(activityId), utils.TEMPLATE_MSG_CYGX_ACTIVITY_ADD)
- return
- }
- //发送报告提问消息提醒
- func SendWxMsgWithAsk(name, askTime, askMsg, title string, openIdList []*models.OpenIdList, articleId int) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- go utils.SendAlarmMsg(fmt.Sprint("发送报告提问消息提醒模版消息失败,用户名", name, "文章ID:", articleId), 2)
- utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
- }
- fmt.Println("line 21", err, msg)
- }()
- utils.FileLog.Info("%s", "services SendMsg")
- //accessToken, err := models.GetWxAccessToken()
- accessToken, err := models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- var first string
- var keyword1 string
- var keyword3 string
- var keyword4 string
- var remark string
- first = "研选报告有新的提问,请及时处理"
- keyword1 = name
- keyword3 = askTime
- keyword4 = askMsg
- remark = title
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- //templateId := utils.WxMsgTemplateIdAskMsg
- templateId := utils.WxMsgTemplateIdAskMsgXzs
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- sendMap["template_id"] = templateId
- sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "pages/reportDetail/reportDetail?id=" + strconv.Itoa(articleId)}
- //sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "path": "article/detail?ArticleId=1000001"}
- sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
- sendData["keyword2"] = map[string]interface{}{"value": "", "color": "#173177"}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": "#173177"}
- sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": "#173177"}
- sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
- sendMap["data"] = sendData
- WxSendTemplateMsg(sendUrl, sendMap, openIdList, strconv.Itoa(articleId), utils.TEMPLATE_MSG_CYGX_ARTICLE_ADD)
- return
- }
- //到期提醒模板消息
- func SendWxMsgWithCompanyRemind(first, keyword1, keyword2, remark string, openIdList []*models.OpenIdList) (err error) {
- var msg string
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
- }
- }()
- utils.FileLog.Info("%s", "services SendMsg")
- accessToken, err := models.GetWxAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- sendMap["template_id"] = utils.WxMsgTemplateIdActivityChange
- sendData["first"] = map[string]interface{}{"value": first, "color": "#173177"}
- sendData["productname"] = map[string]interface{}{"value": keyword1, "color": "#173177"}
- sendData["date"] = map[string]interface{}{"value": keyword2, "color": "#173177"}
- sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"}
- sendMap["data"] = sendData
- fmt.Println(accessToken)
- fmt.Println(sendUrl)
- //WxSendTemplateMsg(sendUrl, sendMap, openIdList)
- return
- }
- //发送报告提问消息提醒
- func SendWxMsgWithArticleClassToAdmin(keyWord1, keyWord2, keyWord3, keyWord4 string, openIdList []*models.OpenIdList, articleId int) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- go utils.SendAlarmMsg(fmt.Sprint("发送报告提问消息提醒模版消息失败,文章ID:", articleId), 2)
- utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
- }
- }()
- accessToken, err := models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- var first string
- first = keyWord1
- keyword1 := keyWord2
- keyword2 := keyWord3
- keyword3 := keyWord4
- keyword4 := ""
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- templateId := utils.TemplateIdByProductXzs
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- sendMap["template_id"] = templateId
- sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "pageMy/reportDetail/reportDetail?id=" + strconv.Itoa(articleId)}
- 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["data"] = sendData
- WxSendTemplateMsg(sendUrl, sendMap, openIdList, strconv.Itoa(articleId), utils.TEMPLATE_MSG_CYGX_ARTICLE_ADD)
- return
- }
- //活动带问提醒
- func SendActivityAskApplyTemplateMsg(applyName, applyTime, askContent, activityName string, activityId int, itemOpenid *models.OpenIdList) (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)
- go utils.SendAlarmMsg("活动带问提醒发送模版消息失败"+activityName, 2)
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- var accessToken string
- if utils.RunMode == "release" {
- accessToken, err = models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- } else {
- accessToken, err = models.GetWxAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- }
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- first := "有新的客户提问"
- keyword1 := applyName
- keyword2 := "-"
- keyword3 := applyTime
- keyword4 := askContent
- remark := activityName
- fontColor := "#D9001B"
- sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
- sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
- sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
- sendData["remark"] = map[string]interface{}{"value": remark, "color": fontColor}
- if utils.RunMode == "release" {
- sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
- } else {
- sendMap["template_id"] = utils.WxMsgTemplateIdApply
- }
- sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "activityPages/activityDetail/activityDetail?id=" + strconv.Itoa(activityId)}
- sendMap["data"] = sendData
- sendTemplateMsg(sendUrl, sendMap, itemOpenid, strconv.Itoa(activityId), utils.TEMPLATE_MSG_CYGX_ACTIVITY_ADD)
- fmt.Println("send end")
- return
- }
- //专项产业调研模板消息推送
- func SendSpecialTemplateMsg(applyName, applyTime, mobile, activityName, resource string, itemOpenid *models.OpenIdList) (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)
- go utils.SendAlarmMsg("专项产业调研模板消息推送消息失败"+activityName, 2)
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- var accessToken string
- if utils.RunMode == "release" {
- accessToken, err = models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- } else {
- accessToken, err = models.GetWxAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- }
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- var first string
- if resource == "sale" {
- first = "有客户对专项调研感兴趣"
- } else {
- first = "有5家公司预报名专项调研"
- }
- keyword1 := applyName
- keyword2 := mobile
- keyword3 := applyTime
- keyword4 := activityName
- fontColor := "#D9001B"
- sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
- sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
- sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
- if utils.RunMode == "release" {
- sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
- } else {
- sendMap["template_id"] = utils.WxMsgTemplateIdApply
- }
- sendMap["data"] = sendData
- sendTemplateMsg(sendUrl, sendMap, itemOpenid, mobile, utils.TEMPLATE_MSG_CYGX_ACTIVITY_ADD)
- return
- }
- //弘则投资:
- //Y59n_AHg-RLCKaz293geW76KDHpGL1qOnE7eF_lxelY 活动预约通知
- //CB7bOl7f3viMG4s1uhRo7WM0Jbx3WvodKuIZ8A_z8fM 项目状态变更通知
- //
- //
- //弘则研究:
- //MwZ5wxfd0O1Yt0Pkf6OkfWP4USQzZbiEo5SkZ26735s 活动预约通知
- //dYg6iHooRq74PyCXmw_Ns7qdJZmbtLoKS2p2FKeaXl0 项目状态变更通知
- func WxSendTemplateMsg(sendUrl string, sendMap map[string]interface{}, items []*models.OpenIdList, resource string, sendType int) (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())
- return err
- }
- utils.FileLog.Info("One SendData:%s", string(data))
- fmt.Println(string(data))
- err = SendTemplateMsg(sendUrl, data, resource, sendType, v)
- if err != nil {
- fmt.Println("send err:", err.Error())
- return err
- }
- }
- return
- }
- func SendTemplateMsg(sendUrl string, data []byte, resource string, sendType int, dataItem *models.OpenIdList) (err error) {
- 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 models.SendTemplateResponse
- err = json.Unmarshal(body, &templateResponse)
- fmt.Println(templateResponse.Errcode)
- fmt.Println(templateResponse.Errmsg)
- if err != nil {
- return err
- }
- //新增模板消息推送记录
- {
- tr := new(models.UserTemplateRecord)
- tr.UserId = dataItem.UserId
- tr.OpenId = dataItem.OpenId
- tr.Resource = resource
- tr.SendData = string(data)
- tr.Result = string(body)
- tr.CreateDate = time.Now().Format(utils.FormatDate)
- tr.CreateTime = time.Now().Format(utils.FormatDateTime)
- if templateResponse.Errcode == 0 {
- tr.SendStatus = 1
- } else {
- tr.SendStatus = 0
- }
- tr.SendType = sendType
- go func() {
- err = models.AddUserTemplateRecord(tr)
- if err != nil {
- utils.FileLog.Info(fmt.Sprintf("AddUserTemplateRecord Err:%s", err.Error()))
- }
- }()
- }
- return
- }
|