From 59e23147ba6be742b0865b91314a45c773838a40 Mon Sep 17 00:00:00 2001 From: Georgios Andrianakis Date: Tue, 17 Oct 2023 11:05:33 +0300 Subject: [PATCH] Allow for setting logging scope programmatically Without this change, the logger that can be provided programmatically is totally useful unless the user also configures a Quarkus config property. This change allows for logging to actually be useful in a programmatically created client --- .../reactive/QuarkusRestClientBuilder.java | 9 +++++++++ .../runtime/QuarkusRestClientBuilderImpl.java | 7 +++++++ .../reactive/runtime/RestClientBuilderImpl.java | 17 ++++++++++++++--- 3 files changed, 30 insertions(+), 3 deletions(-) diff --git a/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/QuarkusRestClientBuilder.java b/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/QuarkusRestClientBuilder.java index 16fbd147b69b6..db7ca2d7525a7 100644 --- a/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/QuarkusRestClientBuilder.java +++ b/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/QuarkusRestClientBuilder.java @@ -17,6 +17,7 @@ import org.eclipse.microprofile.rest.client.ext.QueryParamStyle; import org.eclipse.microprofile.rest.client.spi.RestClientBuilderListener; import org.jboss.resteasy.reactive.client.api.ClientLogger; +import org.jboss.resteasy.reactive.client.api.LoggingScope; import io.quarkus.rest.client.reactive.runtime.QuarkusRestClientBuilderImpl; import io.quarkus.rest.client.reactive.runtime.RestClientBuilderImpl; @@ -259,6 +260,14 @@ static QuarkusRestClientBuilder newBuilder() { */ QuarkusRestClientBuilder clientLogger(ClientLogger clientLogger); + /** + * Specifies the client logger to use. + * + * @param loggingScope to use + * @return the current builder + */ + QuarkusRestClientBuilder loggingScope(LoggingScope loggingScope); + /** * Based on the configured QuarkusRestClientBuilder, creates a new instance of the given REST interface to invoke API calls * against. diff --git a/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/QuarkusRestClientBuilderImpl.java b/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/QuarkusRestClientBuilderImpl.java index 50bb3bfc17309..a47c4fba20124 100644 --- a/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/QuarkusRestClientBuilderImpl.java +++ b/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/QuarkusRestClientBuilderImpl.java @@ -15,6 +15,7 @@ import org.eclipse.microprofile.rest.client.ext.ClientHeadersFactory; import org.eclipse.microprofile.rest.client.ext.QueryParamStyle; import org.jboss.resteasy.reactive.client.api.ClientLogger; +import org.jboss.resteasy.reactive.client.api.LoggingScope; import io.quarkus.rest.client.reactive.QuarkusRestClientBuilder; import io.quarkus.rest.client.reactive.runtime.context.ClientHeadersFactoryContextResolver; @@ -224,6 +225,12 @@ public QuarkusRestClientBuilder clientLogger(ClientLogger clientLogger) { return this; } + @Override + public QuarkusRestClientBuilder loggingScope(LoggingScope loggingScope) { + proxy.loggingScope(loggingScope); + return this; + } + @Override public T build(Class clazz) throws IllegalStateException, RestClientDefinitionException { return proxy.build(clazz); diff --git a/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/RestClientBuilderImpl.java b/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/RestClientBuilderImpl.java index 680b9f0c89692..a6e1c152ec0a5 100644 --- a/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/RestClientBuilderImpl.java +++ b/extensions/resteasy-reactive/rest-client-reactive/runtime/src/main/java/io/quarkus/rest/client/reactive/runtime/RestClientBuilderImpl.java @@ -70,6 +70,7 @@ public class RestClientBuilderImpl implements RestClientBuilder { private String nonProxyHosts; private ClientLogger clientLogger; + private LoggingScope loggingScope; @Override public RestClientBuilderImpl baseUrl(URL url) { @@ -167,6 +168,11 @@ public RestClientBuilderImpl clientLogger(ClientLogger clientLogger) { return this; } + public RestClientBuilderImpl loggingScope(LoggingScope loggingScope) { + this.loggingScope = loggingScope; + return this; + } + @Override public RestClientBuilderImpl executorService(ExecutorService executor) { throw new IllegalArgumentException("Specifying executor service is not supported. " + @@ -333,10 +339,15 @@ public T build(Class aClass) throws IllegalStateException, RestClientDefi RestClientsConfig restClientsConfig = arcContainer.instance(RestClientsConfig.class).get(); RestClientLoggingConfig logging = restClientsConfig.logging; - LoggingScope loggingScope = logging != null ? logging.scope.map(LoggingScope::forName).orElse(LoggingScope.NONE) - : LoggingScope.NONE; + + LoggingScope effectiveLoggingScope = loggingScope; // if a scope was specified programmatically, it takes precedence + if (effectiveLoggingScope == null) { + effectiveLoggingScope = logging != null ? logging.scope.map(LoggingScope::forName).orElse(LoggingScope.NONE) + : LoggingScope.NONE; + } + Integer loggingBodySize = logging != null ? logging.bodyLimit : 100; - clientBuilder.loggingScope(loggingScope); + clientBuilder.loggingScope(effectiveLoggingScope); clientBuilder.loggingBodySize(loggingBodySize); if (clientLogger != null) { clientBuilder.clientLogger(clientLogger);