/
claims.go
39 lines (34 loc) · 1.09 KB
/
claims.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package oakoidc
import (
"encoding/json"
"fmt"
"github.com/coreos/go-oidc"
)
// StandardClaims captures fields that are typically included in [oidc.UserInfo] claims by various OIDC providers.
//
// https://developers.google.com/identity/openid-connect/openid-connect#an-id-tokens-payload
type StandardClaims struct {
Email string `json:"email"`
EmailVerified bool `json:"email_verified"`
FamilyName string `json:"family_name"`
GivenName string `json:"given_name"`
OrganizationName string `json:"hd"`
Locale string `json:"locale"`
Name string `json:"name"`
Picture string `json:"picture"`
AccountID string `json:"sub"`
}
func (s *StandardClaims) String() string {
result, err := json.MarshalIndent(s, "", " ")
if err != nil {
return "<invalid standard claims>"
}
return string(result)
}
func NewStandardClaims(info *oidc.UserInfo) (*StandardClaims, error) {
var claims *StandardClaims
if err := info.Claims(&claims); err != nil {
return nil, fmt.Errorf("cannot decode token claims: %w", err)
}
return claims, nil
}