From 107c93d858f82332bea01167cc6ac5d3085033e0 Mon Sep 17 00:00:00 2001 From: Andrej Petras Date: Tue, 8 Oct 2024 17:18:57 +0200 Subject: [PATCH] feat: add leader election configuration --- .../pages/index.adoc | 2 ++ .../onecx-product-store-operator-docs.adoc | 10 ------ ...ecx-product-store-operator-extensions.adoc | 36 +++++++++---------- .../pages/onecx-product-store-operator.adoc | 31 ++++++++++++++++ src/main/helm/templates/role.yaml | 11 +++++- .../store/operator/LeaderConfiguration.java | 13 +++++++ .../store/operator/OperatorConfig.java | 35 ++++++++++++++++++ .../operator/LeaderConfigurationTest.java | 28 +++++++++++++++ 8 files changed, 137 insertions(+), 29 deletions(-) create mode 100644 docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator.adoc create mode 100644 src/main/java/org/tkit/onecx/product/store/operator/LeaderConfiguration.java create mode 100644 src/main/java/org/tkit/onecx/product/store/operator/OperatorConfig.java create mode 100644 src/test/java/org/tkit/onecx/product/store/operator/LeaderConfigurationTest.java diff --git a/docs/modules/onecx-product-store-operator/pages/index.adoc b/docs/modules/onecx-product-store-operator/pages/index.adoc index bafda01..019335f 100644 --- a/docs/modules/onecx-product-store-operator/pages/index.adoc +++ b/docs/modules/onecx-product-store-operator/pages/index.adoc @@ -4,5 +4,7 @@ include::onecx-product-store-operator-attributes.adoc[opts=optional] include::docs.adoc[opts=optional] +=== Configuration +include::onecx-product-store-operator.adoc[opts=optional] include::onecx-product-store-operator-docs.adoc[opts=optional] diff --git a/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-docs.adoc b/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-docs.adoc index 6837fc3..4a0d92c 100644 --- a/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-docs.adoc +++ b/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-docs.adoc @@ -61,13 +61,3 @@ app: ---- - enabled: true - spec: - kcConfig: - defaultClientScopes: [ ocx-ps-product:write ] - -# Values: JOSDK_WATCH_CURRENT, JOSDK_ALL_NAMESPACES or comma separated list of namespaces -watchNamespaces: "JOSDK_WATCH_CURRENT" - ----- - diff --git a/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-extensions.adoc b/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-extensions.adoc index 4c5b781..c214080 100644 --- a/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-extensions.adoc +++ b/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator-extensions.adoc @@ -11,38 +11,38 @@ h| Version | tkit-quarkus-log-cdi | https://1000kit.github.io/tkit-quarkus/current/tkit-quarkus/tkit-quarkus-log-cdi.html[Link] -| https://github.com/1000kit/tkit-quarkus/blob/2.31.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-log-cdi.adoc[Link] -| 2.31.0 +| https://github.com/1000kit/tkit-quarkus/blob/2.33.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-log-cdi.adoc[Link] +| 2.33.0 | tkit-quarkus-log-rs | https://1000kit.github.io/tkit-quarkus/current/tkit-quarkus/tkit-quarkus-log-rs.html[Link] -| https://github.com/1000kit/tkit-quarkus/blob/2.31.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-log-rs.adoc[Link] -| 2.31.0 +| https://github.com/1000kit/tkit-quarkus/blob/2.33.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-log-rs.adoc[Link] +| 2.33.0 | tkit-quarkus-log-json | https://1000kit.github.io/tkit-quarkus/current/tkit-quarkus/tkit-quarkus-log-json.html[Link] -| https://github.com/1000kit/tkit-quarkus/blob/2.31.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-log-json.adoc[Link] -| 2.31.0 +| https://github.com/1000kit/tkit-quarkus/blob/2.33.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-log-json.adoc[Link] +| 2.33.0 | quarkus-arc | https://quarkus.io/guides/cdi-reference[Link] | https://github.com/quarkusio/quarkusio.github.io/blob/develop/_generated-doc/latest/config/quarkus-arc.adoc[Link] -| 3.13.2 +| 3.15.1 | quarkus-micrometer-registry-prometheus | https://quarkus.io/guides/telemetry-micrometer[Link] | https://github.com/quarkusio/quarkusio.github.io/blob/develop/_generated-doc/latest/config/quarkus-micrometer-registry-prometheus.adoc[Link] -| 3.13.2 +| 3.15.1 | quarkus-opentelemetry | https://quarkus.io/guides/opentelemetry[Link] | https://github.com/quarkusio/quarkusio.github.io/blob/develop/_generated-doc/latest/config/quarkus-opentelemetry.adoc[Link] -| 3.13.2 +| 3.15.1 | quarkus-openapi-generator @@ -54,37 +54,37 @@ h| Version | https://quarkus.io/guides/rest-client[Link] | https://github.com/quarkusio/quarkusio.github.io/blob/develop/_generated-doc/latest/config/quarkus-rest-client.adoc[Link] -| 3.13.2 +| 3.15.1 | quarkus-rest-client-jackson | https://quarkus.io/guides/rest-client[Link] | -| 3.13.2 +| 3.15.1 | tkit-quarkus-security | https://1000kit.github.io/tkit-quarkus/current/tkit-quarkus/tkit-quarkus-security.html[Link] -| https://github.com/1000kit/tkit-quarkus/blob/2.31.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-security.adoc[Link] -| 2.31.0 +| https://github.com/1000kit/tkit-quarkus/blob/2.33.0/docs/modules/tkit-quarkus/pages/includes/tkit-quarkus-security.adoc[Link] +| 2.33.0 | onecx-core | https://onecx.github.io/docs/onecx-quarkus/current/onecx-quarkus/onecx-core.html[Link] | -| 0.26.0 +| 0.31.0 | quarkus-smallrye-health | https://quarkus.io/guides/smallrye-health[Link] | https://github.com/quarkusio/quarkusio.github.io/blob/develop/_generated-doc/latest/config/quarkus-smallrye-health.adoc[Link] -| 3.13.2 +| 3.15.1 | quarkus-container-image-docker | https://quarkus.io/guides/container-image[Link] | https://github.com/quarkusio/quarkusio.github.io/blob/develop/_generated-doc/latest/config/quarkus-container-image-docker.adoc[Link] -| 3.13.2 +| 3.15.1 | quarkus-operator-sdk-bundle-generator @@ -103,13 +103,13 @@ h| Version | | -| 3.13.2 +| 3.15.1 | quarkus-rest-client-oidc-filter | | -| 3.13.2 +| 3.15.1 |=== \ No newline at end of file diff --git a/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator.adoc b/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator.adoc new file mode 100644 index 0000000..6b5e8d1 --- /dev/null +++ b/docs/modules/onecx-product-store-operator/pages/onecx-product-store-operator.adoc @@ -0,0 +1,31 @@ +:summaryTableId: onecx-product-store-operator +[.configuration-legend] +icon:lock[title=Fixed at build time] Configuration property fixed at build time - All other configuration properties are overridable at runtime +[.configuration-reference.searchable, cols="80,.^10,.^10"] +|=== + +h|[.header-title]##Configuration property## +h|Type +h|Default + +a| [[onecx-product-store-operator_onecx-product-store-operator-leader-election-lease-name]] [.property-path]##link:#onecx-product-store-operator_onecx-product-store-operator-leader-election-lease-name[`onecx.product-store.operator.leader-election.lease-name`]## + +[.description] +-- +Lease name + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++ONECX_PRODUCT_STORE_OPERATOR_LEADER_ELECTION_LEASE_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++ONECX_PRODUCT_STORE_OPERATOR_LEADER_ELECTION_LEASE_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +|`onecx-product-store-operator-lease` + +|=== + + +:!summaryTableId: \ No newline at end of file diff --git a/src/main/helm/templates/role.yaml b/src/main/helm/templates/role.yaml index 51b69ec..2145ec9 100644 --- a/src/main/helm/templates/role.yaml +++ b/src/main/helm/templates/role.yaml @@ -16,4 +16,13 @@ rules: - patch - update - create - - delete \ No newline at end of file + - delete + - verbs: + - "get" + - "update" + - "create" + - "patch" + apiGroups: + - "coordination.k8s.io" + resources: + - "leases" \ No newline at end of file diff --git a/src/main/java/org/tkit/onecx/product/store/operator/LeaderConfiguration.java b/src/main/java/org/tkit/onecx/product/store/operator/LeaderConfiguration.java new file mode 100644 index 0000000..1299fa5 --- /dev/null +++ b/src/main/java/org/tkit/onecx/product/store/operator/LeaderConfiguration.java @@ -0,0 +1,13 @@ +package org.tkit.onecx.product.store.operator; + +import jakarta.inject.Singleton; + +import io.javaoperatorsdk.operator.api.config.LeaderElectionConfiguration; + +@Singleton +public class LeaderConfiguration extends LeaderElectionConfiguration { + + public LeaderConfiguration(OperatorConfig config) { + super(config.leaderElectionConfig().leaseName()); + } +} diff --git a/src/main/java/org/tkit/onecx/product/store/operator/OperatorConfig.java b/src/main/java/org/tkit/onecx/product/store/operator/OperatorConfig.java new file mode 100644 index 0000000..f49c663 --- /dev/null +++ b/src/main/java/org/tkit/onecx/product/store/operator/OperatorConfig.java @@ -0,0 +1,35 @@ +package org.tkit.onecx.product.store.operator; + +import io.quarkus.runtime.annotations.ConfigDocFilename; +import io.quarkus.runtime.annotations.ConfigPhase; +import io.quarkus.runtime.annotations.ConfigRoot; +import io.quarkus.runtime.annotations.StaticInitSafe; +import io.smallrye.config.ConfigMapping; +import io.smallrye.config.WithDefault; +import io.smallrye.config.WithName; + +@StaticInitSafe +@ConfigDocFilename("onecx-product-store-operator.adoc") +@ConfigMapping(prefix = "onecx.product-store.operator") +@ConfigRoot(phase = ConfigPhase.RUN_TIME) +public interface OperatorConfig { + + /** + * Leader election configuration + */ + @WithName("leader-election") + LeaderElectionConfig leaderElectionConfig(); + + /** + * Leader election config + */ + interface LeaderElectionConfig { + + /** + * Lease name + */ + @WithName("lease-name") + @WithDefault("onecx-product-store-operator-lease") + String leaseName(); + } +} diff --git a/src/test/java/org/tkit/onecx/product/store/operator/LeaderConfigurationTest.java b/src/test/java/org/tkit/onecx/product/store/operator/LeaderConfigurationTest.java new file mode 100644 index 0000000..d5c261d --- /dev/null +++ b/src/test/java/org/tkit/onecx/product/store/operator/LeaderConfigurationTest.java @@ -0,0 +1,28 @@ +package org.tkit.onecx.product.store.operator; + +import static org.assertj.core.api.Assertions.assertThat; + +import jakarta.inject.Inject; + +import org.junit.jupiter.api.Test; +import org.tkit.onecx.product.store.test.AbstractTest; + +import io.quarkus.test.junit.QuarkusTest; + +@QuarkusTest +class LeaderConfigurationTest extends AbstractTest { + + @Inject + OperatorConfig dataConfig; + + @Inject + LeaderConfiguration leaderConfiguration; + + @Test + void testLeaderConfiguration() { + assertThat(dataConfig).isNotNull(); + assertThat(dataConfig.leaderElectionConfig()).isNotNull(); + assertThat(leaderConfiguration).isNotNull(); + assertThat(leaderConfiguration.getLeaseName()).isNotNull().isEqualTo(dataConfig.leaderElectionConfig().leaseName()); + } +}