diff --git a/src/main/java/org/tkit/onecx/iam/kc/client/operator/models/ClientRepresentationMapper.java b/src/main/java/org/tkit/onecx/iam/kc/client/operator/models/ClientRepresentationMapper.java new file mode 100644 index 0000000..1c55ca4 --- /dev/null +++ b/src/main/java/org/tkit/onecx/iam/kc/client/operator/models/ClientRepresentationMapper.java @@ -0,0 +1,10 @@ +package org.tkit.onecx.iam.kc.client.operator.models; + +import org.keycloak.representations.idm.ClientRepresentation; +import org.mapstruct.Mapper; + +@Mapper +public interface ClientRepresentationMapper { + + ExtClientRepresentation create(ClientRepresentation data); +} diff --git a/src/main/java/org/tkit/onecx/iam/kc/client/operator/models/ExtClientRepresentation.java b/src/main/java/org/tkit/onecx/iam/kc/client/operator/models/ExtClientRepresentation.java new file mode 100644 index 0000000..7972d56 --- /dev/null +++ b/src/main/java/org/tkit/onecx/iam/kc/client/operator/models/ExtClientRepresentation.java @@ -0,0 +1,10 @@ +package org.tkit.onecx.iam.kc.client.operator.models; + +import org.keycloak.representations.idm.ClientRepresentation; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; + +@JsonIgnoreProperties({ "type" }) +public class ExtClientRepresentation extends ClientRepresentation { + +} diff --git a/src/main/java/org/tkit/onecx/iam/kc/client/operator/service/KeycloakAdminService.java b/src/main/java/org/tkit/onecx/iam/kc/client/operator/service/KeycloakAdminService.java index 34629bd..1a7d6be 100644 --- a/src/main/java/org/tkit/onecx/iam/kc/client/operator/service/KeycloakAdminService.java +++ b/src/main/java/org/tkit/onecx/iam/kc/client/operator/service/KeycloakAdminService.java @@ -18,6 +18,7 @@ import org.tkit.onecx.iam.kc.client.operator.KeycloakClient; import org.tkit.onecx.iam.kc.client.operator.config.KCClientConfig; import org.tkit.onecx.iam.kc.client.operator.config.KCDefaultConfig; +import org.tkit.onecx.iam.kc.client.operator.models.ClientRepresentationMapper; @ApplicationScoped public class KeycloakAdminService { @@ -35,6 +36,9 @@ public class KeycloakAdminService { @Inject KCClientConfig kcClientConfig; + @Inject + ClientRepresentationMapper mapper; + @ActivateRequestContext public CreateClientResponse createClient(KeycloakClient keycloakClient) { var spec = keycloakClient.getSpec(); @@ -72,7 +76,8 @@ public CreateClientResponse createClient(KeycloakClient keycloakClient) { if (clients.isEmpty()) { // do create - try (var resp = keycloak.realm(realm).clients().create(client)) { + var extClient = mapper.create(client); + try (var resp = keycloak.realm(realm).clients().create(extClient)) { return CreateClientResponse.of(resp.getStatus(), resp.readEntity(String.class)); } } else { @@ -80,7 +85,8 @@ public CreateClientResponse createClient(KeycloakClient keycloakClient) { var defaultClientScopeNames = client.getDefaultClientScopes(); var optionalClientScopeNames = client.getOptionalClientScopes(); var clientToUpdate = keycloak.realm(realm).clients().get(clients.get(0).getId()); - clientToUpdate.update(client); + var extClient = mapper.create(client); + clientToUpdate.update(extClient); // update default client scopes var toRemove = clientToUpdate.getDefaultClientScopes().stream() .filter(rep -> !defaultClientScopeNames.contains(rep.getName())).map(ClientScopeRepresentation::getId)