blob: 874ca524327f0f71d0fa57d07110c32895b559e9 (
plain)
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
|
package middleware
import (
"github.com/coreos/go-oidc/v3/oidc"
"github.com/xlgmokha/x/pkg/mapper"
"gitlab.com/gitlab-org/software-supply-chain-security/authorization/sparkled/app/domain"
)
type CustomClaims struct {
Name string `json:"name"`
Nickname string `json:"nickname"`
Email string `json:"email"`
ProfileURL string `json:"profile"`
Picture string `json:"picture"`
Groups []string `json:"groups_direct"`
}
func init() {
mapper.Register(func(idToken *oidc.IDToken) *domain.User {
customClaims := &CustomClaims{}
if err := idToken.Claims(customClaims); err != nil {
return &domain.User{ID: domain.ID(idToken.Subject)}
}
return &domain.User{
ID: domain.ID(idToken.Subject),
Username: customClaims.Nickname,
Email: customClaims.Email,
ProfileURL: customClaims.ProfileURL,
Picture: customClaims.Picture,
}
})
}
|