- 解决wxtoken的刷新问题
This commit is contained in:
@@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user