package auth
import (
"time"
"github.com/go-jose/go-jose/v3/jwt"
)
type APIKeyTokenVerifier struct {
token *jwt.JSONWebToken
identity string
apiKey string
}
func ParseAPIToken(raw string) (*APIKeyTokenVerifier, error) {
tok, err := jwt.ParseSigned(raw)
if err != nil {
return nil, err
}
out := jwt.Claims{}
if err := tok.UnsafeClaimsWithoutVerification(&out); err != nil {
return nil, err
}
v := &APIKeyTokenVerifier{
token: tok,
apiKey: out.Issuer,
identity: out.Subject,
}
if v.identity == "" {
v.identity = out.ID
}
return v, nil
}
func (v *APIKeyTokenVerifier) APIKey() string {
return v.apiKey
}
func (v *APIKeyTokenVerifier) Identity() string {
return v.identity
}
func (v *APIKeyTokenVerifier) Verify(key interface{}) (*jwt.Claims, *ClaimGrants, error) {
if key == nil || key == "" {
return nil, nil, ErrKeysMissing
}
if s, ok := key.(string); ok {
key = []byte(s)
}
out := jwt.Claims{}
claims := ClaimGrants{}
if err := v.token.Claims(key, &out, &claims); err != nil {
return nil, nil, err
}
if err := out.Validate(jwt.Expected{Issuer: v.apiKey, Time: time.Now()}); err != nil {
return nil, nil, err
}
claims.Identity = v.identity
return &out, &claims, nil
}