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>
		
			
				
	
	
		
			634 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			634 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package projection
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/zitadel/zitadel/internal/database"
 | |
| 	"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/repository"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/instance"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/org"
 | |
| 	"github.com/zitadel/zitadel/internal/repository/project"
 | |
| )
 | |
| 
 | |
| func TestAppProjection_reduces(t *testing.T) {
 | |
| 	type args struct {
 | |
| 		event func(t *testing.T) eventstore.Event
 | |
| 	}
 | |
| 	tests := []struct {
 | |
| 		name   string
 | |
| 		args   args
 | |
| 		reduce func(event eventstore.Event) (*handler.Statement, error)
 | |
| 		want   wantReduce
 | |
| 	}{
 | |
| 		{
 | |
| 			name: "project reduceAppAdded",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.ApplicationAddedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 			"appId": "app-id",
 | |
| 			"name": "my-app"
 | |
| 		}`),
 | |
| 				), project.ApplicationAddedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAppAdded,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "INSERT INTO projections.apps4 (id, name, project_id, creation_date, change_date, resource_owner, instance_id, state, sequence) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"app-id",
 | |
| 								"my-app",
 | |
| 								"agg-id",
 | |
| 								anyArg{},
 | |
| 								anyArg{},
 | |
| 								"ro-id",
 | |
| 								"instance-id",
 | |
| 								domain.AppStateActive,
 | |
| 								uint64(15),
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAppChanged",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.ApplicationChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 			"appId": "app-id",
 | |
| 			"name": "my-app"
 | |
| 		}`),
 | |
| 				), project.ApplicationChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAppChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (name, change_date, sequence) = ($1, $2, $3) WHERE (id = $4) AND (instance_id = $5)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"my-app",
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAppDeactivated",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.ApplicationDeactivatedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 			"appId": "app-id"
 | |
| 		}`),
 | |
| 				), project.ApplicationDeactivatedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAppDeactivated,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (state, change_date, sequence) = ($1, $2, $3) WHERE (id = $4) AND (instance_id = $5)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								domain.AppStateInactive,
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAppReactivated",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.ApplicationReactivatedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 			"appId": "app-id"
 | |
| 		}`),
 | |
| 				), project.ApplicationReactivatedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAppReactivated,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (state, change_date, sequence) = ($1, $2, $3) WHERE (id = $4) AND (instance_id = $5)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								domain.AppStateActive,
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAppRemoved",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.ApplicationRemovedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 			"appId": "app-id"
 | |
| 		}`),
 | |
| 				), project.ApplicationRemovedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAppRemoved,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "DELETE FROM projections.apps4 WHERE (id = $1) AND (instance_id = $2)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceProjectRemoved",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.ProjectRemovedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{}`),
 | |
| 				), project.ProjectRemovedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceProjectRemoved,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "DELETE FROM projections.apps4 WHERE (project_id = $1) AND (instance_id = $2)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"agg-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "instance reduceInstanceRemoved",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(instance.InstanceRemovedEventType),
 | |
| 					instance.AggregateType,
 | |
| 					nil,
 | |
| 				), instance.InstanceRemovedEventMapper),
 | |
| 			},
 | |
| 			reduce: reduceInstanceRemovedHelper(AppColumnInstanceID),
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("instance"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "DELETE FROM projections.apps4 WHERE (instance_id = $1)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"agg-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAPIConfigAdded",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.APIConfigAddedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 		            "appId": "app-id",
 | |
| 					"clientId": "client-id",
 | |
| 					"clientSecret": {},
 | |
| 				    "authMethodType": 1
 | |
| 				}`),
 | |
| 				), project.APIConfigAddedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAPIConfigAdded,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "INSERT INTO projections.apps4_api_configs (app_id, instance_id, client_id, client_secret, auth_method) VALUES ($1, $2, $3, $4, $5)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 								"client-id",
 | |
| 								anyArg{},
 | |
| 								domain.APIAuthMethodTypePrivateKeyJWT,
 | |
| 							},
 | |
| 						},
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence) = ($1, $2) WHERE (id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAPIConfigChanged",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.APIConfigChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 		            "appId": "app-id",
 | |
| 					"clientId": "client-id",
 | |
| 					"clientSecret": {},
 | |
| 				    "authMethodType": 1
 | |
| 				}`),
 | |
