mirror of
https://github.com/livekit/livekit.git
synced 2026-04-16 19:15:50 +00:00
62 lines
1.2 KiB
Go
62 lines
1.2 KiB
Go
package auth
|
|
|
|
import (
|
|
"time"
|
|
|
|
"gopkg.in/square/go-jose.v2/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
|
|
}
|
|
|
|
return &APIKeyTokenVerifier{
|
|
token: tok,
|
|
apiKey: out.Issuer,
|
|
identity: out.ID,
|
|
}, nil
|
|
}
|
|
|
|
// Returns the API key this token was signed with
|
|
func (v *APIKeyTokenVerifier) APIKey() string {
|
|
return v.apiKey
|
|
}
|
|
|
|
func (v *APIKeyTokenVerifier) Identity() string {
|
|
return v.identity
|
|
}
|
|
|
|
func (v *APIKeyTokenVerifier) Verify(key interface{}) (*ClaimGrants, error) {
|
|
if key == nil || key == "" {
|
|
return 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, err
|
|
}
|
|
if err := out.Validate(jwt.Expected{Issuer: v.apiKey, Time: time.Now()}); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// copy over identity
|
|
claims.Identity = out.ID
|
|
return &claims, nil
|
|
}
|