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";
+    }
 }

Reply via email to