This is an automated email from the ASF dual-hosted git repository.

acosentino pushed a commit to branch CAMEL-20798-AWS-complete
in repository https://gitbox.apache.org/repos/asf/camel.git

commit 8b9408d97cf33f0f5bd4178da1fb81459143d554
Author: Andrea Cosentino <[email protected]>
AuthorDate: Tue Jun 18 10:27:18 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 MSK
    
    Signed-off-by: Andrea Cosentino <[email protected]>
---
 .../camel/component/aws2/msk/MSK2Endpoint.java       | 20 +++++++++++++++++++-
 1 file changed, 19 insertions(+), 1 deletion(-)

diff --git 
a/components/camel-aws/camel-aws2-msk/src/main/java/org/apache/camel/component/aws2/msk/MSK2Endpoint.java
 
b/components/camel-aws/camel-aws2-msk/src/main/java/org/apache/camel/component/aws2/msk/MSK2Endpoint.java
index ee7d7625ce5..0b739c572c2 100644
--- 
a/components/camel-aws/camel-aws2-msk/src/main/java/org/apache/camel/component/aws2/msk/MSK2Endpoint.java
+++ 
b/components/camel-aws/camel-aws2-msk/src/main/java/org/apache/camel/component/aws2/msk/MSK2Endpoint.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.aws2.msk.client.MSK2ClientFactory;
+import org.apache.camel.spi.EndpointServiceLocation;
 import org.apache.camel.spi.UriEndpoint;
 import org.apache.camel.spi.UriParam;
 import org.apache.camel.support.ScheduledPollEndpoint;
@@ -34,7 +35,7 @@ import software.amazon.awssdk.services.kafka.KafkaClient;
 @UriEndpoint(firstVersion = "3.1.0", scheme = "aws2-msk", title = "AWS Managed 
Streaming for Apache Kafka (MSK)",
              syntax = "aws2-msk:label", producerOnly = true, category = { 
Category.CLOUD, Category.MANAGEMENT },
              headersClass = MSK2Constants.class)
-public class MSK2Endpoint extends ScheduledPollEndpoint {
+public class MSK2Endpoint extends ScheduledPollEndpoint implements 
EndpointServiceLocation {
 
     private KafkaClient mskClient;
 
@@ -87,4 +88,21 @@ public class MSK2Endpoint extends ScheduledPollEndpoint {
     public KafkaClient getMskClient() {
         return mskClient;
     }
+
+    @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 "msk";
+    }
 }

Reply via email to