package services import ( "bytes" "encoding/json" "errors" "fmt" "hongze/hz_eta_api/models" "hongze/hz_eta_api/models/system" "hongze/hz_eta_api/services/alarm_msg" "hongze/hz_eta_api/utils" "io/ioutil" "net/http" "strconv" "strings" "time" ) func SendWxTemplateMsg(reportId int) (err error) { var msg string defer func() { if err != nil { go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers) utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,Err:%s,%s", err.Error(), msg)) } if msg != "" { utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,msg:%s", msg)) } }() utils.FileLog.Info("%s", "services SendMsg") report, err := models.GetReportById(reportId) if err != nil { msg = "GetReportInfo Err:" + err.Error() return } if report == nil { utils.FileLog.Info("报告信息不存在") return } //accessToken, err := models.GetWxAccessToken() //if err != nil { // msg = "GetWxAccessToken Err:" + err.Error() // return //} //if accessToken == "" { // msg = "accessToken is empty" // return //} openIdArr, err := models.GetOpenIdArr() if err != nil { msg = "get GetOpenIdArr err:" + err.Error() return } //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,最新一期日度点评已上线,欢迎查看" if CheckTwoWeekOrMonthReport(report.ClassifyIdFirst, report.ClassifyNameFirst) { keyword1 = fmt.Sprintf("弘则%s", report.ClassifyNameSecond) first = fmt.Sprintf("Hi,最新一期%s已上线,欢迎查看", report.ClassifyNameFirst) } 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, strconv.Itoa(reportId), utils.TEMPLATE_MSG_REPORT) //} sendInfo := new(SendWxTemplate) sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Keyword3 = keyword3 sendInfo.Keyword4 = keyword4 sendInfo.TemplateId = utils.TemplateIdByProduct sendInfo.RedirectUrl = redirectUrl sendInfo.RedirectTarget = 1 sendInfo.Resource = strconv.Itoa(reportId) sendInfo.SendType = utils.TEMPLATE_MSG_REPORT sendInfo.OpenIdArr = openIdArr err = SendTemplateMsg(sendInfo) return } func sendTemplateMsg(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()) utils.FileLog.Info(fmt.Sprintf("SendTemplateMsgOne Marshal Err:%s", err.Error())) return err } err = toSendTemplateMsg(sendUrl, data, resource, sendType, v) if err != nil { fmt.Println("send err:", err.Error()) utils.FileLog.Info(fmt.Sprintf("ToSendTemplateMsg Err:%s", err.Error())) } } return } func toSendTemplateMsg(sendUrl string, data []byte, resource string, sendType int, dataItem *models.OpenIdList) (err error) { var msg string utils.FileLog.Info("Send:" + 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:" + string(body)) var templateResponse SendTemplateResponse err = json.Unmarshal(body, &templateResponse) if err != nil { utils.FileLog.Info(fmt.Sprintf("SendResult Unmarshal Err:%s", err.Error())) 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())) } }() } accessToken, err := models.GetWxAccessToken() if err != nil { msg = "GetWxAccessToken Err:" + err.Error() utils.FileLog.Info("获取Token失败,msg:" + msg) return } if accessToken == "" { msg = "accessToken is empty" utils.FileLog.Info("accessToken为空,msg:" + msg) return } //模板消息发送超过当日10万次限制错误处理 if templateResponse.Errcode == 45009 { key := "CACHE_SendTemplateMsg_ERR" isExist := utils.Rc.IsExist(key) if isExist == true { return } else { result, _ := json.Marshal(templateResponse) if err != nil { utils.FileLog.Info(fmt.Sprintf("templateResponse Marshal Err:%s", err.Error())) return err } //发送邮件提醒异常 go alarm_msg.SendAlarmMsg("模板消息发送超过当日10万次限制,templateResponse = "+string(result), 3) //go utils.SendEmail("异常提醒:", "模板消息发送超过当日10万次限制,templateResponse = "+string(result), utils.EmailSendToUsers) //设置3分钟缓存,不允许重复添加 utils.Rc.SetNX(key, 1, 6*time.Minute) } //清空发送次数 sendUrl := fmt.Sprintf("https://api.weixin.qq.com/cgi-bin/clear_quota?access_token=%s", accessToken) clearData := make(map[string]interface{}) clearData["appid"] = utils.WxAppId clearJson, _ := json.Marshal(clearData) utils.FileLog.Info("clear_quota data:" + string(clearJson)) resp, err := client.Post(sendUrl, "application/json", bytes.NewBuffer(clearJson)) if err != nil { return err } defer resp.Body.Close() clearBody, err := ioutil.ReadAll(resp.Body) utils.FileLog.Info("clear_quota result:" + string(clearBody)) var clearQuotaResponse ClearQuotaResponse err = json.Unmarshal(clearBody, &clearQuotaResponse) if err != nil { utils.FileLog.Info(fmt.Sprintf("clearQuotaResponse Unmarshal Err:%s", err.Error())) return err } if clearQuotaResponse.Errcode == 0 { //发送邮件解决异常 go alarm_msg.SendAlarmMsg("异常已解决,自动清理限制接口,调用成功", 3) //go utils.SendEmail("异常已解决:", "自动清理限制接口,调用成功", utils.EmailSendToUsers) //重新推送一次 toSendTemplateMsg(sendUrl, data, resource, sendType, dataItem) } } return } type SendTemplateResponse struct { Errcode int `json:"errcode"` Errmsg string `json:"errmsg"` MsgID int `json:"msgid"` } type ClearQuotaResponse struct { Errcode int `json:"errcode"` Errmsg string `json:"errmsg"` } // SendCompanyApplyWxTemplateMsg 微信审批通知模板消息 func SendCompanyApplyWxTemplateMsg(mobile, redirectUrl, wxAppPath string, wxMsgMap map[int]string) (err error) { var msg string defer func() { if err != nil { go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers) utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,Err:%s,%s", err.Error(), msg)) } if msg != "" { utils.FileLog.Info("发送模版消息失败,msg:%s", msg) } }() 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 //} utils.FileLog.Info("mobile:%s", mobile) openIdList, err := system.GetAdminOpenIdListByMobile(mobile) 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.WxCrmAppId, "pagepath": wxAppPath} //} //sendTemplateMsg(sendUrl, sendMap, openIdList, mobile, utils.TEMPLATE_MSG_APPLY) openIdArr := make([]string, len(openIdList)) for i, v := range openIdList { openIdArr[i] = v.OpenId } sendInfo := new(SendWxTemplate) sendInfo.WxAppId = utils.AdminWxAppId sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Keyword3 = keyword3 sendInfo.Remark = remark sendInfo.TemplateId = utils.TemplateIdByCompanyApply sendInfo.RedirectUrl = redirectUrl sendInfo.RedirectTarget = 2 sendInfo.Resource = mobile sendInfo.SendType = utils.TEMPLATE_MSG_APPLY sendInfo.OpenIdArr = openIdArr if wxAppPath != "" { sendInfo.RedirectUrl = wxAppPath } err = SendTemplateMsg(sendInfo) } utils.FileLog.Info("send end") return } // SendDayReportWxTemplateMsg 发送日报(周报、双周报、月报)模板消息 func SendDayReportWxTemplateMsg(researchReport *models.ResearchReport) (err error) { var msg string defer func() { if err != nil { go alarm_msg.SendAlarmMsg("发送日报(周报)模版消息失败,Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("发送日报(周报)模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers) utils.FileLog.Info(fmt.Sprintf("发送日报(周报)模版消息失败,Err:%s,%s", err.Error(), msg)) } if msg != "" { utils.FileLog.Info("发送日报(周报)模版消息失败,msg:%s", msg) } }() utils.FileLog.Info("%s", "services SendMsg") resource := strconv.Itoa(researchReport.ResearchReportId) //跳转地址 redirectUrl := fmt.Sprint(utils.DayReportTemplateRedirectUrl, researchReport.ResearchReportId, "/", researchReport.Type) first := "Hi,最新一期晨报已上线,欢迎查看" keyword1 := "弘则晨报" keyword2 := researchReport.ResearchReportName keyword3 := researchReport.ResearchReportDate.Format(utils.FormatDate) keyword4 := researchReport.ResearchReportName switch researchReport.Type { case "day": first = "Hi,最新一期晨报已上线,欢迎查看" keyword1 = "弘则晨报" case "week": first = "Hi,最新一期周报已上线,欢迎查看" keyword1 = "弘则周报" case "two_week": first = "Hi,最新一期双周报已上线,欢迎查看" keyword1 = "弘则双周报" case "month": first = "Hi,最新一期月报已上线,欢迎查看" keyword1 = "弘则月报" // 模板消息的名称替换 tmpReport, _ := models.GetReportByOldReportId(researchReport.ResearchReportId) if tmpReport != nil { keyword1 = fmt.Sprintf("弘则%s", tmpReport.ClassifyNameSecond) } case "other": first = "Hi,最新一期点评已上线,欢迎查看" keyword1 = "数据点评" } //accessToken, err := models.GetWxAccessToken() //if err != nil { // msg = "GetWxAccessToken Err:" + err.Error() // return //} //fmt.Println(accessToken) //if accessToken == "" { // msg = "accessToken is empty" // return //} openIdList, err := models.GetOpenIdList() 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{}) //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, resource, utils.TEMPLATE_MSG_CYGX_DAY_REPORT) //} openIdArr := make([]string, len(openIdList)) for i, v := range openIdList { openIdArr[i] = v.OpenId } sendInfo := new(SendWxTemplate) sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Keyword3 = keyword3 sendInfo.Keyword4 = keyword4 sendInfo.TemplateId = utils.TemplateIdByProduct sendInfo.RedirectUrl = redirectUrl sendInfo.RedirectTarget = 1 sendInfo.Resource = resource sendInfo.SendType = utils.TEMPLATE_MSG_CYGX_DAY_REPORT sendInfo.OpenIdArr = openIdArr err = SendTemplateMsg(sendInfo) fmt.Println("send end") utils.FileLog.Info("send end") return } // 路演->研究员收到待处理的申请 func SendWxMsgWithRoadshowPending(first, keyword1, keyword2, keyword3, keyword4, remark, wxAppPath string, openIdList []*system.OpenIdList) (err error) { var msg string defer func() { if err != nil { go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers) utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,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.WxMsgTemplateIdWithRoadshowPending //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"} //sendData["remark"] = map[string]interface{}{"value": remark, "color": "#173177"} //if wxAppPath != "" && utils.RunMode == "release" { // sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxCrmAppId, "pagepath": wxAppPath} //} //sendMap["data"] = sendData //sendTemplateMsg(sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT) openIdArr := make([]string, len(openIdList)) for i, v := range openIdList { openIdArr[i] = v.OpenId } sendInfo := new(SendWxTemplate) sendInfo.WxAppId = utils.AdminWxAppId sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Keyword3 = keyword3 sendInfo.Keyword4 = keyword4 sendInfo.Remark = remark sendInfo.TemplateId = utils.WxMsgTemplateIdWithRoadshowPending if wxAppPath != "" && utils.RunMode == "release" { sendInfo.RedirectUrl = wxAppPath } sendInfo.RedirectTarget = 2 sendInfo.Resource = wxAppPath sendInfo.SendType = utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT sendInfo.OpenIdArr = openIdArr err = SendTemplateMsg(sendInfo) return } // 路演->销售收到处理结果 func SendWxMsgWithRoadshowDetailResult(first, keyword1, keyword2, keyword3, keyword4, keyword5, remark, wxAppPath string, openIdList []*system.OpenIdList) (err error) { var msg string defer func() { if err != nil { go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers) utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,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.WxMsgTemplateIdWithRoadshowDetailResult //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["remark"] = map[string]interface{}{"value": remark, "color": "#173177"} // //if wxAppPath != "" && utils.RunMode == "release" { // sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxCrmAppId, "pagepath": wxAppPath} //} //sendMap["data"] = sendData //sendTemplateMsg(sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT) openIdArr := make([]string, len(openIdList)) for i, v := range openIdList { openIdArr[i] = v.OpenId } sendInfo := new(SendWxTemplate) sendInfo.WxAppId = utils.AdminWxAppId sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Keyword3 = keyword3 sendInfo.Keyword4 = keyword4 sendInfo.Keyword5 = keyword5 sendInfo.Remark = remark sendInfo.TemplateId = utils.WxMsgTemplateIdWithRoadshowDetailResult if wxAppPath != "" && utils.RunMode == "release" { sendInfo.RedirectUrl = wxAppPath } sendInfo.RedirectTarget = 2 sendInfo.Resource = wxAppPath sendInfo.SendType = utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT sendInfo.OpenIdArr = openIdArr err = SendTemplateMsg(sendInfo) return } // 路演->研究员收到活动删除通知 func SendWxMsgWithRoadshowDeleteNotice(first, keyword1, keyword2, remark, wxAppPath string, openIdList []*system.OpenIdList) (err error) { var msg string defer func() { if err != nil { go alarm_msg.SendAlarmMsg("发送模版消息失败,Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers) utils.FileLog.Info(fmt.Sprintf("发送模版消息失败,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.WxMsgTemplateIdWithRoadshowDeleteNotice //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["remark"] = map[string]interface{}{"value": remark, "color": "#173177"} //if wxAppPath != "" && utils.RunMode == "release" { // sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxCrmAppId, "pagepath": wxAppPath} //} //sendMap["data"] = sendData //sendTemplateMsg(sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT) openIdArr := make([]string, len(openIdList)) for i, v := range openIdList { openIdArr[i] = v.OpenId } sendInfo := new(SendWxTemplate) sendInfo.WxAppId = utils.AdminWxAppId sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Remark = remark sendInfo.TemplateId = utils.WxMsgTemplateIdWithRoadshowDeleteNotice if wxAppPath != "" && utils.RunMode == "release" { sendInfo.RedirectUrl = wxAppPath } sendInfo.RedirectTarget = 2 sendInfo.Resource = wxAppPath sendInfo.SendType = utils.TEMPLATE_MSG_ACTIVITY_APPOINTMENT sendInfo.OpenIdArr = openIdArr err = SendTemplateMsg(sendInfo) return } // SendMiniProgramReportWxMsg 推送报告微信模板消息-小程序链接 func SendMiniProgramReportWxMsg(reportId int) (err error) { var msg string reportIdStr := strconv.Itoa(reportId) defer func() { if err != nil { fmt.Println("msg:", msg) utils.FileLog.Error(fmt.Sprintf("SendMiniProgramReportWxMsg, 发送报告模版消息失败, ReportId:%s, Err:%s", reportIdStr, err.Error())) go alarm_msg.SendAlarmMsg("SendMiniProgramReportWxMsg发送报告模版消息失败;"+"ReportId:"+reportIdStr+",Err:"+err.Error()+";msg:"+msg, 3) //go utils.SendEmail("SendMiniProgramReportWxMsg发送报告模版消息失败"+"【"+utils.APPNAME+"】"+"【"+utils.RunMode+"】"+time.Now().Format("2006-01-02 15:04:05"), "ReportId:"+reportIdStr+";"+msg+";Err:"+err.Error(), toUser) } }() utils.FileLog.Info("%s", "services SendMsg") report, err := models.GetReportById(reportId) if err != nil { msg = "GetReportInfo Err:" + err.Error() return } if report == nil { utils.FileLog.Info("报告信息不存在") return } //if report.MsgIsSend == 1 { // return //} //accessToken, err := models.GetWxAccessToken() //if err != nil { // msg = "GetWxAccessToken Err:" + err.Error() // return //} //if accessToken == "" { // msg = "accessToken is empty" // return //} var openIdArr []string if report.ClassifyIdSecond <= 0 { openIdArr, err = models.GetOpenIdArr() if err != nil { msg = "get GetOpenIdArr err:" + err.Error() return } } else { classify, err := models.GetClassifyById(report.ClassifyIdSecond) if err != nil { msg = "获取报告分类失败 err:" + err.Error() return err } if classify.IsMassSend == 1 { openIdArr, err = models.GetOpenIdArr() if err != nil { msg = "get GetOpenIdArr err:" + err.Error() return err } } else { openIdArr, err = models.GetOpenIdArrByClassifyNameSecond(report.ClassifyNameSecond) if err != nil { msg = "GetOpenIdArrByClassifyNameSecond err:" + err.Error() return err } } } //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{}) title := fmt.Sprintf("弘则%s", report.ClassifyNameFirst) if CheckTwoWeekOrMonthReport(report.ClassifyIdFirst, report.ClassifyNameFirst) { title = fmt.Sprintf("弘则%s", report.ClassifyNameSecond) } //redirectUrl := utils.TemplateRedirectUrl + strconv.Itoa(reportId) first := fmt.Sprintf("Hi,最新一期%s已上线,欢迎查看", report.ClassifyNameFirst) keyword1 := title keyword2 := report.Title 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 var wxAppPath string if report.ChapterType == utils.REPORT_TYPE_WEEK { wxAppPath = fmt.Sprintf("pages-report/chapterList?reportId=%s", reportIdStr) } else { wxAppPath = fmt.Sprintf("pages-report/reportDetail?reportId=%s", reportIdStr) } //if wxAppPath != "" { // sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxYbAppId, "pagepath": wxAppPath} //} //err = sendTemplateMsg(sendUrl, sendMap, openIdList, wxAppPath, utils.TEMPLATE_MSG_REPORT) sendInfo := new(SendWxTemplate) sendInfo.First = first sendInfo.Keyword1 = keyword1 sendInfo.Keyword2 = keyword2 sendInfo.Keyword3 = keyword3 sendInfo.Keyword4 = keyword4 sendInfo.TemplateId = utils.TemplateIdByProduct sendInfo.RedirectUrl = wxAppPath sendInfo.Resource = wxAppPath sendInfo.SendType = utils.TEMPLATE_MSG_REPORT sendInfo.OpenIdArr = openIdArr sendInfo.RedirectTarget = 1 err = SendTemplateMsg(sendInfo) return } // CheckTwoWeekOrMonthReport 校验推送报告是否为双周报或者月报 func CheckTwoWeekOrMonthReport(classifyId int, classifyName string) (ok bool) { if utils.RunMode == "debug" { miniStrArr := []string{ "双周报", "月报", } if utils.InArrayByStr(miniStrArr, classifyName) { ok = true } } else { // 此处生产环境用ID主要是担心分类改了名字... IdArr := []int{ 96, 112, } if utils.InArrayByInt(IdArr, classifyId) { ok = true } } return } type SendWxTemplate struct { WxAppId string `description:"公众号appId"` First string `description:"模板消息first字段"` Keyword1 string `description:"模板消息keyword1字段"` Keyword2 string `description:"模板消息keyword2字段"` Keyword3 string `description:"模板消息keyword3字段"` Keyword4 string `description:"模板消息keyword4字段"` Keyword5 string `description:"模板消息keyword5字段"` Remark string `description:"模板消息remark字段"` TemplateId string `description:"模板id"` RedirectUrl string `description:"跳转地址"` RedirectTarget int `description:"小程序跳转目标:1:弘则研报小程序,2:随手办公小程序"` Resource string `description:"资源唯一标识"` SendType int `description:"发送的消息类型:1:报告,2:指标更新提醒,3:审批通知,4:销售领取客户通知,5:活动取消通知,6活动更改时间通知,7:关注的作者发布报告通知,8:发送日报(周报、双周报、月报)模板消息,9:活动预约/报名时间通知"` OpenIdArr []string `description:"消息接收者openid"` } // 推送模板消息 func SendTemplateMsg(sendInfo *SendWxTemplate) (err error) { postData, err := json.Marshal(sendInfo) if err != nil { alarm_msg.SendAlarmMsg("SendTemplateMsg json.Marshal Err:"+err.Error(), 1) return err } body := ioutil.NopCloser(strings.NewReader(string(postData))) client := &http.Client{} req, err := http.NewRequest("POST", utils.SendWxTemplateMsgUrl, body) if err != nil { alarm_msg.SendAlarmMsg("SendTemplateMsg http.NewRequest Err:"+err.Error(), 1) return err } contentType := "application/json;charset=utf-8" req.Header.Set("Content-Type", contentType) req.Header.Set("Authorization", utils.SendTemplateMsgAuthorization) resp, err := client.Do(req) if err != nil { fmt.Println("http client.Do Err:" + err.Error()) return err } defer resp.Body.Close() b, err := ioutil.ReadAll(resp.Body) if err != nil { return err } result := new(models.BaseResponse) err = json.Unmarshal(b, &result) if err != nil { return err } if result.Ret != 200 { err = errors.New(string(b)) return err } return } func PublicsendTemplateMsg(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()) utils.FileLog.Info(fmt.Sprintf("SendTemplateMsgOne Marshal Err:%s", err.Error())) return err } err = toSendTemplateMsg(sendUrl, data, resource, sendType, v) if err != nil { fmt.Println("send err:", err.Error()) utils.FileLog.Info(fmt.Sprintf("ToSendTemplateMsg Err:%s", err.Error())) } } return }