mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-13 11:34:26 +00:00
6398349c24
* add token exchange feature flag * allow setting reason and actor to access tokens * impersonation * set token types and scopes in response * upgrade oidc to working draft state * fix tests * audience and scope validation * id toke and jwt as input * return id tokens * add grant type token exchange to app config * add integration tests * check and deny actors in api calls * fix instance setting tests by triggering projection on write and cleanup * insert sleep statements again * solve linting issues * add translations * pin oidc v3.15.0 * resolve comments, add event translation * fix refreshtoken test * use ValidateAuthReqScopes from oidc * apparently the linter can't make up its mind * persist actor thru refresh tokens and check in tests * remove unneeded triggers
68 lines
1.6 KiB
Go
68 lines
1.6 KiB
Go
package domain
|
|
|
|
import (
|
|
"context"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/zitadel/zitadel/internal/api/authz"
|
|
es_models "github.com/zitadel/zitadel/internal/eventstore/v1/models"
|
|
)
|
|
|
|
type Token struct {
|
|
es_models.ObjectRoot
|
|
|
|
TokenID string
|
|
ApplicationID string
|
|
UserAgentID string
|
|
RefreshTokenID string
|
|
Audience []string
|
|
Expiration time.Time
|
|
Scopes []string
|
|
PreferredLanguage string
|
|
Reason TokenReason
|
|
Actor *TokenActor
|
|
}
|
|
|
|
func AddAudScopeToAudience(ctx context.Context, audience, scopes []string) []string {
|
|
for _, scope := range scopes {
|
|
if !(strings.HasPrefix(scope, ProjectIDScope) && strings.HasSuffix(scope, AudSuffix)) {
|
|
continue
|
|
}
|
|
projectID := strings.TrimSuffix(strings.TrimPrefix(scope, ProjectIDScope), AudSuffix)
|
|
if projectID == ProjectIDScopeZITADEL {
|
|
projectID = authz.GetInstance(ctx).ProjectID()
|
|
}
|
|
audience = addProjectID(audience, projectID)
|
|
}
|
|
return audience
|
|
}
|
|
|
|
func addProjectID(audience []string, projectID string) []string {
|
|
for _, a := range audience {
|
|
if a == projectID {
|
|
return audience
|
|
}
|
|
}
|
|
return append(audience, projectID)
|
|
}
|
|
|
|
//go:generate enumer -type TokenReason -transform snake -trimprefix TokenReason -json
|
|
type TokenReason int
|
|
|
|
const (
|
|
TokenReasonUnspecified TokenReason = iota
|
|
TokenReasonAuthRequest
|
|
TokenReasonRefresh
|
|
TokenReasonJWTProfile
|
|
TokenReasonClientCredentials
|
|
TokenReasonExchange
|
|
TokenReasonImpersonation
|
|
)
|
|
|
|
type TokenActor struct {
|
|
Actor *TokenActor `json:"actor,omitempty"`
|
|
UserID string `json:"user_id,omitempty"`
|
|
Issuer string `json:"issuer,omitempty"`
|
|
}
|