mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2025-12-18 13:29:03 +08:00
59 lines
1.5 KiB
Go
59 lines
1.5 KiB
Go
package utils
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/1Panel-dev/1Panel/app/dto"
|
|
"github.com/1Panel-dev/1Panel/constant/errres"
|
|
"github.com/1Panel-dev/1Panel/global"
|
|
|
|
"github.com/golang-jwt/jwt/v4"
|
|
)
|
|
|
|
type JWT struct {
|
|
SigningKey []byte
|
|
}
|
|
|
|
func NewJWT() *JWT {
|
|
return &JWT{
|
|
[]byte(global.Config.JWT.SigningKey),
|
|
}
|
|
}
|
|
|
|
func (j *JWT) CreateToken(request dto.JwtRequest) (string, error) {
|
|
request.RegisteredClaims = jwt.RegisteredClaims{
|
|
Issuer: global.Config.JWT.Issuer,
|
|
NotBefore: jwt.NewNumericDate(time.Now()),
|
|
ExpiresAt: jwt.NewNumericDate(time.Now().Add(24 * time.Hour)),
|
|
}
|
|
token := jwt.NewWithClaims(jwt.SigningMethodES256, &request)
|
|
return token.SignedString(j.SigningKey)
|
|
}
|
|
|
|
func (j *JWT) ParseToken(tokenStr string) (*dto.JwtRequest, error) {
|
|
token, err := jwt.ParseWithClaims(tokenStr, &dto.JwtRequest{}, func(token *jwt.Token) (interface{}, error) {
|
|
return j.SigningKey, nil
|
|
})
|
|
if err != nil {
|
|
if ve, ok := err.(*jwt.ValidationError); ok {
|
|
if ve.Errors&jwt.ValidationErrorMalformed != 0 {
|
|
return nil, errres.TokenMalformed
|
|
} else if ve.Errors&jwt.ValidationErrorExpired != 0 {
|
|
return nil, errres.TokenExpired
|
|
} else if ve.Errors&jwt.ValidationErrorNotValidYet != 0 {
|
|
return nil, errres.TokenNotValidYet
|
|
} else {
|
|
return nil, errres.TokenInvalid
|
|
}
|
|
}
|
|
}
|
|
if token != nil {
|
|
if claims, ok := token.Claims.(*dto.JwtRequest); ok && token.Valid {
|
|
return claims, nil
|
|
}
|
|
return nil, errres.TokenInvalid
|
|
|
|
} else {
|
|
return nil, errres.TokenInvalid
|
|
}
|
|
}
|