mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 20:38:48 +00:00 
			
		
		
		
	 f3e6f3b23b
			
		
	
	f3e6f3b23b
	
	
	
		
			
			* feat(command): remove org * refactor: imports, unused code, error handling * reduce org removed in action * add org deletion to projections * add org removal to projections * add org removal to projections * org removed projection * lint import * projections * fix: table names in tests * fix: table names in tests * logging * add org state * fix(domain): add Owner removed to object details * feat(ListQuery): add with owner removed * fix(org-delete): add bool to functions to select with owner removed * fix(org-delete): add bools to user grants with events to determine if dependencies lost owner * fix(org-delete): add unit tests for owner removed and org removed events * fix(org-delete): add handling of org remove for grants and members * fix(org-delete): correction of unit tests for owner removed * fix(org-delete): update projections, unit tests and get functions * fix(org-delete): add change date to authnkeys and owner removed to org metadata * fix(org-delete): include owner removed for login names * fix(org-delete): some column fixes in projections and build for queries with owner removed * indexes * fix(org-delete): include review changes * fix(org-delete): change user projection name after merge * fix(org-delete): include review changes for project grant where no project owner is necessary * fix(org-delete): include auth and adminapi tables with owner removed information * fix(org-delete): cleanup username and orgdomain uniqueconstraints when org is removed * fix(org-delete): add permissions for org.remove * remove unnecessary unique constraints * fix column order in primary keys * fix(org-delete): include review changes * fix(org-delete): add owner removed indexes and chang setup step to create tables * fix(org-delete): move PK order of instance_id and change added user_grant from review * fix(org-delete): no params for prepareUserQuery * change to step 6 * merge main * fix(org-delete): OldUserName rename to private * fix linting * cleanup * fix: remove org test * create prerelease * chore: delete org-delete as prerelease Co-authored-by: Stefan Benz <stefan@caos.ch> Co-authored-by: Livio Spring <livio.a@gmail.com> Co-authored-by: Fabi <38692350+hifabienne@users.noreply.github.com> Co-authored-by: Stefan Benz <46600784+stebenz@users.noreply.github.com>
		
			
				
	
	
		
			188 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			188 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package saml
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/zitadel/saml/pkg/provider"
 | |
| 	"github.com/zitadel/saml/pkg/provider/key"
 | |
| 	"github.com/zitadel/saml/pkg/provider/models"
 | |
| 	"github.com/zitadel/saml/pkg/provider/serviceprovider"
 | |
| 	"github.com/zitadel/saml/pkg/provider/xml/samlp"
 | |
| 
 | |
| 	"github.com/zitadel/zitadel/internal/api/http/middleware"
 | |
| 	"github.com/zitadel/zitadel/internal/auth/repository"
 | |
| 	"github.com/zitadel/zitadel/internal/command"
 | |
| 	"github.com/zitadel/zitadel/internal/crypto"
 | |
| 	"github.com/zitadel/zitadel/internal/domain"
 | |
| 	"github.com/zitadel/zitadel/internal/errors"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore/handler/crdb"
 | |
| 	"github.com/zitadel/zitadel/internal/query"
 | |
| 	"github.com/zitadel/zitadel/internal/telemetry/tracing"
 | |
| )
 | |
| 
 | |
| var _ provider.EntityStorage = &Storage{}
 | |
| var _ provider.IdentityProviderStorage = &Storage{}
 | |
| var _ provider.AuthStorage = &Storage{}
 | |
| var _ provider.UserStorage = &Storage{}
 | |
| 
 | |
| type Storage struct {
 | |
| 	certChan                   <-chan interface{}
 | |
| 	defaultCertificateLifetime time.Duration
 | |
| 
 | |
| 	currentCACertificate       query.Certificate
 | |
| 	currentMetadataCertificate query.Certificate
 | |
| 	currentResponseCertificate query.Certificate
 | |
| 
 | |
| 	locker               crdb.Locker
 | |
| 	certificateAlgorithm string
 | |
| 	encAlg               crypto.EncryptionAlgorithm
 | |
| 	certEncAlg           crypto.EncryptionAlgorithm
 | |
| 
 | |
| 	eventstore *eventstore.Eventstore
 | |
| 	repo       repository.Repository
 | |
| 	command    *command.Commands
 | |
| 	query      *query.Queries
 | |
| 
 | |
| 	defaultLoginURL string
 | |
| }
 | |
| 
 | |
