mirror of
https://github.com/tickstep/aliyunpan.git
synced 2025-01-23 22:42:15 +08:00
add token plugin callback for token refresh routine
This commit is contained in:
parent
90a889f0eb
commit
c3dadd00b7
@ -17,6 +17,8 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"github.com/tickstep/aliyunpan-api/aliyunpan"
|
"github.com/tickstep/aliyunpan-api/aliyunpan"
|
||||||
"github.com/tickstep/aliyunpan/internal/config"
|
"github.com/tickstep/aliyunpan/internal/config"
|
||||||
|
"github.com/tickstep/aliyunpan/internal/plugins"
|
||||||
|
"github.com/tickstep/aliyunpan/internal/utils"
|
||||||
"github.com/tickstep/library-go/logger"
|
"github.com/tickstep/library-go/logger"
|
||||||
"math/rand"
|
"math/rand"
|
||||||
"net/url"
|
"net/url"
|
||||||
@ -124,8 +126,21 @@ func RefreshTokenInNeed(activeUser *config.PanUser) bool {
|
|||||||
return true
|
return true
|
||||||
} else {
|
} else {
|
||||||
// token refresh error
|
// token refresh error
|
||||||
// if token has expired, callback plugin api
|
// if token has expired, callback plugin api for notify
|
||||||
// TODO: plugin api callback
|
if now.Unix() >= expiredTime.Unix() {
|
||||||
|
pluginManger := plugins.NewPluginManager(config.GetPluginDir())
|
||||||
|
plugin, _ := pluginManger.GetPlugin()
|
||||||
|
params := &plugins.UserTokenRefreshFinishParams{
|
||||||
|
Result: "fail",
|
||||||
|
Message: er.Error(),
|
||||||
|
OldToken: activeUser.RefreshToken,
|
||||||
|
NewToken: "",
|
||||||
|
UpdatedAt: utils.NowTimeStr(),
|
||||||
|
}
|
||||||
|
if er1 := plugin.UserTokenRefreshFinishCallback(plugins.GetContext(activeUser), params); er1 != nil {
|
||||||
|
logger.Verbosef("UserTokenRefreshFinishCallback error: " + er1.Error())
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user