From 59456bbab3fbf3236a7c75611a2cc20719c1b3bb Mon Sep 17 00:00:00 2001 From: Erik Mattheis <erikmattheis@me.com> Date: Wed, 13 Nov 2024 14:07:56 -0500 Subject: [PATCH] feat: add acm extension (#1476) * add new extension for ACM * add documentation for ACM extension * add ACM to list of services in README * use requestCertificate to simplify tests and examples --- README.md | 1 + acm/deployment/pom.xml | 87 + .../amazon/acm/deployment/AcmProcessor.java | 210 ++ .../AcmSyncClientFullConfigTest.java | 29 + .../sync-urlconn-full-config.properties | 10 + acm/pom.xml | 21 + acm/runtime/pom.xml | 99 + .../acm/runtime/AcmBuildTimeConfig.java | 32 + .../amazon/acm/runtime/AcmConfig.java | 25 + .../amazon/acm/runtime/AcmRecorder.java | 47 + .../resources/META-INF/quarkus-extension.yaml | 14 + bom/pom.xml | 15 + devservices/acm/pom.xml | 39 + .../acm/AcmDevServicesProcessor.java | 16 + devservices/pom.xml | 1 + docs/modules/ROOT/nav.adoc | 3 +- docs/modules/ROOT/pages/amazon-acm.adoc | 260 +++ .../pages/includes/quarkus-amazon-acm.adoc | 1748 +++++++++++++++++ .../quarkus-amazon-acm_quarkus.acm.adoc | 1748 +++++++++++++++++ integration-tests/pom.xml | 4 + .../it/amazon/acm/AcmResource.java | 60 + .../src/main/resources/application.properties | 2 + .../it/amazon/AmazonAcmITCase.java | 8 + .../quarkiverse/it/amazon/AmazonAcmTest.java | 21 + pom.xml | 1 + 25 files changed, 4500 insertions(+), 1 deletion(-) create mode 100644 acm/deployment/pom.xml create mode 100644 acm/deployment/src/main/java/io/quarkiverse/amazon/acm/deployment/AcmProcessor.java create mode 100644 acm/deployment/src/test/java/io/quarkiverse/amazon/acm/deployment/AcmSyncClientFullConfigTest.java create mode 100644 acm/deployment/src/test/resources/sync-urlconn-full-config.properties create mode 100644 acm/pom.xml create mode 100644 acm/runtime/pom.xml create mode 100644 acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmBuildTimeConfig.java create mode 100644 acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmConfig.java create mode 100644 acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmRecorder.java create mode 100644 acm/runtime/src/main/resources/META-INF/quarkus-extension.yaml create mode 100644 devservices/acm/pom.xml create mode 100644 devservices/acm/src/main/java/io/quarkiverse/amazon/devservices/acm/AcmDevServicesProcessor.java create mode 100644 docs/modules/ROOT/pages/amazon-acm.adoc create mode 100644 docs/modules/ROOT/pages/includes/quarkus-amazon-acm.adoc create mode 100644 docs/modules/ROOT/pages/includes/quarkus-amazon-acm_quarkus.acm.adoc create mode 100644 integration-tests/src/main/java/io/quarkiverse/it/amazon/acm/AcmResource.java create mode 100644 integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmITCase.java create mode 100644 integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmTest.java diff --git a/README.md b/README.md index ceea9d0ee..e2ba6d6be 100644 --- a/README.md +++ b/README.md @@ -9,6 +9,7 @@ This set of extensions allows you to interact with some of the AWS Services namely: + * ACM * Api Gateway Management Api * CloudWatch * CloudWatch Logs diff --git a/acm/deployment/pom.xml b/acm/deployment/pom.xml new file mode 100644 index 000000000..5c47f2ea3 --- /dev/null +++ b/acm/deployment/pom.xml @@ -0,0 +1,87 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + + <parent> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm-parent</artifactId> + <version>999-SNAPSHOT</version> + </parent> + + <artifactId>quarkus-amazon-acm-deployment</artifactId> + <name>Quarkus - Amazon Services - ACM - Deployment</name> + + <dependencies> + <dependency> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-core-deployment</artifactId> + </dependency> + <dependency> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-arc-deployment</artifactId> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-common-deployment</artifactId> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm</artifactId> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-devservices-acm</artifactId> + </dependency> + + <!-- Test dependencies --> + <dependency> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-junit5-internal</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>io.rest-assured</groupId> + <artifactId>rest-assured</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>netty-nio-client</artifactId> + <scope>test</scope> + </dependency> + <!-- Imported manually because conditional dependencies + are not automatically added to test scope --> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-netty-client-internal-deployment</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>aws-crt-client</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>url-connection-client</artifactId> + <scope>test</scope> + </dependency> + </dependencies> + + <build> + <plugins> + <plugin> + <artifactId>maven-compiler-plugin</artifactId> + <configuration> + <annotationProcessorPaths> + <path> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-extension-processor</artifactId> + <version>${quarkus.version}</version> + </path> + </annotationProcessorPaths> + </configuration> + </plugin> + </plugins> + </build> +</project> diff --git a/acm/deployment/src/main/java/io/quarkiverse/amazon/acm/deployment/AcmProcessor.java b/acm/deployment/src/main/java/io/quarkiverse/amazon/acm/deployment/AcmProcessor.java new file mode 100644 index 000000000..9b450030d --- /dev/null +++ b/acm/deployment/src/main/java/io/quarkiverse/amazon/acm/deployment/AcmProcessor.java @@ -0,0 +1,210 @@ +package io.quarkiverse.amazon.acm.deployment; + +import java.util.List; + +import org.jboss.jandex.DotName; + +import io.quarkiverse.amazon.acm.runtime.AcmBuildTimeConfig; +import io.quarkiverse.amazon.acm.runtime.AcmRecorder; +import io.quarkiverse.amazon.common.deployment.AbstractAmazonServiceProcessor; +import io.quarkiverse.amazon.common.deployment.AmazonClientAsyncResultBuildItem; +import io.quarkiverse.amazon.common.deployment.AmazonClientAsyncTransportBuildItem; +import io.quarkiverse.amazon.common.deployment.AmazonClientInterceptorsPathBuildItem; +import io.quarkiverse.amazon.common.deployment.AmazonClientSyncResultBuildItem; +import io.quarkiverse.amazon.common.deployment.AmazonClientSyncTransportBuildItem; +import io.quarkiverse.amazon.common.deployment.AmazonHttpClients; +import io.quarkiverse.amazon.common.deployment.RequireAmazonClientBuildItem; +import io.quarkiverse.amazon.common.deployment.RequireAmazonClientInjectionBuildItem; +import io.quarkiverse.amazon.common.deployment.RequireAmazonClientTransportBuilderBuildItem; +import io.quarkiverse.amazon.common.deployment.RequireAmazonTelemetryBuildItem; +import io.quarkiverse.amazon.common.deployment.spi.EventLoopGroupBuildItem; +import io.quarkiverse.amazon.common.runtime.AmazonClientApacheTransportRecorder; +import io.quarkiverse.amazon.common.runtime.AmazonClientAwsCrtTransportRecorder; +import io.quarkiverse.amazon.common.runtime.AmazonClientCommonRecorder; +import io.quarkiverse.amazon.common.runtime.AmazonClientNettyTransportRecorder; +import io.quarkiverse.amazon.common.runtime.AmazonClientOpenTelemetryRecorder; +import io.quarkiverse.amazon.common.runtime.AmazonClientUrlConnectionTransportRecorder; +import io.quarkus.arc.deployment.BeanRegistrationPhaseBuildItem; +import io.quarkus.arc.deployment.SyntheticBeanBuildItem; +import io.quarkus.deployment.annotations.BuildProducer; +import io.quarkus.deployment.annotations.BuildStep; +import io.quarkus.deployment.annotations.ExecutionTime; +import io.quarkus.deployment.annotations.Record; +import io.quarkus.deployment.builditem.ExecutorBuildItem; +import io.quarkus.deployment.builditem.ExtensionSslNativeSupportBuildItem; +import io.quarkus.deployment.builditem.FeatureBuildItem; +import io.quarkus.deployment.builditem.LaunchModeBuildItem; +import software.amazon.awssdk.services.acm.AcmAsyncClient; +import software.amazon.awssdk.services.acm.AcmAsyncClientBuilder; +import software.amazon.awssdk.services.acm.AcmClient; +import software.amazon.awssdk.services.acm.AcmClientBuilder; + +public class AcmProcessor extends AbstractAmazonServiceProcessor { + + private static final String AMAZON_CLIENT_NAME = "amazon-sdk-acm"; + + AcmBuildTimeConfig buildTimeConfig; + + @Override + protected String amazonServiceClientName() { + return AMAZON_CLIENT_NAME; + } + + @Override + protected String configName() { + return "acm"; + } + + @Override + protected DotName syncClientName() { + return DotName.createSimple(AcmClient.class.getName()); + } + + @Override + protected DotName asyncClientName() { + return DotName.createSimple(AcmAsyncClient.class.getName()); + } + + @Override + protected String builtinInterceptorsPath() { + return "software/amazon/awssdk/services/acm/execution.interceptors"; + } + + @BuildStep + void setup( + BuildProducer<ExtensionSslNativeSupportBuildItem> extensionSslNativeSupport, + BuildProducer<FeatureBuildItem> feature, + BuildProducer<AmazonClientInterceptorsPathBuildItem> interceptors) { + + setupExtension(extensionSslNativeSupport, feature, interceptors); + } + + @BuildStep + void discoverClientInjectionPoints(BeanRegistrationPhaseBuildItem beanRegistrationPhase, + BuildProducer<RequireAmazonClientInjectionBuildItem> requireClientInjectionProducer) { + + discoverClientInjectionPointsInternal(beanRegistrationPhase, requireClientInjectionProducer); + } + + @BuildStep + void discover( + List<RequireAmazonClientInjectionBuildItem> amazonClientInjectionPoints, + BuildProducer<RequireAmazonClientBuildItem> requireClientProducer) { + + discoverClient(amazonClientInjectionPoints, requireClientProducer); + } + + @BuildStep + void discoverTelemetry(BuildProducer<RequireAmazonTelemetryBuildItem> telemetryProducer) { + + discoverTelemetry(telemetryProducer, buildTimeConfig.sdk()); + } + + @BuildStep + void setupClient(List<RequireAmazonClientBuildItem> clientRequirements, + BuildProducer<RequireAmazonClientTransportBuilderBuildItem> clientProducer) { + + setupClient(clientRequirements, clientProducer, buildTimeConfig.sdk(), buildTimeConfig.syncClient(), + buildTimeConfig.asyncClient()); + } + + @BuildStep(onlyIf = AmazonHttpClients.IsAmazonApacheHttpServicePresent.class) + @Record(ExecutionTime.RUNTIME_INIT) + void setupApacheSyncTransport(List<RequireAmazonClientTransportBuilderBuildItem> amazonClients, AcmRecorder recorder, + AmazonClientApacheTransportRecorder transportRecorder, + BuildProducer<AmazonClientSyncTransportBuildItem> syncTransports) { + + createApacheSyncTransportBuilder(amazonClients, + transportRecorder, + buildTimeConfig.syncClient(), + recorder.getSyncConfig(), + syncTransports); + } + + @BuildStep(onlyIf = AmazonHttpClients.IsAmazonAwsCrtHttpServicePresent.class) + @Record(ExecutionTime.RUNTIME_INIT) + void setupAwsCrtSyncTransport(List<RequireAmazonClientTransportBuilderBuildItem> amazonClients, AcmRecorder recorder, + AmazonClientAwsCrtTransportRecorder transportRecorder, + BuildProducer<AmazonClientSyncTransportBuildItem> syncTransports) { + + createAwsCrtSyncTransportBuilder(amazonClients, + transportRecorder, + buildTimeConfig.syncClient(), + recorder.getSyncConfig(), + syncTransports); + } + + @BuildStep(onlyIf = AmazonHttpClients.IsAmazonUrlConnectionHttpServicePresent.class) + @Record(ExecutionTime.RUNTIME_INIT) + void setupUrlConnectionSyncTransport(List<RequireAmazonClientTransportBuilderBuildItem> amazonClients, AcmRecorder recorder, + AmazonClientUrlConnectionTransportRecorder transportRecorder, + BuildProducer<AmazonClientSyncTransportBuildItem> syncTransports) { + + createUrlConnectionSyncTransportBuilder(amazonClients, + transportRecorder, + buildTimeConfig.syncClient(), + recorder.getSyncConfig(), + syncTransports); + } + + @BuildStep(onlyIf = AmazonHttpClients.IsAmazonNettyHttpServicePresent.class) + @Record(ExecutionTime.RUNTIME_INIT) + void setupNettyAsyncTransport(List<RequireAmazonClientTransportBuilderBuildItem> amazonClients, AcmRecorder recorder, + AmazonClientNettyTransportRecorder transportRecorder, + BuildProducer<AmazonClientAsyncTransportBuildItem> asyncTransports, + EventLoopGroupBuildItem eventLoopSupplier) { + + createNettyAsyncTransportBuilder(amazonClients, + transportRecorder, + buildTimeConfig.asyncClient(), + recorder.getAsyncConfig(), + asyncTransports, eventLoopSupplier.getMainEventLoopGroup()); + } + + @BuildStep(onlyIf = AmazonHttpClients.IsAmazonAwsCrtHttpServicePresent.class) + @Record(ExecutionTime.RUNTIME_INIT) + void setupAwsCrtAsyncTransport(List<RequireAmazonClientTransportBuilderBuildItem> amazonClients, AcmRecorder recorder, + AmazonClientAwsCrtTransportRecorder transportRecorder, + BuildProducer<AmazonClientAsyncTransportBuildItem> asyncTransports) { + + createAwsCrtAsyncTransportBuilder(amazonClients, + transportRecorder, + buildTimeConfig.asyncClient(), + recorder.getAsyncConfig(), + asyncTransports); + } + + @BuildStep + @Record(ExecutionTime.RUNTIME_INIT) + void createClientBuilders(AcmRecorder recorder, + AmazonClientCommonRecorder commonRecorder, + AmazonClientOpenTelemetryRecorder otelRecorder, + List<RequireAmazonClientInjectionBuildItem> amazonClientInjections, + List<RequireAmazonTelemetryBuildItem> amazonRequireTelemtryClients, + List<AmazonClientSyncTransportBuildItem> syncTransports, + List<AmazonClientAsyncTransportBuildItem> asyncTransports, + BuildProducer<SyntheticBeanBuildItem> syntheticBeans, + BuildProducer<AmazonClientSyncResultBuildItem> clientSync, + BuildProducer<AmazonClientAsyncResultBuildItem> clientAsync, + LaunchModeBuildItem launchModeBuildItem, + ExecutorBuildItem executorBuildItem) { + + createClientBuilders( + recorder, + commonRecorder, + otelRecorder, + buildTimeConfig, + amazonClientInjections, + amazonRequireTelemtryClients, + syncTransports, + asyncTransports, + AcmClientBuilder.class, + AcmAsyncClientBuilder.class, + null, + syntheticBeans, + clientSync, + clientAsync, + launchModeBuildItem, + executorBuildItem); + } +} diff --git a/acm/deployment/src/test/java/io/quarkiverse/amazon/acm/deployment/AcmSyncClientFullConfigTest.java b/acm/deployment/src/test/java/io/quarkiverse/amazon/acm/deployment/AcmSyncClientFullConfigTest.java new file mode 100644 index 000000000..e55e0dae1 --- /dev/null +++ b/acm/deployment/src/test/java/io/quarkiverse/amazon/acm/deployment/AcmSyncClientFullConfigTest.java @@ -0,0 +1,29 @@ +package io.quarkiverse.amazon.acm.deployment; + +import jakarta.inject.Inject; + +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.RegisterExtension; + +import io.quarkus.test.QuarkusUnitTest; +import software.amazon.awssdk.services.acm.AcmAsyncClient; +import software.amazon.awssdk.services.acm.AcmClient; + +public class AcmSyncClientFullConfigTest { + + @Inject + AcmClient client; + + @Inject + AcmAsyncClient async; + + @RegisterExtension + static final QuarkusUnitTest config = new QuarkusUnitTest() + .withApplicationRoot((jar) -> jar + .addAsResource("sync-urlconn-full-config.properties", "application.properties")); + + @Test + public void test() { + // should finish with success + } +} diff --git a/acm/deployment/src/test/resources/sync-urlconn-full-config.properties b/acm/deployment/src/test/resources/sync-urlconn-full-config.properties new file mode 100644 index 000000000..7f095f8a4 --- /dev/null +++ b/acm/deployment/src/test/resources/sync-urlconn-full-config.properties @@ -0,0 +1,10 @@ +quarkus.acm.endpoint-override=http://localhost:9090 + +quarkus.acm.aws.region=us-east-1 +quarkus.acm.aws.credentials.type=static +quarkus.acm.aws.credentials.static-provider.access-key-id=test-key +quarkus.acm.aws.credentials.static-provider.secret-access-key=test-secret + +quarkus.acm.sync-client.type = url +quarkus.acm.sync-client.connection-timeout = 0.100S +quarkus.acm.sync-client.socket-timeout = 0.100S \ No newline at end of file diff --git a/acm/pom.xml b/acm/pom.xml new file mode 100644 index 000000000..49e1e9478 --- /dev/null +++ b/acm/pom.xml @@ -0,0 +1,21 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + + <parent> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-services-build-parent</artifactId> + <version>999-SNAPSHOT</version> + <relativePath>../build-parent/pom.xml</relativePath> + </parent> + + <artifactId>quarkus-amazon-acm-parent</artifactId> + <name>Quarkus - Amazon Services - ACM</name> + <packaging>pom</packaging> + + <modules> + <module>runtime</module> + <module>deployment</module> + </modules> + +</project> diff --git a/acm/runtime/pom.xml b/acm/runtime/pom.xml new file mode 100644 index 000000000..a4c574e8b --- /dev/null +++ b/acm/runtime/pom.xml @@ -0,0 +1,99 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + + <parent> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm-parent</artifactId> + <version>999-SNAPSHOT</version> + </parent> + + <artifactId>quarkus-amazon-acm</artifactId> + <name>Quarkus - Amazon Services - ACM - Runtime</name> + <description>Connect to Amazon ACM</description> + + <dependencies> + <dependency> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-core</artifactId> + </dependency> + <dependency> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-arc</artifactId> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-common</artifactId> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>acm</artifactId> + <exclusions> + <!-- we exclude them here because we want to make them optional --> + <exclusion> + <groupId>software.amazon.awssdk</groupId> + <artifactId>netty-nio-client</artifactId> + </exclusion> + <exclusion> + <groupId>software.amazon.awssdk</groupId> + <artifactId>url-connection-client</artifactId> + </exclusion> + <exclusion> + <groupId>software.amazon.awssdk</groupId> + <artifactId>apache-client</artifactId> + </exclusion> + </exclusions> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>netty-nio-client</artifactId> + <optional>true</optional> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>aws-crt-client</artifactId> + <optional>true</optional> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>url-connection-client</artifactId> + <optional>true</optional> + </dependency> + <dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>apache-client</artifactId> + <optional>true</optional> + <exclusions> + <exclusion> + <groupId>commons-logging</groupId> + <artifactId>commons-logging</artifactId> + </exclusion> + </exclusions> + </dependency> + <dependency> + <groupId>org.jboss.logging</groupId> + <artifactId>commons-logging-jboss-logging</artifactId> + </dependency> + </dependencies> + + <build> + <plugins> + <plugin> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-extension-maven-plugin</artifactId> + </plugin> + <plugin> + <artifactId>maven-compiler-plugin</artifactId> + <configuration> + <annotationProcessorPaths> + <path> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-extension-processor</artifactId> + <version>${quarkus.version}</version> + </path> + </annotationProcessorPaths> + </configuration> + </plugin> + </plugins> + </build> +</project> diff --git a/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmBuildTimeConfig.java b/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmBuildTimeConfig.java new file mode 100644 index 000000000..5201b3494 --- /dev/null +++ b/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmBuildTimeConfig.java @@ -0,0 +1,32 @@ +package io.quarkiverse.amazon.acm.runtime; + +import io.quarkiverse.amazon.common.runtime.AsyncHttpClientBuildTimeConfig; +import io.quarkiverse.amazon.common.runtime.DevServicesBuildTimeConfig; +import io.quarkiverse.amazon.common.runtime.HasSdkBuildTimeConfig; +import io.quarkiverse.amazon.common.runtime.SyncHttpClientBuildTimeConfig; +import io.quarkus.runtime.annotations.ConfigPhase; +import io.quarkus.runtime.annotations.ConfigRoot; +import io.smallrye.config.ConfigMapping; + +/** + * Amazon ACM build time configuration + */ +@ConfigMapping(prefix = "quarkus.acm") +@ConfigRoot(phase = ConfigPhase.BUILD_AND_RUN_TIME_FIXED) +public interface AcmBuildTimeConfig extends HasSdkBuildTimeConfig { + + /** + * Sync HTTP transport configuration for Amazon ACM client + */ + SyncHttpClientBuildTimeConfig syncClient(); + + /** + * Async HTTP transport configuration for Amazon ACM client + */ + AsyncHttpClientBuildTimeConfig asyncClient(); + + /** + * Config for dev services + */ + DevServicesBuildTimeConfig devservices(); +} diff --git a/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmConfig.java b/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmConfig.java new file mode 100644 index 000000000..986ba4b9c --- /dev/null +++ b/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmConfig.java @@ -0,0 +1,25 @@ +package io.quarkiverse.amazon.acm.runtime; + +import io.quarkiverse.amazon.common.runtime.AsyncHttpClientConfig; +import io.quarkiverse.amazon.common.runtime.HasAmazonClientRuntimeConfig; +import io.quarkiverse.amazon.common.runtime.SyncHttpClientConfig; +import io.quarkus.runtime.annotations.ConfigDocSection; +import io.quarkus.runtime.annotations.ConfigPhase; +import io.quarkus.runtime.annotations.ConfigRoot; +import io.smallrye.config.ConfigMapping; + +@ConfigMapping(prefix = "quarkus.acm") +@ConfigRoot(phase = ConfigPhase.RUN_TIME) +public interface AcmConfig extends HasAmazonClientRuntimeConfig { + /** + * Sync HTTP transport configurations + */ + @ConfigDocSection + SyncHttpClientConfig syncClient(); + + /** + * Async HTTP transport configurations + */ + @ConfigDocSection + AsyncHttpClientConfig asyncClient(); +} diff --git a/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmRecorder.java b/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmRecorder.java new file mode 100644 index 000000000..e00fc17e4 --- /dev/null +++ b/acm/runtime/src/main/java/io/quarkiverse/amazon/acm/runtime/AcmRecorder.java @@ -0,0 +1,47 @@ +package io.quarkiverse.amazon.acm.runtime; + +import io.quarkiverse.amazon.common.runtime.AmazonClientRecorder; +import io.quarkiverse.amazon.common.runtime.AsyncHttpClientConfig; +import io.quarkiverse.amazon.common.runtime.HasAmazonClientRuntimeConfig; +import io.quarkiverse.amazon.common.runtime.SyncHttpClientConfig; +import io.quarkus.runtime.RuntimeValue; +import io.quarkus.runtime.annotations.Recorder; +import software.amazon.awssdk.awscore.client.builder.AwsAsyncClientBuilder; +import software.amazon.awssdk.awscore.client.builder.AwsSyncClientBuilder; +import software.amazon.awssdk.services.acm.AcmAsyncClient; +import software.amazon.awssdk.services.acm.AcmClient; + +@Recorder +public class AcmRecorder extends AmazonClientRecorder { + + final AcmConfig config; + + public AcmRecorder(AcmConfig config) { + this.config = config; + } + + @Override + public RuntimeValue<HasAmazonClientRuntimeConfig> getAmazonClientsConfig() { + return new RuntimeValue<>(config); + } + + @Override + public AsyncHttpClientConfig getAsyncClientConfig() { + return config.asyncClient(); + } + + @Override + public SyncHttpClientConfig getSyncClientConfig() { + return config.syncClient(); + } + + @Override + public AwsSyncClientBuilder<?, ?> geSyncClientBuilder() { + return AcmClient.builder(); + } + + @Override + public AwsAsyncClientBuilder<?, ?> getAsyncClientBuilder() { + return AcmAsyncClient.builder(); + } +} diff --git a/acm/runtime/src/main/resources/META-INF/quarkus-extension.yaml b/acm/runtime/src/main/resources/META-INF/quarkus-extension.yaml new file mode 100644 index 000000000..ac2d038ef --- /dev/null +++ b/acm/runtime/src/main/resources/META-INF/quarkus-extension.yaml @@ -0,0 +1,14 @@ +--- +artifact: ${project.groupId}:${project.artifactId}:${project.version} +name: "Amazon ACM" +metadata: + keywords: + - "acm" + - "aws" + - "amazon" + categories: + - "data" + guide: https://docs.quarkiverse.io/quarkus-amazon-services/dev/amazon-acm.html + status: "stable" + config: + - "quarkus.acm." diff --git a/bom/pom.xml b/bom/pom.xml index 72cc4b259..898f40995 100644 --- a/bom/pom.xml +++ b/bom/pom.xml @@ -449,6 +449,21 @@ <artifactId>quarkus-amazon-devservices-sfn</artifactId> <version>${project.version}</version> </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-devservices-acm</artifactId> + <version>${project.version}</version> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm</artifactId> + <version>${project.version}</version> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm-deployment</artifactId> + <version>${project.version}</version> + </dependency> </dependencies> </dependencyManagement> </project> \ No newline at end of file diff --git a/devservices/acm/pom.xml b/devservices/acm/pom.xml new file mode 100644 index 000000000..bfdb21e5a --- /dev/null +++ b/devservices/acm/pom.xml @@ -0,0 +1,39 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + + <parent> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-devservices-parent</artifactId> + <version>999-SNAPSHOT</version> + </parent> + + <artifactId>quarkus-amazon-devservices-acm</artifactId> + <name>Quarkus - Amazon DevServices - ACM</name> + <dependencies> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-common-deployment-devservices-spi</artifactId> + </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm</artifactId> + </dependency> + </dependencies> + <build> + <plugins> + <plugin> + <artifactId>maven-compiler-plugin</artifactId> + <configuration> + <annotationProcessorPaths> + <path> + <groupId>io.quarkus</groupId> + <artifactId>quarkus-extension-processor</artifactId> + <version>${quarkus.version}</version> + </path> + </annotationProcessorPaths> + </configuration> + </plugin> + </plugins> + </build> +</project> \ No newline at end of file diff --git a/devservices/acm/src/main/java/io/quarkiverse/amazon/devservices/acm/AcmDevServicesProcessor.java b/devservices/acm/src/main/java/io/quarkiverse/amazon/devservices/acm/AcmDevServicesProcessor.java new file mode 100644 index 000000000..7ce2a9a90 --- /dev/null +++ b/devservices/acm/src/main/java/io/quarkiverse/amazon/devservices/acm/AcmDevServicesProcessor.java @@ -0,0 +1,16 @@ +package io.quarkiverse.amazon.devservices.acm; + +import org.testcontainers.containers.localstack.LocalStackContainer.EnabledService; + +import io.quarkiverse.amazon.acm.runtime.AcmBuildTimeConfig; +import io.quarkiverse.amazon.common.deployment.spi.AbstractDevServicesLocalStackProcessor; +import io.quarkiverse.amazon.common.deployment.spi.DevServicesLocalStackProviderBuildItem; +import io.quarkus.deployment.annotations.BuildStep; + +public class AcmDevServicesProcessor extends AbstractDevServicesLocalStackProcessor { + + @BuildStep + DevServicesLocalStackProviderBuildItem setupSsm(AcmBuildTimeConfig clientBuildTimeConfig) { + return this.setup(EnabledService.named("acm"), clientBuildTimeConfig.devservices()); + } +} diff --git a/devservices/pom.xml b/devservices/pom.xml index 117e75437..6610d3449 100644 --- a/devservices/pom.xml +++ b/devservices/pom.xml @@ -17,6 +17,7 @@ </description> <packaging>pom</packaging> <modules> + <module>acm</module> <module>cognito-user-pools</module> <module>cloudwatch</module> <module>cloudwatchlogs</module> diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index 09c6d328c..68e353b7f 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -1,4 +1,5 @@ -* xref:amazon-apigatewaymanagementapi [Api Gateway Management Api] +* xref:amazon-acm.adoc[ACM] +* xref:amazon-apigatewaymanagementapi.adoc[Api Gateway Management Api] * xref:amazon-cloudwatch.adoc[CloudWatch] * xref:amazon-cloudwatchlogs.adoc[CloudWatch Logs] * xref:amazon-cognitouserpools.adoc[Cognito User Pools] diff --git a/docs/modules/ROOT/pages/amazon-acm.adoc b/docs/modules/ROOT/pages/amazon-acm.adoc new file mode 100644 index 000000000..784d1951e --- /dev/null +++ b/docs/modules/ROOT/pages/amazon-acm.adoc @@ -0,0 +1,260 @@ += Amazon ACM Client + +include::./includes/attributes.adoc[] + +AWS Certificate Manager is a service used to manage X.509 certificates used by other AWS services including load balancers and applications. + +You can find more information about ACM at https://aws.amazon.com/certificate-manager/[the AWS Certificate Manager website]. + +NOTE: The ACM extension is based on https://docs.aws.amazon.com/sdk-for-java/v2/developer-guide/welcome.html[AWS Java SDK 2.x]. +It's a major rewrite of the 1.x code base that offers two programming models (Blocking & Async). + +The Quarkus extension supports two programming models: + +* Blocking access using URL Connection HTTP client (by default) or the Apache HTTP Client +* https://docs.aws.amazon.com/sdk-for-java/v2/developer-guide/basics-async.html[Asynchronous programming] based on JDK's `CompletableFuture` objects and the Netty HTTP client (by default) or the AWS CRT-based HTTP client + +In this guide, we see how you can get your REST services to use ACM locally and on AWS. + +== Prerequisites + +To complete this guide, you need: + +* JDK 17+ installed with `JAVA_HOME` configured appropriately +* an IDE +* Apache Maven {maven-version} +* An AWS Account to access the ACM service +* Docker for your system to run ACM locally for testing purposes + +=== Provision ACM locally via Dev Services + +The easiest way to start working with ACM is to run a local instance using Dev Services. + +=== Provision ACM locally manually + +You can also set up a local version of ACM manually, first start a LocalStack container: + +[source,bash,subs="verbatim,attributes"] +---- +docker run --rm --name local-acm --publish 4566:4566 -e SERVICES=acm -e START_WEB=0 -d localstack/localstack:3.7.2 +---- +This starts an ACM instance that is accessible on port `4566`. + +Create an AWS profile for your local instance using AWS CLI: +[source,shell,subs="verbatim,attributes"] +---- +$ aws configure --profile localstack +AWS Access Key ID [None]: test-key +AWS Secret Access Key [None]: test-secret +Default region name [None]: us-east-1 +Default output format [None]: +---- + +== Solution +The application built here allows to import external certificates into ACM. + +We recommend that you follow the instructions in the next sections and create the application step by step. +However, you can go right to the completed example. + +Clone the Git repository: `git clone {quickstarts-clone-url}`, or download an {quickstarts-archive-url}[archive]. + +The solution is located in the `amazon-acm-quickstart` {quickstarts-tree-url}/amazon-acm-quickstart[directory]. + +== Creating the Maven project + +First, we need a new project. Create a new project with the following command: + +[source,bash,subs=attributes+] +---- +mvn io.quarkus.platform:quarkus-maven-plugin:{quarkus-version}:create \ + -DprojectGroupId=org.acme \ + -DprojectArtifactId=amazon-acm-quickstart \ + -DclassName="org.acme.acm.QuarkusAcmSyncResource" \ + -Dpath="/sync" \ + -Dextensions="resteasy-reactive-jackson,amazon-acm" +cd amazon-acm-quickstart +---- + +This command generates a Maven structure importing the RESTEasy Reactive/JAX-RS and Amazon ACM Client extensions. +After this, the `amazon-acm` extension has been added to your `pom.xml` as well as the Mutiny support for RESTEasy. + +== Creating JSON REST service + +In this example, we will create an application that allows us to request certificates for a particular domain using a RESTful API. +The example application will demonstrate the two programming models supported by the extension. + +Let's start with the synchronous implementation in the `org.acme.acm.QuarkusAcmSyncResource` class. + +[source,java] +---- +package org.acme.acm; + +import jakarta.inject.Inject; +import jakarta.ws.rs.GET; +import jakarta.ws.rs.Path; +import jakarta.ws.rs.Produces; +import jakarta.ws.rs.QueryParam; +import jakarta.ws.rs.core.MediaType; +import software.amazon.awssdk.services.acm.AcmClient; + +@Path("/sync") +public class QuarkusAcmSyncResource { + + @Inject <1> + AcmClient acm; + + @GET + @Produces(MediaType.TEXT_PLAIN) + public String requestCertificate(@QueryParam("domainName") String domainName) { + return acm.requestCertificate(r -> r.domainName(domainName)).certificateArn(); + } +} +---- + +<1> Inject the client provided by the amazon-acm extension + +Using the Amazon ACM SDK, we can easily request a certificate for a domain and expose the resulting ARN. + +== Configuring ACM clients + +Both ACM clients (sync and async) are configurable via the `application.properties` file that can be provided in the `src/main/resources` directory. +Additionally, you need to add to the classpath a proper implementation of the sync client. By default, the extension uses the URL connection HTTP client, so +you need to add a URL connection client dependency to the `pom.xml` file: + +[source,xml] +---- +<dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>url-connection-client</artifactId> +</dependency> +---- + +If you want to use the Apache HTTP client instead, configure it as follows: +[source,properties] +---- +quarkus.acm.sync-client.type=apache +---- + +And add the following dependency to the application `pom.xml`: +[source,xml] +---- +<dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>apache-client</artifactId> +</dependency> +---- + +If you want to use the AWS CRT-based HTTP client instead, configure it as follows: +[source,properties] +---- +quarkus.acm.sync-client.type=aws-crt +---- + +And add the following dependency to the application `pom.xml`: +[source,xml] +---- +<dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>aws-crt-client</artifactId> +</dependency> +---- + + +If you're going to use a local ACM instance, configure it as follows: + +[source,properties] +---- +quarkus.acm.endpoint-override=http://localhost:4566 <1> + +quarkus.acm.aws.region=us-east-1 <2> +quarkus.acm.aws.credentials.type=static <3> +quarkus.acm.aws.credentials.static-provider.access-key-id=test-key +quarkus.acm.aws.credentials.static-provider.secret-access-key=test-secret +---- + +<1> Override the ACM client to use LocalStack instead of the actual AWS service +<2> Localstack defaults to `us-east-1` +<3> The `static` credentials provider lets you set the `access-key-id` and `secret-access-key` directly + +If you want to work with an AWS account, you can simply remove or comment out all Amazon ACM related properties. By default, the ACM client extension will use the `default` credentials provider chain that looks for credentials in this order: + +include::./amazon-credentials.adoc[] + +And the region from your AWS CLI profile will be used. + +== Next steps + +=== Packaging + +Packaging your application is as simple as `./mvnw clean package`. +It can then be run with `java -jar target/quarkus-app/quarkus-run.jar`. + +With GraalVM installed, you can also create a native executable binary: `./mvnw clean package -Dnative`. +Depending on your system, that will take some time. + +=== Going asynchronous + +Thanks to the AWS SDK v2.x used by the Quarkus extension, you can use the asynchronous programming model out of the box. + +Create a `org.acme.acm.QuarkusAcmAsyncResource` REST resource that will be similar to our `QuarkusAcmSyncResource` but using an asynchronous programming model. + +[source,java] +---- +package org.acme.acm; + +import io.smallrye.mutiny.Uni; +import jakarta.inject.Inject; +import jakarta.ws.rs.GET; +import jakarta.ws.rs.Path; +import jakarta.ws.rs.Produces; +import jakarta.ws.rs.QueryParam; +import jakarta.ws.rs.core.MediaType; +import software.amazon.awssdk.services.acm.AcmAsyncClient; +import software.amazon.awssdk.services.acm.model.RequestCertificateResponse; + +@Path("/async") +public class QuarkusAcmAsyncResource { + + @Inject + AcmAsyncClient acm; + + @GET + @Produces(MediaType.TEXT_PLAIN) + public Uni<String> importCertificate(@QueryParam("domainName") String domainName) { + return Uni.createFrom().completionStage(acm + .requestCertificate(r -> r.domainName(domainName)) + .thenApply(RequestCertificateResponse::certificateArn)); + } +} +---- + +Note that the `AcmAsyncClient` behaves just like the `AcmClient`, but returns `CompletionStage` objects which we use to create `Uni` instances, and then transform the emitted item. + +To enable the asynchronous client, we also need to add the Netty HTTP client dependency to the `pom.xml`: + +[source,xml] +---- +<dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>netty-nio-client</artifactId> +</dependency> +---- + +If you want to use the AWS CRT-based HTTP client instead, configure it as follows: +[source,properties] +---- +quarkus.acm.async-client.type=aws-crt +---- + +And add the following dependency to the application `pom.xml`: +[source,xml] +---- +<dependency> + <groupId>software.amazon.awssdk</groupId> + <artifactId>aws-crt-client</artifactId> +</dependency> +---- + +== Configuration Reference + +include::./includes/quarkus-amazon-acm.adoc[] diff --git a/docs/modules/ROOT/pages/includes/quarkus-amazon-acm.adoc b/docs/modules/ROOT/pages/includes/quarkus-amazon-acm.adoc new file mode 100644 index 000000000..235eb1743 --- /dev/null +++ b/docs/modules/ROOT/pages/includes/quarkus-amazon-acm.adoc @@ -0,0 +1,1748 @@ +[.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|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-interceptors]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-interceptors[`quarkus.acm.interceptors`]## + +[.description] +-- +List of execution interceptors that will have access to read and modify the request and response objects as they are processed by the AWS SDK. + +The list should consists of class names which implements `software.amazon.awssdk.core.interceptor.ExecutionInterceptor` interface. Classes will be attempted to be loaded via CDI first, and if no CDI beans are available, then the constructor with no parameters will be invoked to instantiate each class. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_INTERCEPTORS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_INTERCEPTORS+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-telemetry-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-telemetry-enabled[`quarkus.acm.telemetry.enabled`]## + +[.description] +-- +OpenTelemetry AWS SDK instrumentation will be enabled if the OpenTelemetry extension is present and this value is true. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_TELEMETRY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_TELEMETRY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-sync-client-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-type[`quarkus.acm.sync-client.type`]## + +[.description] +-- +Type of the sync HTTP client implementation + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`url`, `apache`, `aws-crt` +|`url` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-async-client-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-type[`quarkus.acm.async-client.type`]## + +[.description] +-- +Type of the async HTTP client implementation + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`netty`, `aws-crt` +|`netty` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-enabled[`quarkus.acm.devservices.enabled`]## + +[.description] +-- +If a local AWS stack should be used. (default to true) If this is true and endpoint-override is not configured then a local AWS stack will be started and will be used instead of the given configuration. For all services but Cognito, the local AWS stack will be provided by LocalStack. Otherwise, it will be provided by Moto + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +| + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-shared]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-shared[`quarkus.acm.devservices.shared`]## + +[.description] +-- +Indicates if the LocalStack container managed by Dev Services is shared. When shared, Quarkus looks for running containers using label-based service discovery. If a matching container is found, it is used, and so a second one is not started. Otherwise, Dev Services starts a new container. + +The discovery uses the `quarkus-dev-service-localstack` label. The value is configured using the `service-name` property. + +Sharing is not supported for the Cognito extension. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_SHARED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_SHARED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-isolated]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-isolated[`quarkus.acm.devservices.isolated`]## + +[.description] +-- +Indicates if shared LocalStack services managed by Dev Services should be isolated. When true, the service will be started in its own container and the value of the `quarkus-dev-service-localstack` label will be suffixed by the service name (s3, sqs, ...) + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_ISOLATED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_ISOLATED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-service-name]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-service-name[`quarkus.acm.devservices.service-name`]## + +[.description] +-- +The value of the `quarkus-dev-service-localstack` label attached to the started container. In dev mode, when `shared` is set to `true`, before starting a container, Dev Services looks for a container with the `quarkus-dev-service-localstack` label set to the configured value. If found, it will use this container instead of starting a new one. Otherwise it starts a new container with the `quarkus-dev-service-localstack` label set to the specified value. In test mode, Dev Services will group services with the same `service-name` value in one container instance. + +This property is used when you need multiple shared LocalStack instances. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_SERVICE_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_SERVICE_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +|`localstack` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-container-properties-container-properties]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-container-properties-container-properties[`quarkus.acm.devservices.container-properties."container-properties"`]## + +[.description] +-- +Generic properties that are pass for additional container configuration. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_CONTAINER_PROPERTIES__CONTAINER_PROPERTIES_+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_CONTAINER_PROPERTIES__CONTAINER_PROPERTIES_+++` +endif::add-copy-button-to-env-var[] +-- +|Map<String,String> +| + +h|[[quarkus-amazon-acm_section_quarkus-acm]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm[AWS SDK client configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-endpoint-override]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-endpoint-override[`quarkus.acm.endpoint-override`]## + +`quarkus.acm."client-name".endpoint-override` + +[.description] +-- +The endpoint URI with which the SDK should communicate. + +If not specified, an appropriate endpoint to be used for the given service and region. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ENDPOINT_OVERRIDE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ENDPOINT_OVERRIDE+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-api-call-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-api-call-timeout[`quarkus.acm.api-call-timeout`]## + +`quarkus.acm."client-name".api-call-timeout` + +[.description] +-- +The amount of time to allow the client to complete the execution of an API call. + +This timeout covers the entire client execution except for marshalling. This includes request handler execution, all HTTP requests including retries, unmarshalling, etc. + +This value should always be positive, if present. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_API_CALL_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_API_CALL_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-api-call-attempt-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-api-call-attempt-timeout[`quarkus.acm.api-call-attempt-timeout`]## + +`quarkus.acm."client-name".api-call-attempt-timeout` + +[.description] +-- +The amount of time to wait for the HTTP request to complete before giving up and timing out. + +This value should always be positive, if present. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_API_CALL_ATTEMPT_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_API_CALL_ATTEMPT_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-advanced-use-quarkus-scheduled-executor-service]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-advanced-use-quarkus-scheduled-executor-service[`quarkus.acm.advanced.use-quarkus-scheduled-executor-service`]## + +`quarkus.acm."client-name".advanced.use-quarkus-scheduled-executor-service` + +[.description] +-- +Whether the Quarkus thread pool should be used for scheduling tasks such as async retry attempts and timeout task. + +When disabled, the default sdk behavior is to create a dedicated thread pool for each client, resulting in competition for CPU resources among these thread pools. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ADVANCED_USE_QUARKUS_SCHEDULED_EXECUTOR_SERVICE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ADVANCED_USE_QUARKUS_SCHEDULED_EXECUTOR_SERVICE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm-aws[AWS services configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-region]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-region[`quarkus.acm.aws.region`]## + +`quarkus.acm."client-name".aws.region` + +[.description] +-- +An Amazon Web Services region that hosts the given service. + +It overrides region provider chain with static value of +region with which the service client should communicate. + +If not set, region is retrieved via the default providers chain in the following order: + +* `aws.region` system property +* `region` property from the profile file +* Instance profile file + +See `software.amazon.awssdk.regions.Region` for available regions. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_REGION+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_REGION+++` +endif::add-copy-button-to-env-var[] +-- +|Region +| + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-type[`quarkus.acm.aws.credentials.type`]## + +`quarkus.acm."client-name".aws.credentials.type` + +[.description] +-- +Configure the credentials provider that should be used to authenticate with AWS. + +Available values: + +* `default` - the provider will attempt to identify the credentials automatically using the following checks: +** Java System Properties - `aws.accessKeyId` and `aws.secretAccessKey` +** Environment Variables - `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` +** Credential profiles file at the default location (`~/.aws/credentials`) shared by all AWS SDKs and the AWS CLI +** Credentials delivered through the Amazon EC2 container service if `AWS_CONTAINER_CREDENTIALS_RELATIVE_URI` environment variable is set and security manager has permission to access the variable. +** Instance profile credentials delivered through the Amazon EC2 metadata service +* `static` - the provider that uses the access key and secret access key specified in the `static-provider` section of the config. +* `system-property` - it loads credentials from the `aws.accessKeyId`, `aws.secretAccessKey` and `aws.sessionToken` system properties. +* `env-variable` - it loads credentials from the `AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY` and `AWS_SESSION_TOKEN` environment variables. +* `profile` - credentials are based on AWS configuration profiles. This loads credentials from + a http://docs.aws.amazon.com/cli/latest/userguide/cli-chap-getting-started.html[profile file], + allowing you to share multiple sets of AWS security credentials between different tools like the AWS SDK for Java and the AWS CLI. +* `container` - It loads credentials from a local metadata service. Containers currently supported by the AWS SDK are + **Amazon Elastic Container Service (ECS)** and **AWS Greengrass** +* `instance-profile` - It loads credentials from the Amazon EC2 Instance Metadata Service. +* `process` - Credentials are loaded from an external process. This is used to support the credential_process setting in the profile + credentials file. See https://docs.aws.amazon.com/cli/latest/topic/config-vars.html#sourcing-credentials-from-external-processes[Sourcing Credentials From External Processes] + for more information. +* `anonymous` - It always returns anonymous AWS credentials. Anonymous AWS credentials result in un-authenticated requests and will + fail unless the resource or API's policy has been configured to specifically allow anonymous access. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`default`, `static`, `system-property`, `env-variable`, `profile`, `container`, `instance-profile`, `process`, `custom`, `anonymous` +|`default` + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-default-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-default-provider[Default credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-async-credential-update-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-async-credential-update-enabled[`quarkus.acm.aws.credentials.default-provider.async-credential-update-enabled`]## + +`quarkus.acm."client-name".aws.credentials.default-provider.async-credential-update-enabled` + +[.description] +-- +Whether this provider should fetch credentials asynchronously in the background. + +If this is `true`, threads are less likely to block, but additional resources are used to maintain the provider. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-reuse-last-provider-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-reuse-last-provider-enabled[`quarkus.acm.aws.credentials.default-provider.reuse-last-provider-enabled`]## + +`quarkus.acm."client-name".aws.credentials.default-provider.reuse-last-provider-enabled` + +[.description] +-- +Whether the provider should reuse the last successful credentials provider in the chain. + +Reusing the last successful credentials provider will typically return credentials faster than searching through the chain. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_REUSE_LAST_PROVIDER_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_REUSE_LAST_PROVIDER_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-static-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-static-provider[Static credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-access-key-id]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-access-key-id[`quarkus.acm.aws.credentials.static-provider.access-key-id`]## + +`quarkus.acm."client-name".aws.credentials.static-provider.access-key-id` + +[.description] +-- +AWS Access key id + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_ACCESS_KEY_ID+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_ACCESS_KEY_ID+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-secret-access-key]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-secret-access-key[`quarkus.acm.aws.credentials.static-provider.secret-access-key`]## + +`quarkus.acm."client-name".aws.credentials.static-provider.secret-access-key` + +[.description] +-- +AWS Secret access key + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SECRET_ACCESS_KEY+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SECRET_ACCESS_KEY+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-session-token]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-session-token[`quarkus.acm.aws.credentials.static-provider.session-token`]## + +`quarkus.acm."client-name".aws.credentials.static-provider.session-token` + +[.description] +-- +AWS Session token + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SESSION_TOKEN+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SESSION_TOKEN+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-profile-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-profile-provider[AWS Profile credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-profile-provider-profile-name]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-profile-provider-profile-name[`quarkus.acm.aws.credentials.profile-provider.profile-name`]## + +`quarkus.acm."client-name".aws.credentials.profile-provider.profile-name` + +[.description] +-- +The name of the profile that should be used by this credentials provider. + +If not specified, the value in `AWS_PROFILE` environment variable or `aws.profile` system property is used and defaults to `default` name. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROFILE_PROVIDER_PROFILE_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROFILE_PROVIDER_PROFILE_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-process-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-process-provider[Process credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-async-credential-update-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-async-credential-update-enabled[`quarkus.acm.aws.credentials.process-provider.async-credential-update-enabled`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.async-credential-update-enabled` + +[.description] +-- +Whether the provider should fetch credentials asynchronously in the background. + +If this is true, threads are less likely to block when credentials are loaded, but additional resources are used to maintain the provider. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-credential-refresh-threshold]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-credential-refresh-threshold[`quarkus.acm.aws.credentials.process-provider.credential-refresh-threshold`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.credential-refresh-threshold` + +[.description] +-- +The amount of time between when the credentials expire and when the credentials should start to be refreshed. + +This allows the credentials to be refreshed ++*++before++*++ they are reported to expire. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_CREDENTIAL_REFRESH_THRESHOLD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_CREDENTIAL_REFRESH_THRESHOLD+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`15S` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-process-output-limit]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-process-output-limit[`quarkus.acm.aws.credentials.process-provider.process-output-limit`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.process-output-limit` + +[.description] +-- +The maximum size of the output that can be returned by the external process before an exception is raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_PROCESS_OUTPUT_LIMIT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_PROCESS_OUTPUT_LIMIT+++` +endif::add-copy-button-to-env-var[] +-- +|MemorySize link:#memory-size-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the MemorySize format]] +|`1024` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-command]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-command[`quarkus.acm.aws.credentials.process-provider.command`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.command` + +[.description] +-- +The command that should be executed to retrieve credentials. Command and parameters are seperated list entries. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_COMMAND+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_COMMAND+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-custom-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-custom-provider[Custom credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-custom-provider-name]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-custom-provider-name[`quarkus.acm.aws.credentials.custom-provider.name`]## + +`quarkus.acm."client-name".aws.credentials.custom-provider.name` + +[.description] +-- +The name of custom AwsCredentialsProvider bean. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_CUSTOM_PROVIDER_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_CUSTOM_PROVIDER_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + + +h|[[quarkus-amazon-acm_section_quarkus-acm-sync-client]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm-sync-client[Sync HTTP transport configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-connection-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-connection-timeout[`quarkus.acm.sync-client.connection-timeout`]## + +[.description] +-- +The maximum amount of time to establish a connection before timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CONNECTION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CONNECTION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`2S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-socket-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-socket-timeout[`quarkus.acm.sync-client.socket-timeout`]## + +[.description] +-- +The amount of time to wait for data to be transferred over an established, open connection before the connection is timed out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_SOCKET_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_SOCKET_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`30S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-type[`quarkus.acm.sync-client.tls-key-managers-provider.type`]## + +[.description] +-- +TLS key managers provider type. + +Available providers: + +* `none` - Use this provider if you don't want the client to present any certificates to the remote TLS host. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`none`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-path[`quarkus.acm.sync-client.tls-key-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-type[`quarkus.acm.sync-client.tls-key-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-password[`quarkus.acm.sync-client.tls-key-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-type[`quarkus.acm.sync-client.tls-trust-managers-provider.type`]## + +[.description] +-- +TLS trust managers provider type. + +Available providers: + +* `trust-all` - Use this provider to disable the validation of servers certificates and therefore trust all server certificates. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`trust-all`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-path[`quarkus.acm.sync-client.tls-trust-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-type[`quarkus.acm.sync-client.tls-trust-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-password[`quarkus.acm.sync-client.tls-trust-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +h|[[quarkus-amazon-acm_section_quarkus-acm-sync-client-apache]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-sync-client-apache[Apache HTTP client specific configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-acquisition-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-acquisition-timeout[`quarkus.acm.sync-client.apache.connection-acquisition-timeout`]## + +[.description] +-- +The amount of time to wait when acquiring a connection from the pool before giving up and timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_ACQUISITION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_ACQUISITION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`10S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-max-idle-time]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-max-idle-time[`quarkus.acm.sync-client.apache.connection-max-idle-time`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open while idle. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_MAX_IDLE_TIME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_MAX_IDLE_TIME+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`60S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-time-to-live]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-time-to-live[`quarkus.acm.sync-client.apache.connection-time-to-live`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open, regardless of usage frequency. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_TIME_TO_LIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_TIME_TO_LIVE+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-max-connections]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-max-connections[`quarkus.acm.sync-client.apache.max-connections`]## + +[.description] +-- +The maximum number of connections allowed in the connection pool. + +Each built HTTP client has its own private connection pool. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_MAX_CONNECTIONS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_MAX_CONNECTIONS+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`50` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-expect-continue-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-expect-continue-enabled[`quarkus.acm.sync-client.apache.expect-continue-enabled`]## + +[.description] +-- +Whether the client should send an HTTP expect-continue handshake before each request. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_EXPECT_CONTINUE_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_EXPECT_CONTINUE_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-use-idle-connection-reaper]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-use-idle-connection-reaper[`quarkus.acm.sync-client.apache.use-idle-connection-reaper`]## + +[.description] +-- +Whether the idle connections in the connection pool should be closed asynchronously. + +When enabled, connections left idling for longer than `quarkus..sync-client.connection-max-idle-time` will be closed. This will not close connections currently in use. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_USE_IDLE_CONNECTION_REAPER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_USE_IDLE_CONNECTION_REAPER+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-tcp-keep-alive]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-tcp-keep-alive[`quarkus.acm.sync-client.apache.tcp-keep-alive`]## + +[.description] +-- +Configure whether to enable or disable TCP KeepAlive. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_TCP_KEEP_ALIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_TCP_KEEP_ALIVE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-enabled[`quarkus.acm.sync-client.apache.proxy.enabled`]## + +[.description] +-- +Enable HTTP proxy + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-endpoint]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-endpoint[`quarkus.acm.sync-client.apache.proxy.endpoint`]## + +[.description] +-- +The endpoint of the proxy server that the SDK should connect through. + +Currently, the endpoint is limited to a host and port. Any other URI components will result in an exception being raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENDPOINT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENDPOINT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-username]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-username[`quarkus.acm.sync-client.apache.proxy.username`]## + +[.description] +-- +The username to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_USERNAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_USERNAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-password[`quarkus.acm.sync-client.apache.proxy.password`]## + +[.description] +-- +The password to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-domain]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-domain[`quarkus.acm.sync-client.apache.proxy.ntlm-domain`]## + +[.description] +-- +For NTLM proxies - the Windows domain name to use when authenticating with the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_DOMAIN+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_DOMAIN+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-workstation]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-workstation[`quarkus.acm.sync-client.apache.proxy.ntlm-workstation`]## + +[.description] +-- +For NTLM proxies - the Windows workstation name to use when authenticating with the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_WORKSTATION+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_WORKSTATION+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-preemptive-basic-authentication-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-preemptive-basic-authentication-enabled[`quarkus.acm.sync-client.apache.proxy.preemptive-basic-authentication-enabled`]## + +[.description] +-- +Whether to attempt to authenticate preemptively against the proxy server using basic authentication. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PREEMPTIVE_BASIC_AUTHENTICATION_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PREEMPTIVE_BASIC_AUTHENTICATION_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-non-proxy-hosts]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-non-proxy-hosts[`quarkus.acm.sync-client.apache.proxy.non-proxy-hosts`]## + +[.description] +-- +The hosts that the client is allowed to access without going through the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NON_PROXY_HOSTS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NON_PROXY_HOSTS+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-sync-client-crt]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-sync-client-crt[AWS CRT-based HTTP client specific configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-connection-max-idle-time]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-connection-max-idle-time[`quarkus.acm.sync-client.crt.connection-max-idle-time`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open while idle. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_CONNECTION_MAX_IDLE_TIME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_CONNECTION_MAX_IDLE_TIME+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`60S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-max-concurrency]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-max-concurrency[`quarkus.acm.sync-client.crt.max-concurrency`]## + +[.description] +-- +The maximum number of allowed concurrent requests. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_MAX_CONCURRENCY+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_MAX_CONCURRENCY+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`50` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-enabled[`quarkus.acm.sync-client.crt.proxy.enabled`]## + +[.description] +-- +Enable HTTP proxy + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-endpoint]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-endpoint[`quarkus.acm.sync-client.crt.proxy.endpoint`]## + +[.description] +-- +The endpoint of the proxy server that the SDK should connect through. + +Currently, the endpoint is limited to a host and port. Any other URI components will result in an exception being raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENDPOINT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENDPOINT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-username]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-username[`quarkus.acm.sync-client.crt.proxy.username`]## + +[.description] +-- +The username to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_USERNAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_USERNAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-password[`quarkus.acm.sync-client.crt.proxy.password`]## + +[.description] +-- +The password to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + + +h|[[quarkus-amazon-acm_section_quarkus-acm-async-client]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm-async-client[Async HTTP transport configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-max-concurrency]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-max-concurrency[`quarkus.acm.async-client.max-concurrency`]## + +[.description] +-- +The maximum number of allowed concurrent requests. + +For HTTP/1.1 this is the same as max connections. For HTTP/2 the number of connections that will be used depends on the max streams allowed per connection. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_MAX_CONCURRENCY+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_MAX_CONCURRENCY+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`50` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-max-pending-connection-acquires]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-max-pending-connection-acquires[`quarkus.acm.async-client.max-pending-connection-acquires`]## + +[.description] +-- +The maximum number of pending acquires allowed. + +Once this exceeds, acquire tries will be failed. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_MAX_PENDING_CONNECTION_ACQUIRES+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_MAX_PENDING_CONNECTION_ACQUIRES+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`10000` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-read-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-read-timeout[`quarkus.acm.async-client.read-timeout`]## + +[.description] +-- +The amount of time to wait for a read on a socket before an exception is thrown. + +Specify `0` to disable. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_READ_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_READ_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`30S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-write-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-write-timeout[`quarkus.acm.async-client.write-timeout`]## + +[.description] +-- +The amount of time to wait for a write on a socket before an exception is thrown. + +Specify `0` to disable. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_WRITE_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_WRITE_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`30S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-timeout[`quarkus.acm.async-client.connection-timeout`]## + +[.description] +-- +The amount of time to wait when initially establishing a connection before giving up and timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`10S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-acquisition-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-acquisition-timeout[`quarkus.acm.async-client.connection-acquisition-timeout`]## + +[.description] +-- +The amount of time to wait when acquiring a connection from the pool before giving up and timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_ACQUISITION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_ACQUISITION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`2S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-time-to-live]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-time-to-live[`quarkus.acm.async-client.connection-time-to-live`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open, regardless of usage frequency. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIME_TO_LIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIME_TO_LIVE+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-max-idle-time]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-max-idle-time[`quarkus.acm.async-client.connection-max-idle-time`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open while idle. + +Currently has no effect if `quarkus..async-client.use-idle-connection-reaper` is false. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_MAX_IDLE_TIME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_MAX_IDLE_TIME+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`5S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-use-idle-connection-reaper]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-use-idle-connection-reaper[`quarkus.acm.async-client.use-idle-connection-reaper`]## + +[.description] +-- +Whether the idle connections in the connection pool should be closed. + +When enabled, connections left idling for longer than `quarkus..async-client.connection-max-idle-time` will be closed. This will not close connections currently in use. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_USE_IDLE_CONNECTION_REAPER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_USE_IDLE_CONNECTION_REAPER+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tcp-keep-alive]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tcp-keep-alive[`quarkus.acm.async-client.tcp-keep-alive`]## + +[.description] +-- +Configure whether to enable or disable TCP KeepAlive. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TCP_KEEP_ALIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TCP_KEEP_ALIVE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-protocol]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-protocol[`quarkus.acm.async-client.protocol`]## + +[.description] +-- +The HTTP protocol to use. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROTOCOL+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROTOCOL+++` +endif::add-copy-button-to-env-var[] +-- +a|`http1-1`, `http2` +|`http1-1` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-ssl-provider]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-ssl-provider[`quarkus.acm.async-client.ssl-provider`]## + +[.description] +-- +The SSL Provider to be used in the Netty client. + +Default is `OPENSSL` if available, `JDK` otherwise. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_SSL_PROVIDER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_SSL_PROVIDER+++` +endif::add-copy-button-to-env-var[] +-- +a|`jdk`, `openssl`, `openssl-refcnt` +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-http2-max-streams]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-http2-max-streams[`quarkus.acm.async-client.http2.max-streams`]## + +[.description] +-- +The maximum number of concurrent streams for an HTTP/2 connection. + +This setting is only respected when the HTTP/2 protocol is used. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_MAX_STREAMS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_MAX_STREAMS+++` +endif::add-copy-button-to-env-var[] +-- +|long +|`4294967295` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-http2-initial-window-size]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-http2-initial-window-size[`quarkus.acm.async-client.http2.initial-window-size`]## + +[.description] +-- +The initial window size for an HTTP/2 stream. + +This setting is only respected when the HTTP/2 protocol is used. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_INITIAL_WINDOW_SIZE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_INITIAL_WINDOW_SIZE+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`1048576` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-http2-health-check-ping-period]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-http2-health-check-ping-period[`quarkus.acm.async-client.http2.health-check-ping-period`]## + +[.description] +-- +Sets the period that the Netty client will send `PING` frames to the remote endpoint to check the health of the connection. To disable this feature, set a duration of 0. + +This setting is only respected when the HTTP/2 protocol is used. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_HEALTH_CHECK_PING_PERIOD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_HEALTH_CHECK_PING_PERIOD+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`5` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-proxy-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-proxy-enabled[`quarkus.acm.async-client.proxy.enabled`]## + +[.description] +-- +Enable HTTP proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-proxy-endpoint]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-proxy-endpoint[`quarkus.acm.async-client.proxy.endpoint`]## + +[.description] +-- +The endpoint of the proxy server that the SDK should connect through. + +Currently, the endpoint is limited to a host and port. Any other URI components will result in an exception being raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENDPOINT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENDPOINT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-proxy-non-proxy-hosts]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-proxy-non-proxy-hosts[`quarkus.acm.async-client.proxy.non-proxy-hosts`]## + +[.description] +-- +The hosts that the client is allowed to access without going through the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_NON_PROXY_HOSTS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_NON_PROXY_HOSTS+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-type[`quarkus.acm.async-client.tls-key-managers-provider.type`]## + +[.description] +-- +TLS key managers provider type. + +Available providers: + +* `none` - Use this provider if you don't want the client to present any certificates to the remote TLS host. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`none`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-path[`quarkus.acm.async-client.tls-key-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-type[`quarkus.acm.async-client.tls-key-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-password[`quarkus.acm.async-client.tls-key-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-type[`quarkus.acm.async-client.tls-trust-managers-provider.type`]## + +[.description] +-- +TLS trust managers provider type. + +Available providers: + +* `trust-all` - Use this provider to disable the validation of servers certificates and therefore trust all server certificates. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`trust-all`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-path[`quarkus.acm.async-client.tls-trust-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-type[`quarkus.acm.async-client.tls-trust-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-password[`quarkus.acm.async-client.tls-trust-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-event-loop-override]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-event-loop-override[`quarkus.acm.async-client.event-loop.override`]## + +[.description] +-- +Enable the custom configuration of the Netty event loop group. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_OVERRIDE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_OVERRIDE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-event-loop-number-of-threads]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-event-loop-number-of-threads[`quarkus.acm.async-client.event-loop.number-of-threads`]## + +[.description] +-- +Number of threads to use for the event loop group. + +If not set, the default Netty thread count is used (which is double the number of available processors unless the `io.netty.eventLoopThreads` system property is set. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_NUMBER_OF_THREADS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_NUMBER_OF_THREADS+++` +endif::add-copy-button-to-env-var[] +-- +|int +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-event-loop-thread-name-prefix]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-event-loop-thread-name-prefix[`quarkus.acm.async-client.event-loop.thread-name-prefix`]## + +[.description] +-- +The thread name prefix for threads created by this thread factory used by event loop group. + +The prefix will be appended with a number unique to the thread factory and a number unique to the thread. + +If not specified it defaults to `aws-java-sdk-NettyEventLoop` + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_THREAD_NAME_PREFIX+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_THREAD_NAME_PREFIX+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-advanced-use-future-completion-thread-pool]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-advanced-use-future-completion-thread-pool[`quarkus.acm.async-client.advanced.use-future-completion-thread-pool`]## + +[.description] +-- +Whether the default thread pool should be used to complete the futures returned from the HTTP client request. + +When disabled, futures will be completed on the Netty event loop thread. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_ADVANCED_USE_FUTURE_COMPLETION_THREAD_POOL+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_ADVANCED_USE_FUTURE_COMPLETION_THREAD_POOL+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + + +|=== + +ifndef::no-duration-note[] +[NOTE] +[id=duration-note-anchor-quarkus-amazon-acm_quarkus-acm] +.About the Duration format +==== +To write duration values, use the standard `java.time.Duration` format. +See the link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html#parse(java.lang.CharSequence)[Duration#parse() Java API documentation] for more information. + +You can also use a simplified format, starting with a number: + +* If the value is only a number, it represents time in seconds. +* If the value is a number followed by `ms`, it represents time in milliseconds. + +In other cases, the simplified format is translated to the `java.time.Duration` format for parsing: + +* If the value is a number followed by `h`, `m`, or `s`, it is prefixed with `PT`. +* If the value is a number followed by `d`, it is prefixed with `P`. +==== +endif::no-duration-note[] +ifndef::no-memory-size-note[] +[NOTE] +[id=memory-size-note-anchor-quarkus-amazon-acm_quarkus-acm] +.About the MemorySize format +==== +A size configuration option recognizes strings in this format (shown as a regular expression): `[0-9]+[KkMmGgTtPpEeZzYy]?`. + +If no suffix is given, assume bytes. +==== +ifndef::no-memory-size-note[] diff --git a/docs/modules/ROOT/pages/includes/quarkus-amazon-acm_quarkus.acm.adoc b/docs/modules/ROOT/pages/includes/quarkus-amazon-acm_quarkus.acm.adoc new file mode 100644 index 000000000..235eb1743 --- /dev/null +++ b/docs/modules/ROOT/pages/includes/quarkus-amazon-acm_quarkus.acm.adoc @@ -0,0 +1,1748 @@ +[.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|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-interceptors]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-interceptors[`quarkus.acm.interceptors`]## + +[.description] +-- +List of execution interceptors that will have access to read and modify the request and response objects as they are processed by the AWS SDK. + +The list should consists of class names which implements `software.amazon.awssdk.core.interceptor.ExecutionInterceptor` interface. Classes will be attempted to be loaded via CDI first, and if no CDI beans are available, then the constructor with no parameters will be invoked to instantiate each class. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_INTERCEPTORS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_INTERCEPTORS+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-telemetry-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-telemetry-enabled[`quarkus.acm.telemetry.enabled`]## + +[.description] +-- +OpenTelemetry AWS SDK instrumentation will be enabled if the OpenTelemetry extension is present and this value is true. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_TELEMETRY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_TELEMETRY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-sync-client-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-type[`quarkus.acm.sync-client.type`]## + +[.description] +-- +Type of the sync HTTP client implementation + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`url`, `apache`, `aws-crt` +|`url` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-async-client-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-type[`quarkus.acm.async-client.type`]## + +[.description] +-- +Type of the async HTTP client implementation + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`netty`, `aws-crt` +|`netty` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-enabled[`quarkus.acm.devservices.enabled`]## + +[.description] +-- +If a local AWS stack should be used. (default to true) If this is true and endpoint-override is not configured then a local AWS stack will be started and will be used instead of the given configuration. For all services but Cognito, the local AWS stack will be provided by LocalStack. Otherwise, it will be provided by Moto + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +| + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-shared]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-shared[`quarkus.acm.devservices.shared`]## + +[.description] +-- +Indicates if the LocalStack container managed by Dev Services is shared. When shared, Quarkus looks for running containers using label-based service discovery. If a matching container is found, it is used, and so a second one is not started. Otherwise, Dev Services starts a new container. + +The discovery uses the `quarkus-dev-service-localstack` label. The value is configured using the `service-name` property. + +Sharing is not supported for the Cognito extension. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_SHARED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_SHARED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-isolated]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-isolated[`quarkus.acm.devservices.isolated`]## + +[.description] +-- +Indicates if shared LocalStack services managed by Dev Services should be isolated. When true, the service will be started in its own container and the value of the `quarkus-dev-service-localstack` label will be suffixed by the service name (s3, sqs, ...) + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_ISOLATED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_ISOLATED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-service-name]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-service-name[`quarkus.acm.devservices.service-name`]## + +[.description] +-- +The value of the `quarkus-dev-service-localstack` label attached to the started container. In dev mode, when `shared` is set to `true`, before starting a container, Dev Services looks for a container with the `quarkus-dev-service-localstack` label set to the configured value. If found, it will use this container instead of starting a new one. Otherwise it starts a new container with the `quarkus-dev-service-localstack` label set to the specified value. In test mode, Dev Services will group services with the same `service-name` value in one container instance. + +This property is used when you need multiple shared LocalStack instances. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_SERVICE_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_SERVICE_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +|`localstack` + +a|icon:lock[title=Fixed at build time] [[quarkus-amazon-acm_quarkus-acm-devservices-container-properties-container-properties]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-devservices-container-properties-container-properties[`quarkus.acm.devservices.container-properties."container-properties"`]## + +[.description] +-- +Generic properties that are pass for additional container configuration. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_DEVSERVICES_CONTAINER_PROPERTIES__CONTAINER_PROPERTIES_+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_DEVSERVICES_CONTAINER_PROPERTIES__CONTAINER_PROPERTIES_+++` +endif::add-copy-button-to-env-var[] +-- +|Map<String,String> +| + +h|[[quarkus-amazon-acm_section_quarkus-acm]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm[AWS SDK client configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-endpoint-override]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-endpoint-override[`quarkus.acm.endpoint-override`]## + +`quarkus.acm."client-name".endpoint-override` + +[.description] +-- +The endpoint URI with which the SDK should communicate. + +If not specified, an appropriate endpoint to be used for the given service and region. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ENDPOINT_OVERRIDE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ENDPOINT_OVERRIDE+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-api-call-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-api-call-timeout[`quarkus.acm.api-call-timeout`]## + +`quarkus.acm."client-name".api-call-timeout` + +[.description] +-- +The amount of time to allow the client to complete the execution of an API call. + +This timeout covers the entire client execution except for marshalling. This includes request handler execution, all HTTP requests including retries, unmarshalling, etc. + +This value should always be positive, if present. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_API_CALL_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_API_CALL_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-api-call-attempt-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-api-call-attempt-timeout[`quarkus.acm.api-call-attempt-timeout`]## + +`quarkus.acm."client-name".api-call-attempt-timeout` + +[.description] +-- +The amount of time to wait for the HTTP request to complete before giving up and timing out. + +This value should always be positive, if present. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_API_CALL_ATTEMPT_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_API_CALL_ATTEMPT_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-advanced-use-quarkus-scheduled-executor-service]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-advanced-use-quarkus-scheduled-executor-service[`quarkus.acm.advanced.use-quarkus-scheduled-executor-service`]## + +`quarkus.acm."client-name".advanced.use-quarkus-scheduled-executor-service` + +[.description] +-- +Whether the Quarkus thread pool should be used for scheduling tasks such as async retry attempts and timeout task. + +When disabled, the default sdk behavior is to create a dedicated thread pool for each client, resulting in competition for CPU resources among these thread pools. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ADVANCED_USE_QUARKUS_SCHEDULED_EXECUTOR_SERVICE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ADVANCED_USE_QUARKUS_SCHEDULED_EXECUTOR_SERVICE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm-aws[AWS services configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-region]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-region[`quarkus.acm.aws.region`]## + +`quarkus.acm."client-name".aws.region` + +[.description] +-- +An Amazon Web Services region that hosts the given service. + +It overrides region provider chain with static value of +region with which the service client should communicate. + +If not set, region is retrieved via the default providers chain in the following order: + +* `aws.region` system property +* `region` property from the profile file +* Instance profile file + +See `software.amazon.awssdk.regions.Region` for available regions. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_REGION+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_REGION+++` +endif::add-copy-button-to-env-var[] +-- +|Region +| + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-type[`quarkus.acm.aws.credentials.type`]## + +`quarkus.acm."client-name".aws.credentials.type` + +[.description] +-- +Configure the credentials provider that should be used to authenticate with AWS. + +Available values: + +* `default` - the provider will attempt to identify the credentials automatically using the following checks: +** Java System Properties - `aws.accessKeyId` and `aws.secretAccessKey` +** Environment Variables - `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` +** Credential profiles file at the default location (`~/.aws/credentials`) shared by all AWS SDKs and the AWS CLI +** Credentials delivered through the Amazon EC2 container service if `AWS_CONTAINER_CREDENTIALS_RELATIVE_URI` environment variable is set and security manager has permission to access the variable. +** Instance profile credentials delivered through the Amazon EC2 metadata service +* `static` - the provider that uses the access key and secret access key specified in the `static-provider` section of the config. +* `system-property` - it loads credentials from the `aws.accessKeyId`, `aws.secretAccessKey` and `aws.sessionToken` system properties. +* `env-variable` - it loads credentials from the `AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY` and `AWS_SESSION_TOKEN` environment variables. +* `profile` - credentials are based on AWS configuration profiles. This loads credentials from + a http://docs.aws.amazon.com/cli/latest/userguide/cli-chap-getting-started.html[profile file], + allowing you to share multiple sets of AWS security credentials between different tools like the AWS SDK for Java and the AWS CLI. +* `container` - It loads credentials from a local metadata service. Containers currently supported by the AWS SDK are + **Amazon Elastic Container Service (ECS)** and **AWS Greengrass** +* `instance-profile` - It loads credentials from the Amazon EC2 Instance Metadata Service. +* `process` - Credentials are loaded from an external process. This is used to support the credential_process setting in the profile + credentials file. See https://docs.aws.amazon.com/cli/latest/topic/config-vars.html#sourcing-credentials-from-external-processes[Sourcing Credentials From External Processes] + for more information. +* `anonymous` - It always returns anonymous AWS credentials. Anonymous AWS credentials result in un-authenticated requests and will + fail unless the resource or API's policy has been configured to specifically allow anonymous access. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`default`, `static`, `system-property`, `env-variable`, `profile`, `container`, `instance-profile`, `process`, `custom`, `anonymous` +|`default` + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-default-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-default-provider[Default credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-async-credential-update-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-async-credential-update-enabled[`quarkus.acm.aws.credentials.default-provider.async-credential-update-enabled`]## + +`quarkus.acm."client-name".aws.credentials.default-provider.async-credential-update-enabled` + +[.description] +-- +Whether this provider should fetch credentials asynchronously in the background. + +If this is `true`, threads are less likely to block, but additional resources are used to maintain the provider. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-reuse-last-provider-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-default-provider-reuse-last-provider-enabled[`quarkus.acm.aws.credentials.default-provider.reuse-last-provider-enabled`]## + +`quarkus.acm."client-name".aws.credentials.default-provider.reuse-last-provider-enabled` + +[.description] +-- +Whether the provider should reuse the last successful credentials provider in the chain. + +Reusing the last successful credentials provider will typically return credentials faster than searching through the chain. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_REUSE_LAST_PROVIDER_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_DEFAULT_PROVIDER_REUSE_LAST_PROVIDER_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-static-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-static-provider[Static credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-access-key-id]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-access-key-id[`quarkus.acm.aws.credentials.static-provider.access-key-id`]## + +`quarkus.acm."client-name".aws.credentials.static-provider.access-key-id` + +[.description] +-- +AWS Access key id + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_ACCESS_KEY_ID+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_ACCESS_KEY_ID+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-secret-access-key]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-secret-access-key[`quarkus.acm.aws.credentials.static-provider.secret-access-key`]## + +`quarkus.acm."client-name".aws.credentials.static-provider.secret-access-key` + +[.description] +-- +AWS Secret access key + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SECRET_ACCESS_KEY+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SECRET_ACCESS_KEY+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-session-token]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-static-provider-session-token[`quarkus.acm.aws.credentials.static-provider.session-token`]## + +`quarkus.acm."client-name".aws.credentials.static-provider.session-token` + +[.description] +-- +AWS Session token + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SESSION_TOKEN+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_STATIC_PROVIDER_SESSION_TOKEN+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-profile-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-profile-provider[AWS Profile credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-profile-provider-profile-name]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-profile-provider-profile-name[`quarkus.acm.aws.credentials.profile-provider.profile-name`]## + +`quarkus.acm."client-name".aws.credentials.profile-provider.profile-name` + +[.description] +-- +The name of the profile that should be used by this credentials provider. + +If not specified, the value in `AWS_PROFILE` environment variable or `aws.profile` system property is used and defaults to `default` name. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROFILE_PROVIDER_PROFILE_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROFILE_PROVIDER_PROFILE_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-process-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-process-provider[Process credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-async-credential-update-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-async-credential-update-enabled[`quarkus.acm.aws.credentials.process-provider.async-credential-update-enabled`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.async-credential-update-enabled` + +[.description] +-- +Whether the provider should fetch credentials asynchronously in the background. + +If this is true, threads are less likely to block when credentials are loaded, but additional resources are used to maintain the provider. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_ASYNC_CREDENTIAL_UPDATE_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-credential-refresh-threshold]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-credential-refresh-threshold[`quarkus.acm.aws.credentials.process-provider.credential-refresh-threshold`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.credential-refresh-threshold` + +[.description] +-- +The amount of time between when the credentials expire and when the credentials should start to be refreshed. + +This allows the credentials to be refreshed ++*++before++*++ they are reported to expire. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_CREDENTIAL_REFRESH_THRESHOLD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_CREDENTIAL_REFRESH_THRESHOLD+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`15S` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-process-output-limit]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-process-output-limit[`quarkus.acm.aws.credentials.process-provider.process-output-limit`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.process-output-limit` + +[.description] +-- +The maximum size of the output that can be returned by the external process before an exception is raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_PROCESS_OUTPUT_LIMIT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_PROCESS_OUTPUT_LIMIT+++` +endif::add-copy-button-to-env-var[] +-- +|MemorySize link:#memory-size-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the MemorySize format]] +|`1024` + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-command]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-process-provider-command[`quarkus.acm.aws.credentials.process-provider.command`]## + +`quarkus.acm."client-name".aws.credentials.process-provider.command` + +[.description] +-- +The command that should be executed to retrieve credentials. Command and parameters are seperated list entries. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_COMMAND+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_PROCESS_PROVIDER_COMMAND+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-aws-credentials-custom-provider]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-aws-credentials-custom-provider[Custom credentials provider configuration]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-aws-credentials-custom-provider-name]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-aws-credentials-custom-provider-name[`quarkus.acm.aws.credentials.custom-provider.name`]## + +`quarkus.acm."client-name".aws.credentials.custom-provider.name` + +[.description] +-- +The name of custom AwsCredentialsProvider bean. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_AWS_CREDENTIALS_CUSTOM_PROVIDER_NAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_AWS_CREDENTIALS_CUSTOM_PROVIDER_NAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + + +h|[[quarkus-amazon-acm_section_quarkus-acm-sync-client]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm-sync-client[Sync HTTP transport configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-connection-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-connection-timeout[`quarkus.acm.sync-client.connection-timeout`]## + +[.description] +-- +The maximum amount of time to establish a connection before timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CONNECTION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CONNECTION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`2S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-socket-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-socket-timeout[`quarkus.acm.sync-client.socket-timeout`]## + +[.description] +-- +The amount of time to wait for data to be transferred over an established, open connection before the connection is timed out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_SOCKET_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_SOCKET_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`30S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-type[`quarkus.acm.sync-client.tls-key-managers-provider.type`]## + +[.description] +-- +TLS key managers provider type. + +Available providers: + +* `none` - Use this provider if you don't want the client to present any certificates to the remote TLS host. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`none`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-path[`quarkus.acm.sync-client.tls-key-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-type[`quarkus.acm.sync-client.tls-key-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-key-managers-provider-file-store-password[`quarkus.acm.sync-client.tls-key-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-type[`quarkus.acm.sync-client.tls-trust-managers-provider.type`]## + +[.description] +-- +TLS trust managers provider type. + +Available providers: + +* `trust-all` - Use this provider to disable the validation of servers certificates and therefore trust all server certificates. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`trust-all`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-path[`quarkus.acm.sync-client.tls-trust-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-type[`quarkus.acm.sync-client.tls-trust-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-tls-trust-managers-provider-file-store-password[`quarkus.acm.sync-client.tls-trust-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +h|[[quarkus-amazon-acm_section_quarkus-acm-sync-client-apache]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-sync-client-apache[Apache HTTP client specific configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-acquisition-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-acquisition-timeout[`quarkus.acm.sync-client.apache.connection-acquisition-timeout`]## + +[.description] +-- +The amount of time to wait when acquiring a connection from the pool before giving up and timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_ACQUISITION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_ACQUISITION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`10S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-max-idle-time]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-max-idle-time[`quarkus.acm.sync-client.apache.connection-max-idle-time`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open while idle. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_MAX_IDLE_TIME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_MAX_IDLE_TIME+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`60S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-time-to-live]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-connection-time-to-live[`quarkus.acm.sync-client.apache.connection-time-to-live`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open, regardless of usage frequency. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_TIME_TO_LIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_CONNECTION_TIME_TO_LIVE+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-max-connections]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-max-connections[`quarkus.acm.sync-client.apache.max-connections`]## + +[.description] +-- +The maximum number of connections allowed in the connection pool. + +Each built HTTP client has its own private connection pool. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_MAX_CONNECTIONS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_MAX_CONNECTIONS+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`50` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-expect-continue-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-expect-continue-enabled[`quarkus.acm.sync-client.apache.expect-continue-enabled`]## + +[.description] +-- +Whether the client should send an HTTP expect-continue handshake before each request. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_EXPECT_CONTINUE_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_EXPECT_CONTINUE_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-use-idle-connection-reaper]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-use-idle-connection-reaper[`quarkus.acm.sync-client.apache.use-idle-connection-reaper`]## + +[.description] +-- +Whether the idle connections in the connection pool should be closed asynchronously. + +When enabled, connections left idling for longer than `quarkus..sync-client.connection-max-idle-time` will be closed. This will not close connections currently in use. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_USE_IDLE_CONNECTION_REAPER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_USE_IDLE_CONNECTION_REAPER+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-tcp-keep-alive]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-tcp-keep-alive[`quarkus.acm.sync-client.apache.tcp-keep-alive`]## + +[.description] +-- +Configure whether to enable or disable TCP KeepAlive. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_TCP_KEEP_ALIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_TCP_KEEP_ALIVE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-enabled[`quarkus.acm.sync-client.apache.proxy.enabled`]## + +[.description] +-- +Enable HTTP proxy + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-endpoint]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-endpoint[`quarkus.acm.sync-client.apache.proxy.endpoint`]## + +[.description] +-- +The endpoint of the proxy server that the SDK should connect through. + +Currently, the endpoint is limited to a host and port. Any other URI components will result in an exception being raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENDPOINT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_ENDPOINT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-username]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-username[`quarkus.acm.sync-client.apache.proxy.username`]## + +[.description] +-- +The username to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_USERNAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_USERNAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-password[`quarkus.acm.sync-client.apache.proxy.password`]## + +[.description] +-- +The password to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-domain]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-domain[`quarkus.acm.sync-client.apache.proxy.ntlm-domain`]## + +[.description] +-- +For NTLM proxies - the Windows domain name to use when authenticating with the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_DOMAIN+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_DOMAIN+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-workstation]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-ntlm-workstation[`quarkus.acm.sync-client.apache.proxy.ntlm-workstation`]## + +[.description] +-- +For NTLM proxies - the Windows workstation name to use when authenticating with the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_WORKSTATION+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NTLM_WORKSTATION+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-preemptive-basic-authentication-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-preemptive-basic-authentication-enabled[`quarkus.acm.sync-client.apache.proxy.preemptive-basic-authentication-enabled`]## + +[.description] +-- +Whether to attempt to authenticate preemptively against the proxy server using basic authentication. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PREEMPTIVE_BASIC_AUTHENTICATION_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_PREEMPTIVE_BASIC_AUTHENTICATION_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-non-proxy-hosts]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-apache-proxy-non-proxy-hosts[`quarkus.acm.sync-client.apache.proxy.non-proxy-hosts`]## + +[.description] +-- +The hosts that the client is allowed to access without going through the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NON_PROXY_HOSTS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_APACHE_PROXY_NON_PROXY_HOSTS+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + + +h|[[quarkus-amazon-acm_section_quarkus-acm-sync-client-crt]] [.section-name.section-level1]##link:#quarkus-amazon-acm_section_quarkus-acm-sync-client-crt[AWS CRT-based HTTP client specific configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-connection-max-idle-time]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-connection-max-idle-time[`quarkus.acm.sync-client.crt.connection-max-idle-time`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open while idle. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_CONNECTION_MAX_IDLE_TIME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_CONNECTION_MAX_IDLE_TIME+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`60S` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-max-concurrency]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-max-concurrency[`quarkus.acm.sync-client.crt.max-concurrency`]## + +[.description] +-- +The maximum number of allowed concurrent requests. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_MAX_CONCURRENCY+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_MAX_CONCURRENCY+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`50` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-enabled[`quarkus.acm.sync-client.crt.proxy.enabled`]## + +[.description] +-- +Enable HTTP proxy + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-endpoint]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-endpoint[`quarkus.acm.sync-client.crt.proxy.endpoint`]## + +[.description] +-- +The endpoint of the proxy server that the SDK should connect through. + +Currently, the endpoint is limited to a host and port. Any other URI components will result in an exception being raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENDPOINT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_ENDPOINT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-username]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-username[`quarkus.acm.sync-client.crt.proxy.username`]## + +[.description] +-- +The username to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_USERNAME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_USERNAME+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-sync-client-crt-proxy-password[`quarkus.acm.sync-client.crt.proxy.password`]## + +[.description] +-- +The password to use when connecting through a proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_SYNC_CLIENT_CRT_PROXY_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + + + +h|[[quarkus-amazon-acm_section_quarkus-acm-async-client]] [.section-name.section-level0]##link:#quarkus-amazon-acm_section_quarkus-acm-async-client[Async HTTP transport configurations]## +h|Type +h|Default + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-max-concurrency]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-max-concurrency[`quarkus.acm.async-client.max-concurrency`]## + +[.description] +-- +The maximum number of allowed concurrent requests. + +For HTTP/1.1 this is the same as max connections. For HTTP/2 the number of connections that will be used depends on the max streams allowed per connection. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_MAX_CONCURRENCY+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_MAX_CONCURRENCY+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`50` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-max-pending-connection-acquires]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-max-pending-connection-acquires[`quarkus.acm.async-client.max-pending-connection-acquires`]## + +[.description] +-- +The maximum number of pending acquires allowed. + +Once this exceeds, acquire tries will be failed. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_MAX_PENDING_CONNECTION_ACQUIRES+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_MAX_PENDING_CONNECTION_ACQUIRES+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`10000` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-read-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-read-timeout[`quarkus.acm.async-client.read-timeout`]## + +[.description] +-- +The amount of time to wait for a read on a socket before an exception is thrown. + +Specify `0` to disable. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_READ_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_READ_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`30S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-write-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-write-timeout[`quarkus.acm.async-client.write-timeout`]## + +[.description] +-- +The amount of time to wait for a write on a socket before an exception is thrown. + +Specify `0` to disable. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_WRITE_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_WRITE_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`30S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-timeout[`quarkus.acm.async-client.connection-timeout`]## + +[.description] +-- +The amount of time to wait when initially establishing a connection before giving up and timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`10S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-acquisition-timeout]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-acquisition-timeout[`quarkus.acm.async-client.connection-acquisition-timeout`]## + +[.description] +-- +The amount of time to wait when acquiring a connection from the pool before giving up and timing out. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_ACQUISITION_TIMEOUT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_ACQUISITION_TIMEOUT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`2S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-time-to-live]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-time-to-live[`quarkus.acm.async-client.connection-time-to-live`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open, regardless of usage frequency. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIME_TO_LIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_TIME_TO_LIVE+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-connection-max-idle-time]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-connection-max-idle-time[`quarkus.acm.async-client.connection-max-idle-time`]## + +[.description] +-- +The maximum amount of time that a connection should be allowed to remain open while idle. + +Currently has no effect if `quarkus..async-client.use-idle-connection-reaper` is false. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_MAX_IDLE_TIME+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_CONNECTION_MAX_IDLE_TIME+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`5S` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-use-idle-connection-reaper]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-use-idle-connection-reaper[`quarkus.acm.async-client.use-idle-connection-reaper`]## + +[.description] +-- +Whether the idle connections in the connection pool should be closed. + +When enabled, connections left idling for longer than `quarkus..async-client.connection-max-idle-time` will be closed. This will not close connections currently in use. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_USE_IDLE_CONNECTION_REAPER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_USE_IDLE_CONNECTION_REAPER+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tcp-keep-alive]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tcp-keep-alive[`quarkus.acm.async-client.tcp-keep-alive`]## + +[.description] +-- +Configure whether to enable or disable TCP KeepAlive. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TCP_KEEP_ALIVE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TCP_KEEP_ALIVE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-protocol]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-protocol[`quarkus.acm.async-client.protocol`]## + +[.description] +-- +The HTTP protocol to use. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROTOCOL+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROTOCOL+++` +endif::add-copy-button-to-env-var[] +-- +a|`http1-1`, `http2` +|`http1-1` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-ssl-provider]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-ssl-provider[`quarkus.acm.async-client.ssl-provider`]## + +[.description] +-- +The SSL Provider to be used in the Netty client. + +Default is `OPENSSL` if available, `JDK` otherwise. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_SSL_PROVIDER+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_SSL_PROVIDER+++` +endif::add-copy-button-to-env-var[] +-- +a|`jdk`, `openssl`, `openssl-refcnt` +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-http2-max-streams]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-http2-max-streams[`quarkus.acm.async-client.http2.max-streams`]## + +[.description] +-- +The maximum number of concurrent streams for an HTTP/2 connection. + +This setting is only respected when the HTTP/2 protocol is used. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_MAX_STREAMS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_MAX_STREAMS+++` +endif::add-copy-button-to-env-var[] +-- +|long +|`4294967295` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-http2-initial-window-size]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-http2-initial-window-size[`quarkus.acm.async-client.http2.initial-window-size`]## + +[.description] +-- +The initial window size for an HTTP/2 stream. + +This setting is only respected when the HTTP/2 protocol is used. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_INITIAL_WINDOW_SIZE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_INITIAL_WINDOW_SIZE+++` +endif::add-copy-button-to-env-var[] +-- +|int +|`1048576` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-http2-health-check-ping-period]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-http2-health-check-ping-period[`quarkus.acm.async-client.http2.health-check-ping-period`]## + +[.description] +-- +Sets the period that the Netty client will send `PING` frames to the remote endpoint to check the health of the connection. To disable this feature, set a duration of 0. + +This setting is only respected when the HTTP/2 protocol is used. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_HEALTH_CHECK_PING_PERIOD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_HTTP2_HEALTH_CHECK_PING_PERIOD+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html[Duration] link:#duration-note-anchor-quarkus-amazon-acm_quarkus-acm[icon:question-circle[title=More information about the Duration format]] +|`5` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-proxy-enabled]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-proxy-enabled[`quarkus.acm.async-client.proxy.enabled`]## + +[.description] +-- +Enable HTTP proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENABLED+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENABLED+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-proxy-endpoint]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-proxy-endpoint[`quarkus.acm.async-client.proxy.endpoint`]## + +[.description] +-- +The endpoint of the proxy server that the SDK should connect through. + +Currently, the endpoint is limited to a host and port. Any other URI components will result in an exception being raised. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENDPOINT+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_ENDPOINT+++` +endif::add-copy-button-to-env-var[] +-- +|link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/URI.html[URI] +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-proxy-non-proxy-hosts]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-proxy-non-proxy-hosts[`quarkus.acm.async-client.proxy.non-proxy-hosts`]## + +[.description] +-- +The hosts that the client is allowed to access without going through the proxy. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_NON_PROXY_HOSTS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_PROXY_NON_PROXY_HOSTS+++` +endif::add-copy-button-to-env-var[] +-- +|list of string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-type[`quarkus.acm.async-client.tls-key-managers-provider.type`]## + +[.description] +-- +TLS key managers provider type. + +Available providers: + +* `none` - Use this provider if you don't want the client to present any certificates to the remote TLS host. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`none`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-path[`quarkus.acm.async-client.tls-key-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-type[`quarkus.acm.async-client.tls-key-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-key-managers-provider-file-store-password[`quarkus.acm.async-client.tls-key-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_KEY_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-type[`quarkus.acm.async-client.tls-trust-managers-provider.type`]## + +[.description] +-- +TLS trust managers provider type. + +Available providers: + +* `trust-all` - Use this provider to disable the validation of servers certificates and therefore trust all server certificates. +* `system-property` - Provider checks the standard `javax.net.ssl.keyStore`, `javax.net.ssl.keyStorePassword`, and + `javax.net.ssl.keyStoreType` properties defined by the + https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide.html[JSSE]. +* `file-store` - Provider that loads the key store from a file. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +a|`trust-all`, `system-property`, `file-store` +|`system-property` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-path]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-path[`quarkus.acm.async-client.tls-trust-managers-provider.file-store.path`]## + +[.description] +-- +Path to the key store. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PATH+++` +endif::add-copy-button-to-env-var[] +-- +|path +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-type]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-type[`quarkus.acm.async-client.tls-trust-managers-provider.file-store.type`]## + +[.description] +-- +Key store type. + +See the KeyStore section in the https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html++#++KeyStore++[++Java Cryptography Architecture Standard Algorithm Name Documentation++]++ for information about standard keystore types. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_TYPE+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-password]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-tls-trust-managers-provider-file-store-password[`quarkus.acm.async-client.tls-trust-managers-provider.file-store.password`]## + +[.description] +-- +Key store password + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_TLS_TRUST_MANAGERS_PROVIDER_FILE_STORE_PASSWORD+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-event-loop-override]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-event-loop-override[`quarkus.acm.async-client.event-loop.override`]## + +[.description] +-- +Enable the custom configuration of the Netty event loop group. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_OVERRIDE+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_OVERRIDE+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`false` + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-event-loop-number-of-threads]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-event-loop-number-of-threads[`quarkus.acm.async-client.event-loop.number-of-threads`]## + +[.description] +-- +Number of threads to use for the event loop group. + +If not set, the default Netty thread count is used (which is double the number of available processors unless the `io.netty.eventLoopThreads` system property is set. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_NUMBER_OF_THREADS+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_NUMBER_OF_THREADS+++` +endif::add-copy-button-to-env-var[] +-- +|int +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-event-loop-thread-name-prefix]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-event-loop-thread-name-prefix[`quarkus.acm.async-client.event-loop.thread-name-prefix`]## + +[.description] +-- +The thread name prefix for threads created by this thread factory used by event loop group. + +The prefix will be appended with a number unique to the thread factory and a number unique to the thread. + +If not specified it defaults to `aws-java-sdk-NettyEventLoop` + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_THREAD_NAME_PREFIX+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_EVENT_LOOP_THREAD_NAME_PREFIX+++` +endif::add-copy-button-to-env-var[] +-- +|string +| + +a| [[quarkus-amazon-acm_quarkus-acm-async-client-advanced-use-future-completion-thread-pool]] [.property-path]##link:#quarkus-amazon-acm_quarkus-acm-async-client-advanced-use-future-completion-thread-pool[`quarkus.acm.async-client.advanced.use-future-completion-thread-pool`]## + +[.description] +-- +Whether the default thread pool should be used to complete the futures returned from the HTTP client request. + +When disabled, futures will be completed on the Netty event loop thread. + + +ifdef::add-copy-button-to-env-var[] +Environment variable: env_var_with_copy_button:+++QUARKUS_ACM_ASYNC_CLIENT_ADVANCED_USE_FUTURE_COMPLETION_THREAD_POOL+++[] +endif::add-copy-button-to-env-var[] +ifndef::add-copy-button-to-env-var[] +Environment variable: `+++QUARKUS_ACM_ASYNC_CLIENT_ADVANCED_USE_FUTURE_COMPLETION_THREAD_POOL+++` +endif::add-copy-button-to-env-var[] +-- +|boolean +|`true` + + +|=== + +ifndef::no-duration-note[] +[NOTE] +[id=duration-note-anchor-quarkus-amazon-acm_quarkus-acm] +.About the Duration format +==== +To write duration values, use the standard `java.time.Duration` format. +See the link:https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/time/Duration.html#parse(java.lang.CharSequence)[Duration#parse() Java API documentation] for more information. + +You can also use a simplified format, starting with a number: + +* If the value is only a number, it represents time in seconds. +* If the value is a number followed by `ms`, it represents time in milliseconds. + +In other cases, the simplified format is translated to the `java.time.Duration` format for parsing: + +* If the value is a number followed by `h`, `m`, or `s`, it is prefixed with `PT`. +* If the value is a number followed by `d`, it is prefixed with `P`. +==== +endif::no-duration-note[] +ifndef::no-memory-size-note[] +[NOTE] +[id=memory-size-note-anchor-quarkus-amazon-acm_quarkus-acm] +.About the MemorySize format +==== +A size configuration option recognizes strings in this format (shown as a regular expression): `[0-9]+[KkMmGgTtPpEeZzYy]?`. + +If no suffix is given, assume bytes. +==== +ifndef::no-memory-size-note[] diff --git a/integration-tests/pom.xml b/integration-tests/pom.xml index abcae0c7e..e3fb34a43 100644 --- a/integration-tests/pom.xml +++ b/integration-tests/pom.xml @@ -28,6 +28,10 @@ <groupId>io.quarkus</groupId> <artifactId>quarkus-core</artifactId> </dependency> + <dependency> + <groupId>io.quarkiverse.amazonservices</groupId> + <artifactId>quarkus-amazon-acm</artifactId> + </dependency> <dependency> <groupId>io.quarkiverse.amazonservices</groupId> <artifactId>quarkus-amazon-cloudwatch</artifactId> diff --git a/integration-tests/src/main/java/io/quarkiverse/it/amazon/acm/AcmResource.java b/integration-tests/src/main/java/io/quarkiverse/it/amazon/acm/AcmResource.java new file mode 100644 index 000000000..6baf54f4a --- /dev/null +++ b/integration-tests/src/main/java/io/quarkiverse/it/amazon/acm/AcmResource.java @@ -0,0 +1,60 @@ +package io.quarkiverse.it.amazon.acm; + +import jakarta.inject.Inject; +import jakarta.ws.rs.GET; +import jakarta.ws.rs.Path; +import jakarta.ws.rs.Produces; +import org.jboss.logging.Logger; +import software.amazon.awssdk.services.acm.AcmAsyncClient; +import software.amazon.awssdk.services.acm.AcmClient; +import software.amazon.awssdk.services.acm.model.CertificateDetail; +import software.amazon.awssdk.services.acm.model.DescribeCertificateResponse; +import software.amazon.awssdk.services.acm.model.RequestCertificateResponse; + +import java.util.concurrent.CompletionStage; + +import static jakarta.ws.rs.core.MediaType.TEXT_PLAIN; + +@Path("/acm") +public class AcmResource { + + private static final Logger LOG = Logger.getLogger(AcmResource.class); + + private static final String DOMAIN_NAME = "quarkus.local"; + + @Inject + AcmClient acmClient; + + @Inject + AcmAsyncClient acmAsyncClient; + + @GET + @Path("sync") + @Produces(TEXT_PLAIN) + public String testSync() { + LOG.info("Testing Sync ACM client"); + // Request certificate + var arn = acmClient + .requestCertificate(r -> r.domainName(DOMAIN_NAME)) + .certificateArn(); + // Get domain name + return acmClient + .describeCertificate(r -> r.certificateArn(arn)) + .certificate() + .domainName(); + } + + @GET + @Path("async") + @Produces(TEXT_PLAIN) + public CompletionStage<String> testAsync() { + LOG.info("Testing Async ACM client"); + // Request certificate then get domain name + return acmAsyncClient + .requestCertificate(r -> r.domainName(DOMAIN_NAME)) + .thenApply(RequestCertificateResponse::certificateArn) + .thenCompose(arn -> acmAsyncClient.describeCertificate(r -> r.certificateArn(arn))) + .thenApply(DescribeCertificateResponse::certificate) + .thenApply(CertificateDetail::domainName); + } +} diff --git a/integration-tests/src/main/resources/application.properties b/integration-tests/src/main/resources/application.properties index dab77526a..753bf048f 100644 --- a/integration-tests/src/main/resources/application.properties +++ b/integration-tests/src/main/resources/application.properties @@ -10,6 +10,7 @@ quarkus.dynamodb.interceptors=io.quarkiverse.it.amazon.dynamodb.DynamoDBModifyRe quarkus.s3.interceptors=io.quarkiverse.it.amazon.s3.S3ModifyResponse quarkus.dynamodbenhanced.client-extensions=software.amazon.awssdk.enhanced.dynamodb.extensions.VersionedRecordExtension,io.quarkiverse.it.amazon.dynamodb.enhanced.MyExtension +quarkus.acm.sync-client.type=${sync-client.type} quarkus.cloudwatch.sync-client.type=${sync-client.type} quarkus.cloudwatchlogs.sync-client.type=${sync-client.type} quarkus.cognito-user-pools.sync-client.type=${sync-client.type} @@ -27,6 +28,7 @@ quarkus.sqs.sync-client.type=${sync-client.type} quarkus.ssm.sync-client.type=${sync-client.type} quarkus.sts.sync-client.type=${sync-client.type} quarkus.sfn.sync-client.type=${sync-client.type} +quarkus.acm.async-client.type=${async-client.type} quarkus.cloudwatch.async-client.type=${async-client.type} quarkus.cloudwatchlogs.async-client.type=${async-client.type} quarkus.cognito-user-pools.async-client.type=${async-client.type} diff --git a/integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmITCase.java b/integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmITCase.java new file mode 100644 index 000000000..05e7c4091 --- /dev/null +++ b/integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmITCase.java @@ -0,0 +1,8 @@ +package io.quarkiverse.it.amazon; + +import io.quarkus.test.junit.QuarkusIntegrationTest; + +@QuarkusIntegrationTest +public class AmazonAcmITCase extends AmazonAcmTest { + +} diff --git a/integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmTest.java b/integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmTest.java new file mode 100644 index 000000000..4da1bc982 --- /dev/null +++ b/integration-tests/src/test/java/io/quarkiverse/it/amazon/AmazonAcmTest.java @@ -0,0 +1,21 @@ +package io.quarkiverse.it.amazon; + +import io.quarkus.test.junit.QuarkusTest; +import io.restassured.RestAssured; +import org.junit.jupiter.api.Test; + +import static org.hamcrest.Matchers.is; + +@QuarkusTest +public class AmazonAcmTest { + + @Test + public void testAcmAsync() { + RestAssured.when().get("/test/acm/async").then().body(is("quarkus.local")); + } + + @Test + public void testAcmSync() { + RestAssured.when().get("/test/acm/sync").then().body(is("quarkus.local")); + } +} diff --git a/pom.xml b/pom.xml index 394a2628b..09c72cb40 100644 --- a/pom.xml +++ b/pom.xml @@ -17,6 +17,7 @@ <module>crt</module> <module>common</module> <module>devservices</module> + <module>acm</module> <module>apigatewaymanagementapi</module> <module>cloudwatch</module> <module>cloudwatchlogs</module>