| func (p *Storage) GetEntityByID(ctx context.Context, entityID string) (*serviceprovider.ServiceProvider, error) {
 | |
| 	app, err := p.query.AppBySAMLEntityID(ctx, entityID, false)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return serviceprovider.NewServiceProvider(
 | |
| 		app.ID,
 | |
| 		&serviceprovider.Config{
 | |
| 			Metadata: app.SAMLConfig.Metadata,
 | |
| 		},
 | |
| 		p.defaultLoginURL,
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func (p *Storage) GetEntityIDByAppID(ctx context.Context, appID string) (string, error) {
 | |
| 	app, err := p.query.AppByID(ctx, appID, false)
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 	return app.SAMLConfig.EntityID, nil
 | |
| }
 | |
| 
 | |
| func (p *Storage) Health(context.Context) error {
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (p *Storage) GetCA(ctx context.Context) (*key.CertificateAndKey, error) {
 | |
| 	return p.GetCertificateAndKey(ctx, domain.KeyUsageSAMLCA)
 | |
| }
 | |
| 
 | |
| func (p *Storage) GetMetadataSigningKey(ctx context.Context) (*key.CertificateAndKey, error) {
 | |
| 	return p.GetCertificateAndKey(ctx, domain.KeyUsageSAMLMetadataSigning)
 | |
| }
 | |
| 
 | |
| func (p *Storage) GetResponseSigningKey(ctx context.Context) (*key.CertificateAndKey, error) {
 | |
| 	return p.GetCertificateAndKey(ctx, domain.KeyUsageSAMLResponseSinging)
 | |
| }
 | |
| 
 | |
| func (p *Storage) CreateAuthRequest(ctx context.Context, req *samlp.AuthnRequestType, acsUrl, protocolBinding, relayState, applicationID string) (_ models.AuthRequestInt, err error) {
 | |
| 	ctx, span := tracing.NewSpan(ctx)
 | |
| 	defer func() { span.EndWithError(err) }()
 | |
| 	userAgentID, ok := middleware.UserAgentIDFromCtx(ctx)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowPreconditionFailed(nil, "SAML-sd436", "no user agent id")
 | |
| 	}
 | |
| 
 | |
| 	authRequest := CreateAuthRequestToBusiness(ctx, req, acsUrl, protocolBinding, applicationID, relayState, userAgentID)
 | |
| 
 | |
| 	resp, err := p.repo.CreateAuthRequest(ctx, authRequest)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return AuthRequestFromBusiness(resp)
 | |
| }
 | |
| 
 | |
| func (p *Storage) AuthRequestByID(ctx context.Context, id string) (_ models.AuthRequestInt, err error) {
 | |
| 	ctx, span := tracing.NewSpan(ctx)
 | |
| 	defer func() { span.EndWithError(err) }()
 | |
| 	userAgentID, ok := middleware.UserAgentIDFromCtx(ctx)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowPreconditionFailed(nil, "SAML-D3g21", "no user agent id")
 | |
| 	}
 | |
| 	resp, err := p.repo.AuthRequestByIDCheckLoggedIn(ctx, id, userAgentID)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return AuthRequestFromBusiness(resp)
 | |
| }
 | |
| 
 | |
| func (p *Storage) SetUserinfoWithUserID(ctx context.Context, userinfo models.AttributeSetter, userID string, attributes []int) (err error) {
 | |
| 	ctx, span := tracing.NewSpan(ctx)
 | |
| 	defer func() { span.EndWithError(err) }()
 | |
| 	user, err := p.query.GetUserByID(ctx, true, userID, false)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	setUserinfo(user, userinfo, attributes)
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (p *Storage) SetUserinfoWithLoginName(ctx context.Context, userinfo models.AttributeSetter, loginName string, attributes []int) (err error) {
 | |
| 	ctx, span := tracing.NewSpan(ctx)
 | |
| 	defer func() { span.EndWithError(err) }()
 | |
| 
 | |
| 	loginNameSQ, err := query.NewUserLoginNamesSearchQuery(loginName)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	user, err := p.query.GetUser(ctx, true, false, loginNameSQ)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	setUserinfo(user, userinfo, attributes)
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func setUserinfo(user *query.User, userinfo models.AttributeSetter, attributes []int) {
 | |
| 	if len(attributes) == 0 {
 | |
| 		userinfo.SetUsername(user.PreferredLoginName)
 | |
| 		userinfo.SetUserID(user.ID)
 | |
| 		if user.Human == nil {
 | |
| 			return
 | |
| 		}
 | |
| 		userinfo.SetEmail(user.Human.Email)
 | |
| 		userinfo.SetSurname(user.Human.LastName)
 | |
| 		userinfo.SetGivenName(user.Human.FirstName)
 | |
| 		userinfo.SetFullName(user.Human.DisplayName)
 | |
| 		return
 | |
| 	}
 | |
| 	for _, attribute := range attributes {
 | |
| 		switch attribute {
 | |
| 		case provider.AttributeEmail:
 | |
| 			if user.Human != nil {
 | |
| 				userinfo.SetEmail(user.Human.Email)
 | |
| 			}
 | |
| 		case provider.AttributeSurname:
 | |
| 			if user.Human != nil {
 | |
| 				userinfo.SetSurname(user.Human.LastName)
 | |
| 			}
 | |
| 		case provider.AttributeFullName:
 | |
| 			if user.Human != nil {
 | |
| 				userinfo.SetFullName(user.Human.DisplayName)
 | |
| 			}
 | |
| 		case provider.AttributeGivenName:
 | |
| 			if user.Human != nil {
 | |
| 				userinfo.SetGivenName(user.Human.FirstName)
 | |
| 			}
 | |
| 		case provider.AttributeUsername:
 | |
| 			userinfo.SetUsername(user.PreferredLoginName)
 | |
| 		case provider.AttributeUserID:
 | |
| 			userinfo.SetUserID(user.ID)
 | |
| 		}
 | |
| 	}
 | |
| }
 |