From fc0f2e5c8e67b0ce1e3ce017bc5bca1d66bd1769 Mon Sep 17 00:00:00 2001 From: barreiro Date: Wed, 7 Feb 2024 02:16:01 +0000 Subject: [PATCH] Fix devservices with DB backup --- .../src/main/resources/application.properties | 4 +-- .../infra/common/HorreumResources.java | 28 +++++++++++-------- .../common/resources/KeycloakResource.java | 7 ++--- 3 files changed, 20 insertions(+), 19 deletions(-) diff --git a/horreum-backend/src/main/resources/application.properties b/horreum-backend/src/main/resources/application.properties index b0fb8c7f3..08d187aad 100644 --- a/horreum-backend/src/main/resources/application.properties +++ b/horreum-backend/src/main/resources/application.properties @@ -100,8 +100,8 @@ quarkus.keycloak.admin-client.grant-type=CLIENT_CREDENTIALS %dev.quarkus.keycloak.admin-client.client-id=admin-cli %dev.quarkus.keycloak.admin-client.realm=master %dev.quarkus.keycloak.admin-client.grant-type=PASSWORD -%dev.quarkus.keycloak.admin-client.username=admin -%dev.quarkus.keycloak.admin-client.password=secret +%dev.quarkus.keycloak.admin-client.username=${horreum.dev-services.keycloak.admin-username} +%dev.quarkus.keycloak.admin-client.password=${horreum.dev-services.keycloak.admin-password} # Secret used to sign database rows horreum.db.secret=secret diff --git a/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/HorreumResources.java b/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/HorreumResources.java index ac99bad1d..063e77de6 100644 --- a/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/HorreumResources.java +++ b/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/HorreumResources.java @@ -163,19 +163,23 @@ public static Map startContainers(Map initArgs) envVariables.put("quarkus.oidc.auth-server-url", keycloakEnv.get("keycloak.host").concat("/realms/").concat(HORREUM_REALM)); envVariables.putAll(oidcTruststoreProperties(initArgs)); - String keycloakAdminUser = initArgs.get(HORREUM_DEV_KEYCLOAK_ADMIN_USERNAME); - String keycloakAdminPassword = initArgs.get(HORREUM_DEV_KEYCLOAK_ADMIN_PASSWORD); - - keycloak = KeycloakBuilder.builder() - .serverUrl(keycloakEnv.get("keycloak.host")) - .realm(KEYCLOAK_REALM) - .username(keycloakAdminUser) - .password(keycloakAdminPassword) - .clientId("admin-cli") - .resteasyClient(((ResteasyClientBuilder) ClientBuilder.newBuilder()).disableTrustManager().build()) - .build(); - if (!initArgs.containsKey(HORREUM_DEV_POSTGRES_BACKUP)) { + + String keycloakAdminUser = initArgs.get(HORREUM_DEV_KEYCLOAK_ADMIN_USERNAME); + String keycloakAdminPassword = initArgs.get(HORREUM_DEV_KEYCLOAK_ADMIN_PASSWORD); + + envVariables.put(HORREUM_DEV_KEYCLOAK_ADMIN_USERNAME, keycloakAdminUser); + envVariables.put(HORREUM_DEV_KEYCLOAK_ADMIN_PASSWORD, keycloakAdminPassword); + + keycloak = KeycloakBuilder.builder() + .serverUrl(keycloakEnv.get("keycloak.host")) + .realm(KEYCLOAK_REALM) + .username(keycloakAdminUser) + .password(keycloakAdminPassword) + .clientId("admin-cli") + .resteasyClient(((ResteasyClientBuilder) ClientBuilder.newBuilder()).disableTrustManager().build()) + .build(); + // Not using a backup db, so need to create the dummy roles // Obtain client secrets for Horreum diff --git a/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/resources/KeycloakResource.java b/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/resources/KeycloakResource.java index 692312da3..52f3e0974 100644 --- a/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/resources/KeycloakResource.java +++ b/infra/horreum-infra-common/src/main/java/io/hyperfoil/tools/horreum/infra/common/resources/KeycloakResource.java @@ -39,9 +39,6 @@ public void init(Map initArgs) { throw new RuntimeException("Arguments did not contain Keycloak image"); } - final String JDBC_URL = initArgs.get("quarkus.datasource.jdbc.url.internal"); - final String DB_PORT = initArgs.get("postgres.container.port"); - final String KEYCLOAK_IMAGE = initArgs.get(HORREUM_DEV_KEYCLOAK_IMAGE); networkAlias = initArgs.get(HORREUM_DEV_KEYCLOAK_NETWORK_ALIAS); @@ -73,7 +70,7 @@ public void init(Map initArgs) { .env("KC_HTTP_ENABLED", "true") .env("KC_HOSTNAME_STRICT", "false") .env("DB_DATABASE", "keycloak") - .env("KC_DB_URL", JDBC_URL) + .env("KC_DB_URL", initArgs.get("quarkus.datasource.jdbc.url.internal")) .run("/opt/keycloak/bin/kc.sh build") .entryPoint("/opt/keycloak/bin/kc.sh ${KEYCLOAK_COMMAND:-start-dev} --import-realm $EXTRA_OPTIONS") .build()).withFileFromFile("/tmp/keycloak-horreum.json", tempKeycloakRealmFile); @@ -100,7 +97,7 @@ public void init(Map initArgs) { .withEnv("KC_DB_URL_HOST", "") .withEnv("KC_HOSTNAME_STRICT", "false") .withEnv("KC_HOSTNAME", "localhost") - .withEnv("KC_DB_URL", "jdbc:postgresql://172.17.0.1:" + DB_PORT + "/keycloak") + .withEnv("KC_DB_URL", "jdbc:postgresql://" + initArgs.get(HORREUM_DEV_POSTGRES_NETWORK_ALIAS) + ":5432/keycloak") .withCommand("-Dquarkus.http.http2=false", "start-dev"); }