- 解决wxtoken的刷新问题

This commit is contained in:
gazebo
2019-04-27 15:44:26 +08:00
parent beb6482a1a
commit dbd9e3a3d2
3 changed files with 54 additions and 66 deletions

View File

@@ -33,7 +33,6 @@ const (
) )
type IEventProducer interface { type IEventProducer interface {
GetEvent(eventTypeList []string, criteria interface{}) (event *EventInfo, err error)
IsCriteriaMatch(eventInfo *EventInfo, criteria interface{}) bool IsCriteriaMatch(eventInfo *EventInfo, criteria interface{}) bool
} }
@@ -212,36 +211,29 @@ func (e *EventHub) PostNewEvent(eventCategory string, event *EventInfo) {
} }
func (e *EventHub) GetEvent(eventCategory string, eventTypeList []string, criteria interface{}, waitTime time.Duration) (event *EventInfo, err error) { func (e *EventHub) GetEvent(eventCategory string, eventTypeList []string, criteria interface{}, waitTime time.Duration) (event *EventInfo, err error) {
eventProducer := e.getEventProducer(eventCategory) notifyChan := e.registerConsumer(eventCategory, eventTypeList, criteria)
if eventProducer == nil { pollingDuration := defPollingDuration
return nil, fmt.Errorf("eventCategory:%s没有注册", eventCategory) if waitTime != 0 {
} pollingDuration = waitTime
event, err = eventProducer.GetEvent(eventTypeList, criteria) if globals.IsProductEnv() {
if err == nil && event == nil { if pollingDuration > maxPollingDuration {
notifyChan := e.registerConsumer(eventCategory, eventTypeList, criteria) pollingDuration = maxPollingDuration
pollingDuration := defPollingDuration } else if pollingDuration < minPollingDuration {
if waitTime != 0 { pollingDuration = minPollingDuration
pollingDuration = waitTime
if globals.IsProductEnv() {
if pollingDuration > maxPollingDuration {
pollingDuration = maxPollingDuration
} else if pollingDuration < minPollingDuration {
pollingDuration = minPollingDuration
}
} }
} }
timer := time.NewTimer(pollingDuration)
select {
case tmpEvent, ok := <-notifyChan:
timer.Stop()
if ok {
event = tmpEvent
}
case <-timer.C:
e.unregisterConsumer(notifyChan)
}
close(notifyChan)
} }
timer := time.NewTimer(pollingDuration)
select {
case tmpEvent, ok := <-notifyChan:
timer.Stop()
if ok {
event = tmpEvent
}
case <-timer.C:
e.unregisterConsumer(notifyChan)
}
close(notifyChan)
return event, err return event, err
} }

View File

@@ -20,6 +20,11 @@ type Hub struct {
type Criteria struct { type Criteria struct {
} }
type WXTokenInfo struct {
IsNew bool `json:"isNew"`
Token string `json:"token"`
}
var ( var (
SysEventHub *Hub SysEventHub *Hub
) )
@@ -36,31 +41,6 @@ func New() (hub *Hub) {
return hub return hub
} }
func (h *Hub) GetEvent(eventTypeList []string, criteria interface{}) (event *eventhub.EventInfo, err error) {
for _, eventType := range eventTypeList {
switch eventType {
case EventTypeWXToken:
return h.getWXToken(criteria)
}
}
return event, err
}
func (h *Hub) getWXToken(criteria interface{}) (event *eventhub.EventInfo, err error) {
criteriaToken := ""
if criteria != nil {
criteriaToken = criteria.(string)
}
token := api.WeixinAPI.CBGetToken()
if token != criteriaToken {
return &eventhub.EventInfo{
Type: EventTypeWXToken,
Data: token,
}, nil
}
return nil, nil
}
func (h *Hub) IsCriteriaMatch(eventInfo *eventhub.EventInfo, criteria interface{}) bool { func (h *Hub) IsCriteriaMatch(eventInfo *eventhub.EventInfo, criteria interface{}) bool {
return true return true
} }
@@ -72,10 +52,21 @@ func (h *Hub) OnNewWXToken(token string) {
}) })
} }
func (h *Hub) GetWXToken(oldToken string, waitTime time.Duration) (token string) { func (h *Hub) GetWXToken(oldToken string, waitTime time.Duration) (tokenInfo *WXTokenInfo) {
eventInfo, err := h.eventHub.GetEvent(EventCategory, []string{EventTypeWXToken}, oldToken, waitTime) token := api.WeixinAPI.CBGetToken()
if err == nil && eventInfo != nil { if token != oldToken {
token = eventInfo.Data.(string) tokenInfo = &WXTokenInfo{
IsNew: false,
Token: token,
}
} else {
eventInfo, err := h.eventHub.GetEvent(EventCategory, []string{EventTypeWXToken}, nil, waitTime)
if err == nil && eventInfo != nil {
tokenInfo = &WXTokenInfo{
IsNew: true,
Token: eventInfo.Data.(string),
}
}
} }
return token return tokenInfo
} }

View File

@@ -4,7 +4,6 @@ import (
"fmt" "fmt"
"io/ioutil" "io/ioutil"
"net/http" "net/http"
"strings"
"time" "time"
"git.rosy.net.cn/baseapi/platformapi" "git.rosy.net.cn/baseapi/platformapi"
@@ -132,10 +131,14 @@ func RefreshWeixinToken() (err error) {
globals.SugarLogger.Errorf("RefreshWeixinToken RefreshToken failed with error:%v", err) globals.SugarLogger.Errorf("RefreshWeixinToken RefreshToken failed with error:%v", err)
} }
} else { } else {
token = getWXTokenFromProd(api.WeixinAPI.CBGetToken()) tokenInfo := getWXTokenFromProd(api.WeixinAPI.CBGetToken())
if !tokenInfo.IsNew {
expireTimeStr = utils.Time2Str(time.Now().Add(-weixinTokenExpires))
}
token = tokenInfo.Token
} }
} }
return token, "" return token, expireTimeStr
}, func(value string) { }, func(value string) {
syseventhub.SysEventHub.OnNewWXToken(value) syseventhub.SysEventHub.OnNewWXToken(value)
api.WeixinAPI.CBSetToken(value) api.WeixinAPI.CBSetToken(value)
@@ -242,8 +245,7 @@ func RefreshYilianyunToken() (err error) {
}) })
} }
func getWXTokenFromProd(oldToken string) (token string) { func getWXTokenFromProd(oldToken string) (tokenInfo *syseventhub.WXTokenInfo) {
token = oldToken
if globals.GetWeixinTokenKey != "" && globals.GetWeixinTokenURL != "" { if globals.GetWeixinTokenKey != "" && globals.GetWeixinTokenURL != "" {
for { for {
waitSecond := 5 * 60 waitSecond := 5 * 60
@@ -256,8 +258,11 @@ func getWXTokenFromProd(oldToken string) (token string) {
var result CallResult var result CallResult
if err = utils.UnmarshalUseNumber(data, &result); err == nil { if err = utils.UnmarshalUseNumber(data, &result); err == nil {
if result.Code == "0" { if result.Code == "0" {
token = strings.Replace(result.Data, "\"", "", -1) if result.Data != "" {
break if err = utils.UnmarshalUseNumber(data, &tokenInfo); err == nil && tokenInfo != nil {
break
}
}
} else { } else {
err = fmt.Errorf("return code is:%s", result.Code) err = fmt.Errorf("return code is:%s", result.Code)
} }
@@ -273,5 +278,5 @@ func getWXTokenFromProd(oldToken string) (token string) {
} }
} }
} }
return token return tokenInfo
} }