|
@@ -44,6 +44,9 @@ func SendWxTemplateMsg(sendInfo *models.SendWxTemplate) (err error) {
|
|
|
sendMap := make(map[string]interface{})
|
|
|
sendData := make(map[string]interface{})
|
|
|
var uniqueCodeStr string
|
|
|
+ if sendInfo.WxAppId != "" {
|
|
|
+ uniqueCodeStr += sendInfo.WxAppId
|
|
|
+ }
|
|
|
if sendInfo.First != "" {
|
|
|
sendData["first"] = map[string]interface{}{"value": sendInfo.First, "color": "#173177"}
|
|
|
uniqueCodeStr += sendInfo.First
|
|
@@ -68,7 +71,14 @@ func SendWxTemplateMsg(sendInfo *models.SendWxTemplate) (err error) {
|
|
|
sendData["keyword4"] = map[string]interface{}{"value": sendInfo.Keyword4, "color": "#173177"}
|
|
|
uniqueCodeStr += sendInfo.Keyword4
|
|
|
}
|
|
|
-
|
|
|
+ if sendInfo.Productname != "" {
|
|
|
+ sendData["productname"] = map[string]interface{}{"value": sendInfo.Productname, "color": "#173177"}
|
|
|
+ uniqueCodeStr += sendInfo.Productname
|
|
|
+ }
|
|
|
+ if sendInfo.Date != "" {
|
|
|
+ sendData["date"] = map[string]interface{}{"value": sendInfo.Date, "color": "#173177"}
|
|
|
+ uniqueCodeStr += sendInfo.Date
|
|
|
+ }
|
|
|
if sendInfo.Remark != "" {
|
|
|
sendData["remark"] = map[string]interface{}{"value": sendInfo.Remark, "color": "#173177"}
|
|
|
uniqueCodeStr += sendInfo.Remark
|
|
@@ -103,7 +113,7 @@ func SendWxTemplateMsg(sendInfo *models.SendWxTemplate) (err error) {
|
|
|
|
|
|
uniqueCode := utils.MD5(uniqueCodeStr)
|
|
|
|
|
|
- err = sendTemplateMsg(sendMap, sendInfo.OpenIdArr, sendInfo.Resource, uniqueCode, sendInfo.SendType)
|
|
|
+ err = sendTemplateMsg(sendInfo.WxAppId, sendMap, sendInfo.OpenIdArr, sendInfo.Resource, uniqueCode, sendInfo.SendType)
|
|
|
if err != nil {
|
|
|
utils.FileLog.Info("send err:" + err.Error())
|
|
|
}
|
|
@@ -113,7 +123,7 @@ func SendWxTemplateMsg(sendInfo *models.SendWxTemplate) (err error) {
|
|
|
}
|
|
|
|
|
|
|
|
|
-func sendTemplateMsg(sendMap map[string]interface{}, openIdArr []string, resource, uniqueCode string, sendType int) (err error) {
|
|
|
+func sendTemplateMsg(wxAppId string, sendMap map[string]interface{}, openIdArr []string, resource, uniqueCode string, sendType int) (err error) {
|
|
|
existList, err := models.GetTemplateRecordByUniqueCode(uniqueCode)
|
|
|
if err != nil && err.Error() != utils.ErrNoRow() {
|
|
|
utils.FileLog.Info(fmt.Sprintf("GetTemplateRecordByUniqueCode Err:%s", err.Error()))
|
|
@@ -128,7 +138,7 @@ func sendTemplateMsg(sendMap map[string]interface{}, openIdArr []string, resourc
|
|
|
utils.FileLog.Info(fmt.Sprintf("SendTemplateMsgOne Marshal Err:%s", err.Error()))
|
|
|
return err
|
|
|
}
|
|
|
- err = toSendTemplateMsg(data, resource, sendType, openId, uniqueCode)
|
|
|
+ err = toSendTemplateMsg(wxAppId, data, resource, sendType, openId, uniqueCode)
|
|
|
if err != nil {
|
|
|
fmt.Println("send err:", err.Error())
|
|
|
utils.FileLog.Info(fmt.Sprintf("ToSendTemplateMsg Err:%s", err.Error()))
|
|
@@ -148,7 +158,7 @@ func sendTemplateMsg(sendMap map[string]interface{}, openIdArr []string, resourc
|
|
|
utils.FileLog.Info(fmt.Sprintf("SendTemplateMsgOne Marshal Err:%s", err.Error()))
|
|
|
return err
|
|
|
}
|
|
|
- err = toSendTemplateMsg( data, resource, sendType, openId, uniqueCode)
|
|
|
+ err = toSendTemplateMsg(wxAppId, data, resource, sendType, openId, uniqueCode)
|
|
|
if err != nil {
|
|
|
fmt.Println("send err:", err.Error())
|
|
|
utils.FileLog.Info(fmt.Sprintf("ToSendTemplateMsg Err:%s", err.Error()))
|
|
@@ -160,14 +170,32 @@ func sendTemplateMsg(sendMap map[string]interface{}, openIdArr []string, resourc
|
|
|
}
|
|
|
|
|
|
|
|
|
-func toSendTemplateMsg(data []byte, resource string, sendType int, openId, uniqueCode string) (err error) {
|
|
|
+func toSendTemplateMsg(wxAppId string, data []byte, resource string, sendType int, openId, uniqueCode string) (err error) {
|
|
|
utils.FileLog.Info("Send:" + string(data))
|
|
|
|
|
|
- accessToken, err,errMsg := getWxAccessToken()
|
|
|
- if err != nil {
|
|
|
- utils.FileLog.Info(fmt.Sprintf("获取Token失败,err:%s,errMsg:%s",err.Error(), errMsg))
|
|
|
- return
|
|
|
+ var accessToken string
|
|
|
+ var errMsg string
|
|
|
+ if wxAppId == utils.WxAppId {
|
|
|
+ accessToken, err, errMsg = getWxAccessToken()
|
|
|
+ if err != nil {
|
|
|
+ utils.FileLog.Info(fmt.Sprintf("获取Token失败,err:%s,errMsg:%s",err.Error(), errMsg))
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }else{
|
|
|
+ var wxAppSecret string
|
|
|
+ var ok bool
|
|
|
+ if wxAppSecret, ok = utils.WxAppList[wxAppId]; !ok {
|
|
|
+ err = errors.New("缺少密钥信息")
|
|
|
+ utils.FileLog.Info(fmt.Sprintf("获取Token失败, errMsg:%s",err.Error()))
|
|
|
+ return
|
|
|
+ }
|
|
|
+ accessToken, err = WxGetRedisAccessToken(wxAppId, wxAppSecret)
|
|
|
+ if err != nil {
|
|
|
+ utils.FileLog.Info(fmt.Sprintf("获取Token失败, errMsg:%s",err.Error()))
|
|
|
+ return
|
|
|
+ }
|
|
|
}
|
|
|
+
|
|
|
sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
|
|
|
|
|
|
client := http.Client{}
|
|
@@ -201,6 +229,7 @@ func toSendTemplateMsg(data []byte, resource string, sendType int, openId, uniqu
|
|
|
}
|
|
|
tr.UniqueCode = uniqueCode
|
|
|
tr.SendType = sendType
|
|
|
+ tr.WxAppId = wxAppId
|
|
|
go func() {
|
|
|
err = models.AddUserTemplateRecord(tr)
|
|
|
if err != nil {
|
|
@@ -217,7 +246,7 @@ func toSendTemplateMsg(data []byte, resource string, sendType int, openId, uniqu
|
|
|
utils.FileLog.Info(fmt.Sprintf("refreshWxAccessToken Err:%s", err.Error()))
|
|
|
return err
|
|
|
}
|
|
|
- return toSendTemplateMsg(data, resource, sendType, openId, uniqueCode)
|
|
|
+ return toSendTemplateMsg(wxAppId,data, resource, sendType, openId, uniqueCode)
|
|
|
}
|
|
|
|
|
|
|
|
@@ -262,7 +291,7 @@ func toSendTemplateMsg(data []byte, resource string, sendType int, openId, uniqu
|
|
|
go alarm_msg.SendAlarmMsg("异常已解决,自动清理限制接口,调用成功", 3)
|
|
|
|
|
|
|
|
|
- toSendTemplateMsg(data, resource, sendType, openId, uniqueCode)
|
|
|
+ toSendTemplateMsg(wxAppId, data, resource, sendType, openId, uniqueCode)
|
|
|
}
|
|
|
}
|
|
|
return
|
|
@@ -291,7 +320,7 @@ func getWxAccessToken()(accessToken string,err error,errMsg string){
|
|
|
func refreshWxAccessToken()(accessToken string,err error,errMsg string){
|
|
|
fmt.Println("强制刷新微信token")
|
|
|
|
|
|
- wxAccessToken, tmpErr := models.GetWxToken()
|
|
|
+ wxAccessToken, tmpErr := models.GetWxToken(utils.WxAppId, utils.WxAppSecret)
|
|
|
if tmpErr != nil {
|
|
|
err = tmpErr
|
|
|
errMsg = "通过微信接口获取accessToken失败 Err:" + err.Error()
|
|
@@ -323,5 +352,32 @@ func refreshWxAccessToken()(accessToken string,err error,errMsg string){
|
|
|
return
|
|
|
}
|
|
|
|
|
|
+ return
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+func WxGetRedisAccessToken(wxAppId, wxAppSecret string) (accessToken string, err error) {
|
|
|
+
|
|
|
+ accessToken, err = utils.Rc.RedisString(utils.HZ_ADMIN_WX_ACCESS_TOEKN+wxAppId)
|
|
|
+ if err != nil {
|
|
|
+ err = nil
|
|
|
+ token, tErr := models.GetWxToken(wxAppId, wxAppSecret)
|
|
|
+ if tErr != nil {
|
|
|
+ return "", tErr
|
|
|
+ }
|
|
|
+ if token.Errmsg != "" {
|
|
|
+ err = errors.New("获取access_token 失败 errcode:" + token.Errmsg + " ;errmsg:" + token.Errmsg)
|
|
|
+ return "", err
|
|
|
+ }
|
|
|
+
|
|
|
+ redisTimeExpire := time.Duration(token.ExpiresIn - 600) * time.Second
|
|
|
+ err = utils.Rc.Put(utils.HZ_ADMIN_WX_ACCESS_TOEKN+wxAppId, token.AccessToken, redisTimeExpire)
|
|
|
+ if err != nil {
|
|
|
+ err = errors.New("保存access_token失败 " + err.Error())
|
|
|
+ return accessToken, err
|
|
|
+ }
|
|
|
+ accessToken = token.AccessToken
|
|
|
+ return
|
|
|
+ }
|
|
|
return
|
|
|
}
|