mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-07 23:07:45 +00:00
fix: token check and error unwrapping (#3648)
* fix: token check and error unwrapping * remove unused code
This commit is contained in:
parent
4ec006dd02
commit
616b31c959
@ -32,11 +32,7 @@ func Start(authZRepo authZRepo) (v *TokenVerifier) {
|
||||
}
|
||||
|
||||
func (v *TokenVerifier) VerifyAccessToken(ctx context.Context, token string, method string) (userID, clientID, agentID, prefLang, resourceOwner string, err error) {
|
||||
verifierClientID, projectID, err := v.clientIDAndProjectIDFromMethod(ctx, method)
|
||||
if err != nil {
|
||||
return "", "", "", "", "", err
|
||||
}
|
||||
userID, agentID, clientID, prefLang, resourceOwner, err = v.authZRepo.VerifyAccessToken(ctx, token, verifierClientID, projectID)
|
||||
userID, agentID, clientID, prefLang, resourceOwner, err = v.authZRepo.VerifyAccessToken(ctx, token, "", GetInstance(ctx).ProjectID())
|
||||
return userID, clientID, agentID, prefLang, resourceOwner, err
|
||||
}
|
||||
|
||||
@ -56,33 +52,6 @@ func (v *TokenVerifier) RegisterServer(appName, methodPrefix string, mappings Me
|
||||
}
|
||||
}
|
||||
|
||||
func prefixFromMethod(method string) (string, bool) {
|
||||
parts := strings.Split(method, "/")
|
||||
if len(parts) < 2 {
|
||||
return "", false
|
||||
}
|
||||
return parts[1], true
|
||||
}
|
||||
|
||||
func (v *TokenVerifier) clientIDAndProjectIDFromMethod(ctx context.Context, method string) (clientID, projectID string, err error) {
|
||||
ctx, span := tracing.NewSpan(ctx)
|
||||
defer func() { span.EndWithError(err) }()
|
||||
|
||||
prefix, ok := prefixFromMethod(method)
|
||||
if !ok {
|
||||
return "", "", caos_errs.ThrowPermissionDenied(nil, "AUTHZ-GRD2Q", "Errors.Internal")
|
||||
}
|
||||
app, ok := v.clients.Load(prefix)
|
||||
if !ok {
|
||||
return "", "", caos_errs.ThrowPermissionDenied(nil, "AUTHZ-G2qrh", "Errors.Internal")
|
||||
}
|
||||
c := app.(*client)
|
||||
c.id, c.projectID, err = v.authZRepo.VerifierClientID(ctx, c.name)
|
||||
if err != nil {
|
||||
return "", "", caos_errs.ThrowPermissionDenied(err, "AUTHZ-ptTIF2", "Errors.Internal")
|
||||
}
|
||||
return c.id, c.projectID, nil
|
||||
}
|
||||
func (v *TokenVerifier) SearchMyMemberships(ctx context.Context) (_ []*Membership, err error) {
|
||||
ctx, span := tracing.NewSpan(ctx)
|
||||
defer func() { span.EndWithError(err) }()
|
||||
|
@ -89,7 +89,7 @@ func (repo *TokenVerifierRepo) VerifyAccessToken(ctx context.Context, tokenStrin
|
||||
return token.UserID, "", "", "", token.ResourceOwner, nil
|
||||
}
|
||||
for _, aud := range token.Audience {
|
||||
if verifierClientID == aud || projectID == aud || authz.GetInstance(ctx).ProjectID() == aud {
|
||||
if verifierClientID == aud || projectID == aud {
|
||||
return token.UserID, token.UserAgentID, token.ApplicationID, token.PreferredLanguage, token.ResourceOwner, nil
|
||||
}
|
||||
}
|
||||
|
@ -38,3 +38,7 @@ func IsErrorAlreadyExists(err error) bool {
|
||||
_, ok := err.(AlreadyExists)
|
||||
return ok
|
||||
}
|
||||
|
||||
func (err *AlreadyExistsError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *DeadlineExceededError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *DeadlineExceededError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *InternalError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *InternalError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -38,3 +38,7 @@ func (err *InvalidArgumentError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *InvalidArgumentError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -33,3 +33,7 @@ func (err *NotFoundError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *NotFoundError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *PermissionDeniedError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *PermissionDeniedError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *PreconditionFailedError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *PreconditionFailedError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *UnauthenticatedError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *UnauthenticatedError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *UnavailableError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *UnavailableError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *UnimplementedError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *UnimplementedError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
@ -40,3 +40,7 @@ func (err *UnknownError) Is(target error) bool {
|
||||
}
|
||||
return err.CaosError.Is(t.CaosError)
|
||||
}
|
||||
|
||||
func (err *UnknownError) Unwrap() error {
|
||||
return err.CaosError
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user