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

acosentino pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/camel.git


The following commit(s) were added to refs/heads/main by this push:
     new d0fd1bbc807 CAMEL-21262 - Camel-AWS2-S3: Explicitly add Producer 
operations HeadObject and HeadBucket (#15902)
d0fd1bbc807 is described below

commit d0fd1bbc807ac882a5dd39dddb7112cb458e4bc0
Author: Andrea Cosentino <[email protected]>
AuthorDate: Wed Oct 9 16:25:57 2024 +0200

    CAMEL-21262 - Camel-AWS2-S3: Explicitly add Producer operations HeadObject 
and HeadBucket (#15902)
    
    * CAMEL-21262 - Camel-AWS2-S3: Explicitly add Producer operations 
HeadObject and HeadBucket - HeadBucket
    
    Signed-off-by: Andrea Cosentino <[email protected]>
    
    * CAMEL-21262 - Camel-AWS2-S3: Explicitly add Producer operations 
HeadObject and HeadBucket - HeadObject
    
    Signed-off-by: Andrea Cosentino <[email protected]>
    
    ---------
    
    Signed-off-by: Andrea Cosentino <[email protected]>
---
 .../camel/component/aws2/s3/AWS2S3Operations.java  |  4 +-
 .../camel/component/aws2/s3/AWS2S3Producer.java    | 55 +++++++++-------
 .../aws2/s3/integration/S3HeadBucketIT.java        | 59 +++++++++++++++++
 .../aws2/s3/integration/S3HeadObjectIT.java        | 73 ++++++++++++++++++++++
 4 files changed, 167 insertions(+), 24 deletions(-)

diff --git 
a/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Operations.java
 
b/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Operations.java
index 0b723b18958..b4e12b1ef85 100644
--- 
a/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Operations.java
+++ 
b/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Operations.java
@@ -25,5 +25,7 @@ public enum AWS2S3Operations {
     listBuckets,
     getObject,
     getObjectRange,
-    createDownloadLink
+    createDownloadLink,
+    headBucket,
+    headObject
 }
diff --git 
a/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Producer.java
 
b/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Producer.java
index 368875fb0f3..b7edba14061 100644
--- 
a/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Producer.java
+++ 
b/components/camel-aws/camel-aws2-s3/src/main/java/org/apache/camel/component/aws2/s3/AWS2S3Producer.java
@@ -49,29 +49,7 @@ import software.amazon.awssdk.core.sync.RequestBody;
 import software.amazon.awssdk.core.sync.ResponseTransformer;
 import software.amazon.awssdk.regions.Region;
 import software.amazon.awssdk.services.s3.S3Client;
-import software.amazon.awssdk.services.s3.model.AbortMultipartUploadRequest;
-import software.amazon.awssdk.services.s3.model.BucketCannedACL;
-import software.amazon.awssdk.services.s3.model.CompleteMultipartUploadRequest;
-import 
software.amazon.awssdk.services.s3.model.CompleteMultipartUploadResponse;
-import software.amazon.awssdk.services.s3.model.CompletedMultipartUpload;
-import software.amazon.awssdk.services.s3.model.CompletedPart;
-import software.amazon.awssdk.services.s3.model.CopyObjectRequest;
-import software.amazon.awssdk.services.s3.model.CopyObjectResponse;
-import software.amazon.awssdk.services.s3.model.CreateMultipartUploadRequest;
-import software.amazon.awssdk.services.s3.model.CreateMultipartUploadResponse;
-import software.amazon.awssdk.services.s3.model.DeleteBucketRequest;
-import software.amazon.awssdk.services.s3.model.DeleteBucketResponse;
-import software.amazon.awssdk.services.s3.model.DeleteObjectRequest;
-import software.amazon.awssdk.services.s3.model.GetObjectRequest;
-import software.amazon.awssdk.services.s3.model.GetObjectResponse;
-import software.amazon.awssdk.services.s3.model.ListBucketsResponse;
-import software.amazon.awssdk.services.s3.model.ListObjectsRequest;
-import software.amazon.awssdk.services.s3.model.ListObjectsResponse;
-import software.amazon.awssdk.services.s3.model.ObjectCannedACL;
-import software.amazon.awssdk.services.s3.model.PutObjectRequest;
-import software.amazon.awssdk.services.s3.model.PutObjectResponse;
-import software.amazon.awssdk.services.s3.model.ServerSideEncryption;
-import software.amazon.awssdk.services.s3.model.UploadPartRequest;
+import software.amazon.awssdk.services.s3.model.*;
 import software.amazon.awssdk.services.s3.presigner.S3Presigner;
 import 
software.amazon.awssdk.services.s3.presigner.model.GetObjectPresignRequest;
 import 
software.amazon.awssdk.services.s3.presigner.model.PresignedGetObjectRequest;
@@ -123,6 +101,12 @@ public class AWS2S3Producer extends DefaultProducer {
                 case createDownloadLink:
                     createDownloadLink(exchange);
                     break;
+                case headBucket:
+                    headBucket(getEndpoint().getS3Client(), exchange);
+                    break;
+                case headObject:
+                    headObject(getEndpoint().getS3Client(), exchange);
+                    break;
                 default:
                     throw new IllegalArgumentException("Unsupported 
operation");
             }
@@ -719,6 +703,31 @@ public class AWS2S3Producer extends DefaultProducer {
         }
     }
 
+    private void headBucket(S3Client s3Client, Exchange exchange) {
+        String bucketName = 
exchange.getIn().getHeader(AWS2S3Constants.BUCKET_NAME, String.class);
+        if (ObjectHelper.isEmpty(bucketName)) {
+            throw new IllegalArgumentException(
+                    "Head Bucket operation requires to specify a bucket name 
via Header");
+        }
+        HeadBucketResponse headBucketResponse = 
s3Client.headBucket(HeadBucketRequest.builder().bucket(bucketName).build());
+
+        Message message = getMessageForResponse(exchange);
+        message.setBody(headBucketResponse);
+    }
+
+    private void headObject(S3Client s3Client, Exchange exchange) {
+        String key = exchange.getIn().getHeader(AWS2S3Constants.KEY, 
String.class);
+        if (ObjectHelper.isEmpty(key)) {
+            throw new IllegalArgumentException(
+                    "Head Object operation requires to specify a bucket name 
via Header");
+        }
+        HeadObjectResponse headObjectResponse = 
s3Client.headObject(HeadObjectRequest.builder()
+                .bucket(AWS2S3Utils.determineBucketName(exchange, 
getConfiguration())).key(key).build());
+
+        Message message = getMessageForResponse(exchange);
+        message.setBody(headObjectResponse);
+    }
+
     private AWS2S3Operations determineOperation(Exchange exchange) {
         AWS2S3Operations operation = 
exchange.getIn().getHeader(AWS2S3Constants.S3_OPERATION, 
AWS2S3Operations.class);
         if (operation == null) {
diff --git 
a/components/camel-aws/camel-aws2-s3/src/test/java/org/apache/camel/component/aws2/s3/integration/S3HeadBucketIT.java
 
b/components/camel-aws/camel-aws2-s3/src/test/java/org/apache/camel/component/aws2/s3/integration/S3HeadBucketIT.java
new file mode 100644
index 00000000000..4bc0b7427c9
--- /dev/null
+++ 
b/components/camel-aws/camel-aws2-s3/src/test/java/org/apache/camel/component/aws2/s3/integration/S3HeadBucketIT.java
@@ -0,0 +1,59 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.aws2.s3.integration;
+
+import org.apache.camel.EndpointInject;
+import org.apache.camel.ProducerTemplate;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.aws2.s3.AWS2S3Constants;
+import org.apache.camel.component.aws2.s3.AWS2S3Operations;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.junit.jupiter.api.Test;
+
+public class S3HeadBucketIT extends Aws2S3Base {
+
+    @EndpointInject
+    private ProducerTemplate template;
+
+    @EndpointInject("mock:result")
+    private MockEndpoint result;
+
+    @Test
+    public void sendInHeadBucket() throws InterruptedException {
+        result.expectedMessageCount(1);
+
+        template.send("direct:headBucket", exchange -> {
+            exchange.getIn().setHeader(AWS2S3Constants.S3_OPERATION, 
AWS2S3Operations.headBucket);
+            exchange.getIn().setHeader(AWS2S3Constants.BUCKET_NAME, "mycamel");
+        });
+
+        result.assertIsSatisfied();
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() {
+        return new RouteBuilder() {
+            @Override
+            public void configure() {
+                String awsEndpoint = "aws2-s3://test-ss3-s3";
+
+                
from("direct:headBucket").to(awsEndpoint).log("${body}").to("mock:result");
+
+            }
+        };
+    }
+}
diff --git 
a/components/camel-aws/camel-aws2-s3/src/test/java/org/apache/camel/component/aws2/s3/integration/S3HeadObjectIT.java
 
b/components/camel-aws/camel-aws2-s3/src/test/java/org/apache/camel/component/aws2/s3/integration/S3HeadObjectIT.java
new file mode 100644
index 00000000000..34b170f3d69
--- /dev/null
+++ 
b/components/camel-aws/camel-aws2-s3/src/test/java/org/apache/camel/component/aws2/s3/integration/S3HeadObjectIT.java
@@ -0,0 +1,73 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.aws2.s3.integration;
+
+import org.apache.camel.EndpointInject;
+import org.apache.camel.Exchange;
+import org.apache.camel.Processor;
+import org.apache.camel.ProducerTemplate;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.aws2.s3.AWS2S3Constants;
+import org.apache.camel.component.aws2.s3.AWS2S3Operations;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.junit.jupiter.api.Test;
+
+public class S3HeadObjectIT extends Aws2S3Base {
+
+    @EndpointInject
+    private ProducerTemplate template;
+
+    @EndpointInject("mock:result")
+    private MockEndpoint result;
+
+    @Test
+    public void sendInHeadObject() throws InterruptedException {
+        result.expectedMessageCount(1);
+
+        template.send("direct:putObject", new Processor() {
+
+            @Override
+            public void process(Exchange exchange) {
+                exchange.getIn().setHeader(AWS2S3Constants.KEY, "camel.txt");
+                exchange.getIn().setHeader(AWS2S3Constants.CONTENT_TYPE, 
"application/text");
+                exchange.getIn().setBody("Camel rocks!");
+            }
+        });
+
+        template.send("direct:headObject", exchange -> {
+            exchange.getIn().setHeader(AWS2S3Constants.S3_OPERATION, 
AWS2S3Operations.headObject);
+            exchange.getIn().setHeader(AWS2S3Constants.KEY, "camel.txt");
+        });
+
+        result.assertIsSatisfied();
+    }
+
+    @Override
+    protected RouteBuilder createRouteBuilder() {
+        return new RouteBuilder() {
+            @Override
+            public void configure() {
+                String awsEndpoint = "aws2-s3://" + name.get();
+                String awsEndpointCreate = "aws2-s3://" + name.get() + 
"?autoCreateBucket=true";
+
+                from("direct:putObject").to(awsEndpointCreate);
+                
from("direct:headObject").to(awsEndpoint).log("${body}").to("mock:result");
+
+            }
+        };
+    }
+}

Reply via email to