summaryrefslogtreecommitdiff
path: root/app/middleware/init.go
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,
		}
	})
}