| 				), project.APIConfigChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAPIConfigChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4_api_configs SET (client_secret, auth_method) = ($1, $2) WHERE (app_id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								domain.APIAuthMethodTypePrivateKeyJWT,
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence) = ($1, $2) WHERE (id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAPIConfigChanged noop",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.APIConfigChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
| 		            "appId": "app-id"
 | |
| 				}`),
 | |
| 				), project.APIConfigChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAPIConfigChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceAPIConfigSecretChanged",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.APIConfigSecretChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
|                         "appId": "app-id",
 | |
|                         "client_secret": {}
 | |
| 		}`),
 | |
| 				), project.APIConfigSecretChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceAPIConfigSecretChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4_api_configs SET client_secret = $1 WHERE (app_id = $2) AND (instance_id = $3)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence) = ($1, $2) WHERE (id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceOIDCConfigAdded",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.OIDCConfigAddedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
|                         "oidcVersion": 0,
 | |
|                         "appId": "app-id",
 | |
|                         "clientId": "client-id",
 | |
|                         "clientSecret": {},
 | |
|                         "redirectUris": ["redirect.one.ch", "redirect.two.ch"],
 | |
|                         "responseTypes": [1,2],
 | |
|                         "grantTypes": [1,2],
 | |
|                         "applicationType": 2,
 | |
|                         "authMethodType": 2,
 | |
|                         "postLogoutRedirectUris": ["logout.one.ch", "logout.two.ch"],
 | |
|                         "devMode": true,
 | |
|                         "accessTokenType": 1,
 | |
|                         "accessTokenRoleAssertion": true,
 | |
|                         "idTokenRoleAssertion": true,
 | |
|                         "idTokenUserinfoAssertion": true,
 | |
|                         "clockSkew": 1000,
 | |
|                         "additionalOrigins": ["origin.one.ch", "origin.two.ch"]
 | |
| 		}`),
 | |
| 				), project.OIDCConfigAddedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceOIDCConfigAdded,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "INSERT INTO projections.apps4_oidc_configs (app_id, instance_id, version, client_id, client_secret, redirect_uris, response_types, grant_types, application_type, auth_method_type, post_logout_redirect_uris, is_dev_mode, access_token_type, access_token_role_assertion, id_token_role_assertion, id_token_userinfo_assertion, clock_skew, additional_origins) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, $15, $16, $17, $18)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 								domain.OIDCVersionV1,
 | |
| 								"client-id",
 | |
| 								anyArg{},
 | |
| 								database.StringArray{"redirect.one.ch", "redirect.two.ch"},
 | |
| 								database.EnumArray[domain.OIDCResponseType]{1, 2},
 | |
| 								database.EnumArray[domain.OIDCGrantType]{1, 2},
 | |
| 								domain.OIDCApplicationTypeNative,
 | |
| 								domain.OIDCAuthMethodTypeNone,
 | |
| 								database.StringArray{"logout.one.ch", "logout.two.ch"},
 | |
| 								true,
 | |
| 								domain.OIDCTokenTypeJWT,
 | |
| 								true,
 | |
| 								true,
 | |
| 								true,
 | |
| 								1 * time.Microsecond,
 | |
| 								database.StringArray{"origin.one.ch", "origin.two.ch"},
 | |
| 							},
 | |
| 						},
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence) = ($1, $2) WHERE (id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceOIDCConfigChanged",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.OIDCConfigChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
|                         "oidcVersion": 0,
 | |
|                         "appId": "app-id",
 | |
|                         "redirectUris": ["redirect.one.ch", "redirect.two.ch"],
 | |
|                         "responseTypes": [1,2],
 | |
|                         "grantTypes": [1,2],
 | |
|                         "applicationType": 2,
 | |
|                         "authMethodType": 2,
 | |
|                         "postLogoutRedirectUris": ["logout.one.ch", "logout.two.ch"],
 | |
|                         "devMode": true,
 | |
|                         "accessTokenType": 1,
 | |
|                         "accessTokenRoleAssertion": true,
 | |
|                         "idTokenRoleAssertion": true,
 | |
|                         "idTokenUserinfoAssertion": true,
 | |
|                         "clockSkew": 1000,
 | |
|                         "additionalOrigins": ["origin.one.ch", "origin.two.ch"]
 | |
| 		}`),
 | |
