mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 20:38:48 +00:00 
			
		
		
		
	feat: add github provider template (#5334)
Adds possibility to manage and use GitHub (incl. Enterprise Server) template based providers
This commit is contained in:
		| @@ -607,6 +607,902 @@ func TestCommandSide_UpdateInstanceGenericOAuthIDP(t *testing.T) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCommandSide_AddInstanceGitHubIDP(t *testing.T) { | ||||
| 	type fields struct { | ||||
| 		eventstore   *eventstore.Eventstore | ||||
| 		idGenerator  id.Generator | ||||
| 		secretCrypto crypto.EncryptionAlgorithm | ||||
| 	} | ||||
| 	type args struct { | ||||
| 		ctx      context.Context | ||||
| 		provider GitHubProvider | ||||
| 	} | ||||
| 	type res struct { | ||||
| 		id   string | ||||
| 		want *domain.ObjectDetails | ||||
| 		err  func(error) bool | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		name   string | ||||
| 		fields fields | ||||
| 		args   args | ||||
| 		res    res | ||||
| 	}{ | ||||
| 		{ | ||||
| 			"invalid client id", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx:      authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubProvider{}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid client secret", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubProvider{ | ||||
| 					ClientID: "clientID", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "ok", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter(), | ||||
| 					expectPush( | ||||
| 						[]*repository.Event{ | ||||
| 							eventFromEventPusherWithInstanceID( | ||||
| 								"instance1", | ||||
| 								instance.NewGitHubIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 									"id1", | ||||
| 									"", | ||||
| 									"clientID", | ||||
| 									&crypto.CryptoValue{ | ||||
| 										CryptoType: crypto.TypeEncryption, | ||||
| 										Algorithm:  "enc", | ||||
| 										KeyID:      "id", | ||||
| 										Crypted:    []byte("clientSecret"), | ||||
| 									}, | ||||
| 									nil, | ||||
| 									idp.Options{}, | ||||
| 								)), | ||||
| 						}, | ||||
| 					), | ||||
| 				), | ||||
| 				idGenerator:  id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubProvider{ | ||||
| 					ClientID:     "clientID", | ||||
| 					ClientSecret: "clientSecret", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				id:   "id1", | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "ok all set", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter(), | ||||
| 					expectPush( | ||||
| 						[]*repository.Event{ | ||||
| 							eventFromEventPusherWithInstanceID( | ||||
| 								"instance1", | ||||
| 								instance.NewGitHubIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 									"id1", | ||||
| 									"name", | ||||
| 									"clientID", | ||||
| 									&crypto.CryptoValue{ | ||||
| 										CryptoType: crypto.TypeEncryption, | ||||
| 										Algorithm:  "enc", | ||||
| 										KeyID:      "id", | ||||
| 										Crypted:    []byte("clientSecret"), | ||||
| 									}, | ||||
| 									[]string{"openid"}, | ||||
| 									idp.Options{ | ||||
| 										IsCreationAllowed: true, | ||||
| 										IsLinkingAllowed:  true, | ||||
| 										IsAutoCreation:    true, | ||||
| 										IsAutoUpdate:      true, | ||||
| 									}, | ||||
| 								)), | ||||
| 						}, | ||||
| 					), | ||||
| 				), | ||||
| 				idGenerator:  id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubProvider{ | ||||
| 					Name:         "name", | ||||
| 					ClientID:     "clientID", | ||||
| 					ClientSecret: "clientSecret", | ||||
| 					Scopes:       []string{"openid"}, | ||||
| 					IDPOptions: idp.Options{ | ||||
| 						IsCreationAllowed: true, | ||||
| 						IsLinkingAllowed:  true, | ||||
| 						IsAutoCreation:    true, | ||||
| 						IsAutoUpdate:      true, | ||||
| 					}, | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				id:   "id1", | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| 	for _, tt := range tests { | ||||
| 		t.Run(tt.name, func(t *testing.T) { | ||||
| 			c := &Commands{ | ||||
| 				eventstore:          tt.fields.eventstore, | ||||
| 				idGenerator:         tt.fields.idGenerator, | ||||
| 				idpConfigEncryption: tt.fields.secretCrypto, | ||||
| 			} | ||||
| 			id, got, err := c.AddInstanceGitHubProvider(tt.args.ctx, tt.args.provider) | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.NoError(t, err) | ||||
| 			} | ||||
| 			if tt.res.err != nil && !tt.res.err(err) { | ||||
| 				t.Errorf("got wrong err: %v ", err) | ||||
| 			} | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.Equal(t, tt.res.id, id) | ||||
| 				assert.Equal(t, tt.res.want, got) | ||||
| 			} | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCommandSide_UpdateInstanceGitHubIDP(t *testing.T) { | ||||
| 	type fields struct { | ||||
| 		eventstore   *eventstore.Eventstore | ||||
| 		secretCrypto crypto.EncryptionAlgorithm | ||||
| 	} | ||||
| 	type args struct { | ||||
| 		ctx      context.Context | ||||
| 		id       string | ||||
| 		provider GitHubProvider | ||||
| 	} | ||||
| 	type res struct { | ||||
| 		want *domain.ObjectDetails | ||||
| 		err  func(error) bool | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		name   string | ||||
| 		fields fields | ||||
| 		args   args | ||||
| 		res    res | ||||
| 	}{ | ||||
| 		{ | ||||
| 			"invalid id", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx:      authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubProvider{}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid client id", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx:      authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:       "id1", | ||||
| 				provider: GitHubProvider{}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "not found", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter(), | ||||
| 				), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubProvider{ | ||||
| 					ClientID: "clientID", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				err: caos_errors.IsNotFound, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "no changes", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter( | ||||
| 						eventFromEventPusher( | ||||
| 							instance.NewGitHubIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 								"id1", | ||||
| 								"", | ||||
| 								"clientID", | ||||
| 								&crypto.CryptoValue{ | ||||
| 									CryptoType: crypto.TypeEncryption, | ||||
| 									Algorithm:  "enc", | ||||
| 									KeyID:      "id", | ||||
| 									Crypted:    []byte("clientSecret"), | ||||
| 								}, | ||||
| 								nil, | ||||
| 								idp.Options{}, | ||||
| 							)), | ||||
| 					), | ||||
| 				), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubProvider{ | ||||
| 					ClientID: "clientID", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "change ok", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter( | ||||
| 						eventFromEventPusher( | ||||
| 							instance.NewGitHubIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 								"id1", | ||||
| 								"name", | ||||
| 								"clientID", | ||||
| 								&crypto.CryptoValue{ | ||||
| 									CryptoType: crypto.TypeEncryption, | ||||
| 									Algorithm:  "enc", | ||||
| 									KeyID:      "id", | ||||
| 									Crypted:    []byte("clientSecret"), | ||||
| 								}, | ||||
| 								nil, | ||||
| 								idp.Options{}, | ||||
| 							)), | ||||
| 					), | ||||
| 					expectPush( | ||||
| 						[]*repository.Event{ | ||||
| 							eventFromEventPusherWithInstanceID( | ||||
| 								"instance1", | ||||
| 								func() eventstore.Command { | ||||
| 									t := true | ||||
| 									event, _ := instance.NewGitHubIDPChangedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 										"id1", | ||||
| 										[]idp.GitHubIDPChanges{ | ||||
| 											idp.ChangeGitHubName("new name"), | ||||
| 											idp.ChangeGitHubClientID("new clientID"), | ||||
| 											idp.ChangeGitHubClientSecret(&crypto.CryptoValue{ | ||||
| 												CryptoType: crypto.TypeEncryption, | ||||
| 												Algorithm:  "enc", | ||||
| 												KeyID:      "id", | ||||
| 												Crypted:    []byte("new clientSecret"), | ||||
| 											}), | ||||
| 											idp.ChangeGitHubScopes([]string{"openid", "profile"}), | ||||
| 											idp.ChangeGitHubOptions(idp.OptionChanges{ | ||||
| 												IsCreationAllowed: &t, | ||||
| 												IsLinkingAllowed:  &t, | ||||
| 												IsAutoCreation:    &t, | ||||
| 												IsAutoUpdate:      &t, | ||||
| 											}), | ||||
| 										}, | ||||
| 									) | ||||
| 									return event | ||||
| 								}(), | ||||
| 							), | ||||
| 						}, | ||||
| 					), | ||||
| 				), | ||||
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubProvider{ | ||||
| 					Name:         "new name", | ||||
| 					ClientID:     "new clientID", | ||||
| 					ClientSecret: "new clientSecret", | ||||
| 					Scopes:       []string{"openid", "profile"}, | ||||
| 					IDPOptions: idp.Options{ | ||||
| 						IsCreationAllowed: true, | ||||
| 						IsLinkingAllowed:  true, | ||||
| 						IsAutoCreation:    true, | ||||
| 						IsAutoUpdate:      true, | ||||
| 					}, | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| 	for _, tt := range tests { | ||||
| 		t.Run(tt.name, func(t *testing.T) { | ||||
| 			c := &Commands{ | ||||
| 				eventstore:          tt.fields.eventstore, | ||||
| 				idpConfigEncryption: tt.fields.secretCrypto, | ||||
| 			} | ||||
| 			got, err := c.UpdateInstanceGitHubProvider(tt.args.ctx, tt.args.id, tt.args.provider) | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.NoError(t, err) | ||||
| 			} | ||||
| 			if tt.res.err != nil && !tt.res.err(err) { | ||||
| 				t.Errorf("got wrong err: %v ", err) | ||||
| 			} | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.Equal(t, tt.res.want, got) | ||||
| 			} | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCommandSide_AddInstanceGitHubEnterpriseIDP(t *testing.T) { | ||||
| 	type fields struct { | ||||
| 		eventstore   *eventstore.Eventstore | ||||
| 		idGenerator  id.Generator | ||||
| 		secretCrypto crypto.EncryptionAlgorithm | ||||
| 	} | ||||
| 	type args struct { | ||||
| 		ctx      context.Context | ||||
| 		provider GitHubEnterpriseProvider | ||||
| 	} | ||||
| 	type res struct { | ||||
| 		id   string | ||||
| 		want *domain.ObjectDetails | ||||
| 		err  func(error) bool | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		name   string | ||||
| 		fields fields | ||||
| 		args   args | ||||
| 		res    res | ||||
| 	}{ | ||||
| 		{ | ||||
| 			"invalid name", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx:      authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid clientID", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name: "name", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid clientSecret", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:     "name", | ||||
| 					ClientID: "clientID", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid auth endpoint", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:         "name", | ||||
| 					ClientID:     "clientID", | ||||
| 					ClientSecret: "clientSecret", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid token endpoint", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					ClientSecret:          "clientSecret", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid user endpoint", | ||||
| 			fields{ | ||||
| 				eventstore:  eventstoreExpect(t), | ||||
| 				idGenerator: id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					ClientSecret:          "clientSecret", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 					TokenEndpoint:         "token", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "ok", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter(), | ||||
| 					expectPush( | ||||
| 						[]*repository.Event{ | ||||
| 							eventFromEventPusherWithInstanceID( | ||||
| 								"instance1", | ||||
| 								instance.NewGitHubEnterpriseIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 									"id1", | ||||
| 									"name", | ||||
| 									"clientID", | ||||
| 									&crypto.CryptoValue{ | ||||
| 										CryptoType: crypto.TypeEncryption, | ||||
| 										Algorithm:  "enc", | ||||
| 										KeyID:      "id", | ||||
| 										Crypted:    []byte("clientSecret"), | ||||
| 									}, | ||||
| 									"auth", | ||||
| 									"token", | ||||
| 									"user", | ||||
| 									nil, | ||||
| 									idp.Options{}, | ||||
| 								)), | ||||
| 						}, | ||||
| 					), | ||||
| 				), | ||||
| 				idGenerator:  id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					ClientSecret:          "clientSecret", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 					TokenEndpoint:         "token", | ||||
| 					UserEndpoint:          "user", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				id:   "id1", | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "ok all set", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter(), | ||||
| 					expectPush( | ||||
| 						[]*repository.Event{ | ||||
| 							eventFromEventPusherWithInstanceID( | ||||
| 								"instance1", | ||||
| 								instance.NewGitHubEnterpriseIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 									"id1", | ||||
| 									"name", | ||||
| 									"clientID", | ||||
| 									&crypto.CryptoValue{ | ||||
| 										CryptoType: crypto.TypeEncryption, | ||||
| 										Algorithm:  "enc", | ||||
| 										KeyID:      "id", | ||||
| 										Crypted:    []byte("clientSecret"), | ||||
| 									}, | ||||
| 									"auth", | ||||
| 									"token", | ||||
| 									"user", | ||||
| 									[]string{"user"}, | ||||
| 									idp.Options{ | ||||
| 										IsCreationAllowed: true, | ||||
| 										IsLinkingAllowed:  true, | ||||
| 										IsAutoCreation:    true, | ||||
| 										IsAutoUpdate:      true, | ||||
| 									}, | ||||
| 								)), | ||||
| 						}, | ||||
| 					), | ||||
| 				), | ||||
| 				idGenerator:  id_mock.NewIDGeneratorExpectIDs(t, "id1"), | ||||
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					ClientSecret:          "clientSecret", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 					TokenEndpoint:         "token", | ||||
| 					UserEndpoint:          "user", | ||||
| 					Scopes:                []string{"user"}, | ||||
| 					IDPOptions: idp.Options{ | ||||
| 						IsCreationAllowed: true, | ||||
| 						IsLinkingAllowed:  true, | ||||
| 						IsAutoCreation:    true, | ||||
| 						IsAutoUpdate:      true, | ||||
| 					}, | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				id:   "id1", | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| 	for _, tt := range tests { | ||||
| 		t.Run(tt.name, func(t *testing.T) { | ||||
| 			c := &Commands{ | ||||
| 				eventstore:          tt.fields.eventstore, | ||||
| 				idGenerator:         tt.fields.idGenerator, | ||||
| 				idpConfigEncryption: tt.fields.secretCrypto, | ||||
| 			} | ||||
| 			id, got, err := c.AddInstanceGitHubEnterpriseProvider(tt.args.ctx, tt.args.provider) | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.NoError(t, err) | ||||
| 			} | ||||
| 			if tt.res.err != nil && !tt.res.err(err) { | ||||
| 				t.Errorf("got wrong err: %v ", err) | ||||
| 			} | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.Equal(t, tt.res.id, id) | ||||
| 				assert.Equal(t, tt.res.want, got) | ||||
| 			} | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCommandSide_UpdateInstanceGitHubEnterpriseIDP(t *testing.T) { | ||||
| 	type fields struct { | ||||
| 		eventstore   *eventstore.Eventstore | ||||
| 		secretCrypto crypto.EncryptionAlgorithm | ||||
| 	} | ||||
| 	type args struct { | ||||
| 		ctx      context.Context | ||||
| 		id       string | ||||
| 		provider GitHubEnterpriseProvider | ||||
| 	} | ||||
| 	type res struct { | ||||
| 		want *domain.ObjectDetails | ||||
| 		err  func(error) bool | ||||
| 	} | ||||
| 	tests := []struct { | ||||
| 		name   string | ||||
| 		fields fields | ||||
| 		args   args | ||||
| 		res    res | ||||
| 	}{ | ||||
| 		{ | ||||
| 			"invalid id", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx:      authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				provider: GitHubEnterpriseProvider{}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid name", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx:      authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:       "id1", | ||||
| 				provider: GitHubEnterpriseProvider{}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid clientID", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name: "name", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid auth endpoint", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name: "name", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid token endpoint", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"invalid user endpoint", | ||||
| 			fields{ | ||||
| 				eventstore: eventstoreExpect(t), | ||||
| 			}, | ||||
| 			args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 					TokenEndpoint:         "token", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res{ | ||||
| 				err: caos_errors.IsErrorInvalidArgument, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "not found", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter(), | ||||
| 				), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 					TokenEndpoint:         "token", | ||||
| 					UserEndpoint:          "user", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				err: caos_errors.IsNotFound, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "no changes", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter( | ||||
| 						eventFromEventPusher( | ||||
| 							instance.NewGitHubEnterpriseIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 								"id1", | ||||
| 								"name", | ||||
| 								"clientID", | ||||
| 								&crypto.CryptoValue{ | ||||
| 									CryptoType: crypto.TypeEncryption, | ||||
| 									Algorithm:  "enc", | ||||
| 									KeyID:      "id", | ||||
| 									Crypted:    []byte("clientSecret"), | ||||
| 								}, | ||||
| 								"auth", | ||||
| 								"token", | ||||
| 								"user", | ||||
| 								nil, | ||||
| 								idp.Options{}, | ||||
| 							)), | ||||
| 					), | ||||
| 				), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "name", | ||||
| 					ClientID:              "clientID", | ||||
| 					AuthorizationEndpoint: "auth", | ||||
| 					TokenEndpoint:         "token", | ||||
| 					UserEndpoint:          "user", | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			name: "change ok", | ||||
| 			fields: fields{ | ||||
| 				eventstore: eventstoreExpect(t, | ||||
| 					expectFilter( | ||||
| 						eventFromEventPusher( | ||||
| 							instance.NewGitHubEnterpriseIDPAddedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 								"id1", | ||||
| 								"name", | ||||
| 								"clientID", | ||||
| 								&crypto.CryptoValue{ | ||||
| 									CryptoType: crypto.TypeEncryption, | ||||
| 									Algorithm:  "enc", | ||||
| 									KeyID:      "id", | ||||
| 									Crypted:    []byte("clientSecret"), | ||||
| 								}, | ||||
| 								"auth", | ||||
| 								"token", | ||||
| 								"user", | ||||
| 								nil, | ||||
| 								idp.Options{}, | ||||
| 							)), | ||||
| 					), | ||||
| 					expectPush( | ||||
| 						[]*repository.Event{ | ||||
| 							eventFromEventPusherWithInstanceID( | ||||
| 								"instance1", | ||||
| 								func() eventstore.Command { | ||||
| 									t := true | ||||
| 									event, _ := instance.NewGitHubEnterpriseIDPChangedEvent(context.Background(), &instance.NewAggregate("instance1").Aggregate, | ||||
| 										"id1", | ||||
| 										[]idp.GitHubEnterpriseIDPChanges{ | ||||
| 											idp.ChangeGitHubEnterpriseName("new name"), | ||||
| 											idp.ChangeGitHubEnterpriseClientID("clientID2"), | ||||
| 											idp.ChangeGitHubEnterpriseClientSecret(&crypto.CryptoValue{ | ||||
| 												CryptoType: crypto.TypeEncryption, | ||||
| 												Algorithm:  "enc", | ||||
| 												KeyID:      "id", | ||||
| 												Crypted:    []byte("newSecret"), | ||||
| 											}), | ||||
| 											idp.ChangeGitHubEnterpriseAuthorizationEndpoint("new auth"), | ||||
| 											idp.ChangeGitHubEnterpriseTokenEndpoint("new token"), | ||||
| 											idp.ChangeGitHubEnterpriseUserEndpoint("new user"), | ||||
| 											idp.ChangeGitHubEnterpriseScopes([]string{"openid", "profile"}), | ||||
| 											idp.ChangeGitHubEnterpriseOptions(idp.OptionChanges{ | ||||
| 												IsCreationAllowed: &t, | ||||
| 												IsLinkingAllowed:  &t, | ||||
| 												IsAutoCreation:    &t, | ||||
| 												IsAutoUpdate:      &t, | ||||
| 											}), | ||||
| 										}, | ||||
| 									) | ||||
| 									return event | ||||
| 								}(), | ||||
| 							), | ||||
| 						}, | ||||
| 					), | ||||
| 				), | ||||
| 				secretCrypto: crypto.CreateMockEncryptionAlg(gomock.NewController(t)), | ||||
| 			}, | ||||
| 			args: args{ | ||||
| 				ctx: authz.WithInstanceID(context.Background(), "instance1"), | ||||
| 				id:  "id1", | ||||
| 				provider: GitHubEnterpriseProvider{ | ||||
| 					Name:                  "new name", | ||||
| 					ClientID:              "clientID2", | ||||
| 					ClientSecret:          "newSecret", | ||||
| 					AuthorizationEndpoint: "new auth", | ||||
| 					TokenEndpoint:         "new token", | ||||
| 					UserEndpoint:          "new user", | ||||
| 					Scopes:                []string{"openid", "profile"}, | ||||
| 					IDPOptions: idp.Options{ | ||||
| 						IsCreationAllowed: true, | ||||
| 						IsLinkingAllowed:  true, | ||||
| 						IsAutoCreation:    true, | ||||
| 						IsAutoUpdate:      true, | ||||
| 					}, | ||||
| 				}, | ||||
| 			}, | ||||
| 			res: res{ | ||||
| 				want: &domain.ObjectDetails{ResourceOwner: "instance1"}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	} | ||||
| 	for _, tt := range tests { | ||||
| 		t.Run(tt.name, func(t *testing.T) { | ||||
| 			c := &Commands{ | ||||
| 				eventstore:          tt.fields.eventstore, | ||||
| 				idpConfigEncryption: tt.fields.secretCrypto, | ||||
| 			} | ||||
| 			got, err := c.UpdateInstanceGitHubEnterpriseProvider(tt.args.ctx, tt.args.id, tt.args.provider) | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.NoError(t, err) | ||||
| 			} | ||||
| 			if tt.res.err != nil && !tt.res.err(err) { | ||||
| 				t.Errorf("got wrong err: %v ", err) | ||||
| 			} | ||||
| 			if tt.res.err == nil { | ||||
| 				assert.Equal(t, tt.res.want, got) | ||||
| 			} | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestCommandSide_AddInstanceGoogleIDP(t *testing.T) { | ||||
| 	type fields struct { | ||||
| 		eventstore   *eventstore.Eventstore | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Livio Spring
					Livio Spring