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>
		
			
				
	
	
		
			218 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			218 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package projection
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"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"
 | |
| 	"github.com/zitadel/zitadel/internal/eventstore/handler/crdb"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/instance"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/org"
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	OrgProjectionTable = "projections.orgs"
 | |
| 
 | |
| 	OrgColumnID            = "id"
 | |
| 	OrgColumnCreationDate  = "creation_date"
 | |
| 	OrgColumnChangeDate    = "change_date"
 | |
| 	OrgColumnResourceOwner = "resource_owner"
 | |
| 	OrgColumnInstanceID    = "instance_id"
 | |
| 	OrgColumnState         = "org_state"
 | |
| 	OrgColumnSequence      = "sequence"
 | |
| 	OrgColumnName          = "name"
 | |
| 	OrgColumnDomain        = "primary_domain"
 | |
| )
 | |
| 
 | |
| type orgProjection struct {
 | |
| 	crdb.StatementHandler
 | |
| }
 | |
| 
 | |
| func newOrgProjection(ctx context.Context, config crdb.StatementHandlerConfig) *orgProjection {
 | |
| 	p := new(orgProjection)
 | |
| 	config.ProjectionName = OrgProjectionTable
 | |
| 	config.Reducers = p.reducers()
 | |
| 	config.InitCheck = crdb.NewTableCheck(
 | |
| 		crdb.NewTable([]*crdb.Column{
 | |
| 			crdb.NewColumn(OrgColumnID, crdb.ColumnTypeText),
 | |
| 			crdb.NewColumn(OrgColumnCreationDate, crdb.ColumnTypeTimestamp),
 | |
| 			crdb.NewColumn(OrgColumnChangeDate, crdb.ColumnTypeTimestamp),
 | |
| 			crdb.NewColumn(OrgColumnResourceOwner, crdb.ColumnTypeText),
 | |
| 			crdb.NewColumn(OrgColumnInstanceID, crdb.ColumnTypeText),
 | |
| 			crdb.NewColumn(OrgColumnState, crdb.ColumnTypeEnum),
 | |
| 			crdb.NewColumn(OrgColumnSequence, crdb.ColumnTypeInt64),
 | |
| 			crdb.NewColumn(OrgColumnName, crdb.ColumnTypeText),
 | |
| 			crdb.NewColumn(OrgColumnDomain, crdb.ColumnTypeText, crdb.Default("")),
 | |
| 		},
 | |
| 			crdb.NewPrimaryKey(OrgColumnInstanceID, OrgColumnID),
 | |
| 			crdb.WithIndex(crdb.NewIndex("domain", []string{OrgColumnDomain})),
 | |
| 			crdb.WithIndex(crdb.NewIndex("name", []string{OrgColumnName})),
 | |
| 		),
 | |
| 	)
 | |
| 	p.StatementHandler = crdb.NewStatementHandler(ctx, config)
 | |
| 	return p
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reducers() []handler.AggregateReducer {
 | |
| 	return []handler.AggregateReducer{
 | |
| 		{
 | |
| 			Aggregate: org.AggregateType,
 | |
| 			EventRedusers: []handler.EventReducer{
 | |
| 				{
 | |
| 					Event:  org.OrgAddedEventType,
 | |
| 					Reduce: p.reduceOrgAdded,
 | |
| 				},
 | |
| 				{
 | |
| 					Event:  org.OrgChangedEventType,
 | |
| 					Reduce: p.reduceOrgChanged,
 | |
| 				},
 | |
| 				{
 | |
| 					Event:  org.OrgDeactivatedEventType,
 | |
| 					Reduce: p.reduceOrgDeactivated,
 | |
| 				},
 | |
| 				{
 | |
| 					Event:  org.OrgReactivatedEventType,
 | |
| 					Reduce: p.reduceOrgReactivated,
 | |
| 				},
 | |
| 				{
 | |
| 					Event:  org.OrgRemovedEventType,
 | |
| 					Reduce: p.reduceOrgRemoved,
 | |
| 				},
 | |
| 				{
 | |
| 					Event:  org.OrgDomainPrimarySetEventType,
 | |
| 					Reduce: p.reducePrimaryDomainSet,
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			Aggregate: instance.AggregateType,
 | |
| 			EventRedusers: []handler.EventReducer{
 | |
| 				{
 | |
| 					Event:  instance.InstanceRemovedEventType,
 | |
| 					Reduce: reduceInstanceRemovedHelper(OrgColumnInstanceID),
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reduceOrgAdded(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*org.OrgAddedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowInvalidArgumentf(nil, "HANDL-uYq4r", "reduce.wrong.event.type %s", org.OrgAddedEventType)
 | |
| 	}
 | |
| 	return crdb.NewCreateStatement(
 | |
| 		e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(OrgColumnID, e.Aggregate().ID),
 | |
| 			handler.NewCol(OrgColumnCreationDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnChangeDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnResourceOwner, e.Aggregate().ResourceOwner),
 | |
| 			handler.NewCol(OrgColumnInstanceID, e.Aggregate().InstanceID),
 | |
| 			handler.NewCol(OrgColumnSequence, e.Sequence()),
 | |
| 			handler.NewCol(OrgColumnName, e.Name),
 | |
| 			handler.NewCol(OrgColumnState, domain.OrgStateActive),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reduceOrgChanged(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*org.OrgChangedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowInvalidArgumentf(nil, "HANDL-Bg8oM", "reduce.wrong.event.type %s", org.OrgChangedEventType)
 | |
| 	}
 | |
| 	if e.Name == "" {
 | |
| 		return crdb.NewNoOpStatement(e), nil
 | |
| 	}
 | |
| 	return crdb.NewUpdateStatement(
 | |
| 		e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(OrgColumnChangeDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnSequence, e.Sequence()),
 | |
| 			handler.NewCol(OrgColumnName, e.Name),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(OrgColumnID, e.Aggregate().ID),
 | |
| 			handler.NewCond(OrgColumnInstanceID, e.Aggregate().InstanceID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reduceOrgDeactivated(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*org.OrgDeactivatedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowInvalidArgumentf(nil, "HANDL-BApK4", "reduce.wrong.event.type %s", org.OrgDeactivatedEventType)
 | |
| 	}
 | |
| 	return crdb.NewUpdateStatement(
 | |
| 		e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(OrgColumnChangeDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnSequence, e.Sequence()),
 | |
| 			handler.NewCol(OrgColumnState, domain.OrgStateInactive),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(OrgColumnID, e.Aggregate().ID),
 | |
| 			handler.NewCond(OrgColumnInstanceID, e.Aggregate().InstanceID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reduceOrgReactivated(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*org.OrgReactivatedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowInvalidArgumentf(nil, "HANDL-o37De", "reduce.wrong.event.type %s", org.OrgReactivatedEventType)
 | |
| 	}
 | |
| 	return crdb.NewUpdateStatement(
 | |
| 		e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(OrgColumnChangeDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnSequence, e.Sequence()),
 | |
| 			handler.NewCol(OrgColumnState, domain.OrgStateActive),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(OrgColumnID, e.Aggregate().ID),
 | |
| 			handler.NewCond(OrgColumnInstanceID, e.Aggregate().InstanceID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reducePrimaryDomainSet(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*org.DomainPrimarySetEvent)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowInvalidArgumentf(nil, "HANDL-4TbKT", "reduce.wrong.event.type %s", org.OrgDomainPrimarySetEventType)
 | |
| 	}
 | |
| 	return crdb.NewUpdateStatement(
 | |
| 		e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(OrgColumnChangeDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnSequence, e.Sequence()),
 | |
| 			handler.NewCol(OrgColumnDomain, e.Domain),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(OrgColumnID, e.Aggregate().ID),
 | |
| 			handler.NewCond(OrgColumnInstanceID, e.Aggregate().InstanceID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 | |
| 
 | |
| func (p *orgProjection) reduceOrgRemoved(event eventstore.Event) (*handler.Statement, error) {
 | |
| 	e, ok := event.(*org.OrgRemovedEvent)
 | |
| 	if !ok {
 | |
| 		return nil, errors.ThrowInvalidArgumentf(nil, "PROJE-DgMSg", "reduce.wrong.event.type %s", org.OrgRemovedEventType)
 | |
| 	}
 | |
| 	return crdb.NewUpdateStatement(
 | |
| 		e,
 | |
| 		[]handler.Column{
 | |
| 			handler.NewCol(OrgColumnChangeDate, e.CreationDate()),
 | |
| 			handler.NewCol(OrgColumnSequence, e.Sequence()),
 | |
| 			handler.NewCol(OrgColumnState, domain.OrgStateRemoved),
 | |
| 		},
 | |
| 		[]handler.Condition{
 | |
| 			handler.NewCond(OrgColumnID, e.Aggregate().ID),
 | |
| 			handler.NewCond(OrgColumnInstanceID, e.Aggregate().InstanceID),
 | |
| 		},
 | |
| 	), nil
 | |
| }
 |