| 				), project.OIDCConfigChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceOIDCConfigChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4_oidc_configs SET (version, redirect_uris, response_types, grant_types, application_type, auth_method_type, post_logout_redirect_uris, is_dev_mode, access_token_type, access_token_role_assertion, id_token_role_assertion, id_token_userinfo_assertion, clock_skew, additional_origins) = ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14) WHERE (app_id = $15) AND (instance_id = $16)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								domain.OIDCVersionV1,
 | |
| 								database.StringArray{"redirect.one.ch", "redirect.two.ch"},
 | |
| 								database.EnumArray[domain.OIDCResponseType]{1, 2},
 | |
| 								database.EnumArray[domain.OIDCGrantType]{1, 2},
 | |
| 								domain.OIDCApplicationTypeNative,
 | |
| 								domain.OIDCAuthMethodTypeNone,
 | |
| 								database.StringArray{"logout.one.ch", "logout.two.ch"},
 | |
| 								true,
 | |
| 								domain.OIDCTokenTypeJWT,
 | |
| 								true,
 | |
| 								true,
 | |
| 								true,
 | |
| 								1 * time.Microsecond,
 | |
| 								database.StringArray{"origin.one.ch", "origin.two.ch"},
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence) = ($1, $2) WHERE (id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceOIDCConfigChanged noop",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.OIDCConfigChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
|                         "appId": "app-id"
 | |
| 		}`),
 | |
| 				), project.OIDCConfigChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceOIDCConfigChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project reduceOIDCConfigSecretChanged",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(project.OIDCConfigSecretChangedType),
 | |
| 					project.AggregateType,
 | |
| 					[]byte(`{
 | |
|                         "appId": "app-id",
 | |
|                         "client_secret": {}
 | |
| 		}`),
 | |
| 				), project.OIDCConfigSecretChangedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceOIDCConfigSecretChanged,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("project"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4_oidc_configs SET client_secret = $1 WHERE (app_id = $2) AND (instance_id = $3)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence) = ($1, $2) WHERE (id = $3) AND (instance_id = $4)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								"app-id",
 | |
| 								"instance-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 		{
 | |
| 			name: "project.reduceOwnerRemoved",
 | |
| 			args: args{
 | |
| 				event: getEvent(testEvent(
 | |
| 					repository.EventType(org.OrgRemovedEventType),
 | |
| 					org.AggregateType,
 | |
| 					nil,
 | |
| 				), org.OrgRemovedEventMapper),
 | |
| 			},
 | |
| 			reduce: (&appProjection{}).reduceOwnerRemoved,
 | |
| 			want: wantReduce{
 | |
| 				aggregateType:    eventstore.AggregateType("org"),
 | |
| 				sequence:         15,
 | |
| 				previousSequence: 10,
 | |
| 				executer: &testExecuter{
 | |
| 					executions: []execution{
 | |
| 						{
 | |
| 							expectedStmt: "UPDATE projections.apps4 SET (change_date, sequence, owner_removed) = ($1, $2, $3) WHERE (instance_id = $4) AND (resource_owner = $5)",
 | |
| 							expectedArgs: []interface{}{
 | |
| 								anyArg{},
 | |
| 								uint64(15),
 | |
| 								true,
 | |
| 								"instance-id",
 | |
| 								"agg-id",
 | |
| 							},
 | |
| 						},
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			event := baseEvent(t)
 | |
| 			got, err := tt.reduce(event)
 | |
| 			if _, ok := err.(errors.InvalidArgument); !ok {
 | |
| 				t.Errorf("no wrong event mapping: %v, got: %v", err, got)
 | |
| 			}
 | |
| 
 | |
| 			event = tt.args.event(t)
 | |
| 			got, err = tt.reduce(event)
 | |
| 			assertReduce(t, got, err, AppProjectionTable, tt.want)
 | |
| 		})
 | |
| 	}
 | |
| }
 |