兼容无token下拉取任务列表
This commit is contained in:
@@ -40,67 +40,63 @@ func (b *TokenBuilder) GenerateToken(kvs map[string]any) (string, int64, error)
|
||||
return tkStr, expiredAt, err
|
||||
}
|
||||
|
||||
func (b *TokenBuilder) ParseUidFromToken(tokenStr string) (string, string, string, int64, error) {
|
||||
func (b *TokenBuilder) ParseUidFromToken(tokenStr string) (int, int64, error) {
|
||||
r := &http.Request{Header: http.Header{}}
|
||||
r.Header.Set("Authorization", fmt.Sprintf("Bearer %s", tokenStr))
|
||||
parser := token.NewTokenParser()
|
||||
tok, err := parser.ParseToken(r, b.config.AccessSecret, "")
|
||||
if err != nil {
|
||||
return "", "", "", 0, err
|
||||
return 0, 0, err
|
||||
}
|
||||
if !tok.Valid {
|
||||
return "", "", "", 0, errors.New("token is invalid")
|
||||
return 0, 0, errors.New("token is invalid")
|
||||
}
|
||||
var appid, userId, tgId string
|
||||
var userId int
|
||||
var expiredAt int64
|
||||
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
||||
if uid, ok := claims["uid"]; ok {
|
||||
userId = cast.ToString(uid)
|
||||
}
|
||||
if aid, ok := claims["app_id"]; ok {
|
||||
appid = cast.ToString(aid)
|
||||
}
|
||||
if tid, ok := claims["tg_id"]; ok {
|
||||
tgId = cast.ToString(tid)
|
||||
if data, ok := claims["data"]; ok {
|
||||
userId, _ = cast.ToStringMapInt(data)["id"]
|
||||
}
|
||||
if exp, ok := claims["exp"]; ok {
|
||||
expiredAt = cast.ToInt64(exp)
|
||||
}
|
||||
}
|
||||
return appid, userId, tgId, expiredAt, nil
|
||||
return userId, expiredAt, nil
|
||||
}
|
||||
|
||||
// ParseUid 解析出uid
|
||||
func (b *TokenBuilder) ParseUid(r *http.Request) (string, error) {
|
||||
func (b *TokenBuilder) ParseUid(r *http.Request) (int, error) {
|
||||
parser := token.NewTokenParser()
|
||||
tok, err := parser.ParseToken(r, b.config.AccessSecret, "")
|
||||
if err != nil {
|
||||
return "", err
|
||||
return 0, err
|
||||
}
|
||||
if !tok.Valid {
|
||||
return "", errors.New("token is invalid")
|
||||
return 0, errors.New("token is invalid")
|
||||
}
|
||||
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
||||
if uid, ok := claims["uid"]; ok {
|
||||
return cast.ToString(uid), nil
|
||||
if data, ok := claims["data"]; ok {
|
||||
uid, _ := cast.ToStringMapInt(data)["id"]
|
||||
return uid, nil
|
||||
}
|
||||
}
|
||||
return "", errors.New("token not exist uid")
|
||||
return 0, errors.New("token not exist uid")
|
||||
}
|
||||
|
||||
func ParseUid(r *http.Request, accessSecret string) (string, error) {
|
||||
func ParseUid(r *http.Request, accessSecret string) (int, error) {
|
||||
parser := token.NewTokenParser()
|
||||
tok, err := parser.ParseToken(r, accessSecret, "")
|
||||
if err != nil {
|
||||
return "", err
|
||||
return 0, err
|
||||
}
|
||||
if !tok.Valid {
|
||||
return "", errors.New("token is invalid")
|
||||
return 0, errors.New("token is invalid")
|
||||
}
|
||||
if claims, ok := tok.Claims.(jwt.MapClaims); ok {
|
||||
if uid, ok := claims["uid"]; ok {
|
||||
return cast.ToString(uid), nil
|
||||
if data, ok := claims["data"]; ok {
|
||||
uid, _ := cast.ToStringMapInt(data)["id"]
|
||||
return uid, nil
|
||||
}
|
||||
}
|
||||
return "", errors.New("token not exist uid")
|
||||
return 0, errors.New("token not exist uid")
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user