This is an automated email from the ASF dual-hosted git repository. acosentino pushed a commit to branch CAMEL-20798-AWS-full in repository https://gitbox.apache.org/repos/asf/camel.git
commit aae7ea7ba2fbc1bd1bdcfc52a6df93aef055a156 Author: Andrea Cosentino <anco...@gmail.com> AuthorDate: Tue Jun 11 11:50:21 2024 +0200 CAMEL-20798: EndpointServiceLocation on components to make it possible to know which remote system Camel connects to to assist for monitoring and observability - AWS Secrets Manager Signed-off-by: Andrea Cosentino <anco...@gmail.com> --- .../aws/secretsmanager/SecretsManagerEndpoint.java | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/components/camel-aws/camel-aws-secrets-manager/src/main/java/org/apache/camel/component/aws/secretsmanager/SecretsManagerEndpoint.java b/components/camel-aws/camel-aws-secrets-manager/src/main/java/org/apache/camel/component/aws/secretsmanager/SecretsManagerEndpoint.java index 126712b1456..36305267539 100644 --- a/components/camel-aws/camel-aws-secrets-manager/src/main/java/org/apache/camel/component/aws/secretsmanager/SecretsManagerEndpoint.java +++ b/components/camel-aws/camel-aws-secrets-manager/src/main/java/org/apache/camel/component/aws/secretsmanager/SecretsManagerEndpoint.java @@ -22,6 +22,7 @@ import org.apache.camel.Consumer; import org.apache.camel.Processor; import org.apache.camel.Producer; import org.apache.camel.component.aws.secretsmanager.client.SecretsManagerClientFactory; +import org.apache.camel.spi.EndpointServiceLocation; import org.apache.camel.spi.Metadata; import org.apache.camel.spi.UriEndpoint; import org.apache.camel.spi.UriParam; @@ -38,7 +39,7 @@ import software.amazon.awssdk.services.secretsmanager.SecretsManagerClient; @Metadata(annotations = { "vault=aws-secrets-manager", }) -public class SecretsManagerEndpoint extends ScheduledPollEndpoint { +public class SecretsManagerEndpoint extends ScheduledPollEndpoint implements EndpointServiceLocation { private SecretsManagerClient secretsManagerClient; @@ -91,4 +92,21 @@ public class SecretsManagerEndpoint extends ScheduledPollEndpoint { public SecretsManagerClient getSecretsManagerClient() { return secretsManagerClient; } + + @Override + public String getServiceUrl() { + if (!configuration.isOverrideEndpoint()) { + if (ObjectHelper.isNotEmpty(configuration.getRegion())) { + return configuration.getRegion(); + } + } else if (ObjectHelper.isNotEmpty(configuration.getUriEndpointOverride())) { + return configuration.getUriEndpointOverride(); + } + return null; + } + + @Override + public String getServiceProtocol() { + return "secrets-manager"; + } }