pocketbase/tools/security/jwt.go

57 lines
1.4 KiB
Go
Raw Permalink Normal View History

2022-07-07 05:19:05 +08:00
package security
import (
"errors"
"time"
2025-01-05 17:05:26 +08:00
"github.com/golang-jwt/jwt/v5"
2022-07-07 05:19:05 +08:00
)
// ParseUnverifiedJWT parses JWT and returns its claims
2022-07-07 05:19:05 +08:00
// but DOES NOT verify the signature.
2022-10-30 16:28:14 +08:00
//
// It verifies only the exp, iat and nbf claims.
2022-07-07 05:19:05 +08:00
func ParseUnverifiedJWT(token string) (jwt.MapClaims, error) {
claims := jwt.MapClaims{}
parser := &jwt.Parser{}
_, _, err := parser.ParseUnverified(token, claims)
if err == nil {
2025-01-05 17:05:26 +08:00
err = jwt.NewValidator(jwt.WithIssuedAt()).Validate(claims)
2022-07-07 05:19:05 +08:00
}
return claims, err
}
// ParseJWT verifies and parses JWT and returns its claims.
2022-07-07 05:19:05 +08:00
func ParseJWT(token string, verificationKey string) (jwt.MapClaims, error) {
parser := jwt.NewParser(jwt.WithValidMethods([]string{"HS256"}))
2022-07-07 05:19:05 +08:00
parsedToken, err := parser.Parse(token, func(t *jwt.Token) (any, error) {
return []byte(verificationKey), nil
})
if err != nil {
return nil, err
}
if claims, ok := parsedToken.Claims.(jwt.MapClaims); ok && parsedToken.Valid {
return claims, nil
}
2024-07-10 03:18:04 +08:00
return nil, errors.New("unable to parse token")
2022-07-07 05:19:05 +08:00
}
// NewJWT generates and returns new HS256 signed JWT.
2024-09-30 00:23:19 +08:00
func NewJWT(payload jwt.MapClaims, signingKey string, duration time.Duration) (string, error) {
2022-07-07 05:19:05 +08:00
claims := jwt.MapClaims{
2024-09-30 00:23:19 +08:00
"exp": time.Now().Add(duration).Unix(),
2022-07-07 05:19:05 +08:00
}
for k, v := range payload {
claims[k] = v
2022-07-07 05:19:05 +08:00
}
return jwt.NewWithClaims(jwt.SigningMethodHS256, claims).SignedString([]byte(signingKey))
}