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

davsclaus pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/camel-spring-boot.git


The following commit(s) were added to refs/heads/main by this push:
     new 0518f4f  CAMEL-16950: camel-servlet-starter doesn't support multipart 
requests (#367)
0518f4f is described below

commit 0518f4f6939c76334080f205b20b4430558f8b2e
Author: avi5kdon <avi5k...@gmail.com>
AuthorDate: Sat Sep 18 13:45:32 2021 +0530

    CAMEL-16950: camel-servlet-starter doesn't support multipart requests (#367)
---
 .../src/main/docs/servlet-starter.adoc             |  3 +
 .../ServletMappingAutoConfiguration.java           |  9 ++-
 .../springboot/test/ServletMultiPartTest.java      | 79 ++++++++++++++++++++++
 3 files changed, 88 insertions(+), 3 deletions(-)

diff --git 
a/components-starter/camel-servlet-starter/src/main/docs/servlet-starter.adoc 
b/components-starter/camel-servlet-starter/src/main/docs/servlet-starter.adoc
index 869e4dd..2af428e 100644
--- 
a/components-starter/camel-servlet-starter/src/main/docs/servlet-starter.adoc
+++ 
b/components-starter/camel-servlet-starter/src/main/docs/servlet-starter.adoc
@@ -40,3 +40,6 @@ The component supports 14 options, which are listed below.
 | *camel.servlet.mapping.servlet-name* | The name of the Camel servlet. | 
CamelServlet | String
 |===
 // spring-boot-auto-configure options: END
+
+==== Advance Multipart configuration
+The multipart configuration is enabled by default. It is inherited from spring 
servlet's 
https://docs.spring.io/spring-boot/docs/current/api/org/springframework/boot/autoconfigure/web/servlet/MultipartProperties.html[multipart
 properties] which can be used for further customization.
diff --git 
a/components-starter/camel-servlet-starter/src/main/java/org/apache/camel/component/servlet/springboot/ServletMappingAutoConfiguration.java
 
b/components-starter/camel-servlet-starter/src/main/java/org/apache/camel/component/servlet/springboot/ServletMappingAutoConfiguration.java
index dce472c..08b1d78 100644
--- 
a/components-starter/camel-servlet-starter/src/main/java/org/apache/camel/component/servlet/springboot/ServletMappingAutoConfiguration.java
+++ 
b/components-starter/camel-servlet-starter/src/main/java/org/apache/camel/component/servlet/springboot/ServletMappingAutoConfiguration.java
@@ -24,6 +24,7 @@ import 
org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
 import 
org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import 
org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication;
+import org.springframework.boot.autoconfigure.web.servlet.MultipartProperties;
 import 
org.springframework.boot.context.properties.EnableConfigurationProperties;
 import org.springframework.boot.web.servlet.ServletRegistrationBean;
 import org.springframework.context.annotation.Bean;
@@ -38,17 +39,19 @@ import org.springframework.context.annotation.Lazy;
 @ConditionalOnBean(type = 
"org.apache.camel.spring.boot.CamelAutoConfiguration")
 @AutoConfigureAfter(name = 
"org.apache.camel.spring.boot.CamelAutoConfiguration")
 @ConditionalOnWebApplication
-@EnableConfigurationProperties(ServletMappingConfiguration.class)
+@EnableConfigurationProperties({ServletMappingConfiguration.class, 
MultipartProperties.class})
 public class ServletMappingAutoConfiguration {
 
     @Bean
-    ServletRegistrationBean 
camelServletRegistrationBean(ServletMappingConfiguration config) {
+    ServletRegistrationBean 
camelServletRegistrationBean(ServletMappingConfiguration config, 
MultipartProperties multipartProperties) {
         ServletRegistrationBean mapping = new ServletRegistrationBean();
         mapping.setServlet(new CamelHttpTransportServlet());
         mapping.addUrlMappings(config.getContextPath());
         mapping.setName(config.getServletName());
         mapping.setLoadOnStartup(1);
-
+        if (multipartProperties != null && multipartProperties.getEnabled()){
+            
mapping.setMultipartConfig(multipartProperties.createMultipartConfig());
+        }
         return mapping;
     }
 
diff --git 
a/components-starter/camel-servlet-starter/src/test/java/org/apache/camel/component/servlet/springboot/test/ServletMultiPartTest.java
 
b/components-starter/camel-servlet-starter/src/test/java/org/apache/camel/component/servlet/springboot/test/ServletMultiPartTest.java
new file mode 100644
index 0000000..1f92c73
--- /dev/null
+++ 
b/components-starter/camel-servlet-starter/src/test/java/org/apache/camel/component/servlet/springboot/test/ServletMultiPartTest.java
@@ -0,0 +1,79 @@
+/*
+ * 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.servlet.springboot.test;
+
+import org.apache.camel.CamelContext;
+import org.apache.camel.builder.RouteBuilder;
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.test.context.SpringBootTest;
+import org.springframework.boot.test.web.client.TestRestTemplate;
+import org.springframework.http.HttpEntity;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.MediaType;
+import org.springframework.test.annotation.DirtiesContext;
+import org.springframework.test.context.ContextConfiguration;
+import org.springframework.test.context.junit4.SpringRunner;
+import org.springframework.util.LinkedMultiValueMap;
+
+import javax.servlet.http.HttpServletRequest;
+
+/**
+ * Testing multipart processing with camel servlet
+ */
+@RunWith(SpringRunner.class)
+@SpringBootApplication
+@DirtiesContext
+@ContextConfiguration(classes = ServletMultiPartTest.class)
+@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT)
+public class ServletMultiPartTest {
+
+    @Autowired
+    private TestRestTemplate restTemplate;
+
+    @Autowired
+    private CamelContext context;
+
+    @Before
+    public void setup() throws Exception {
+        context.addRoutes(new RouteBuilder() {
+            @Override
+            public void configure() {
+                from("servlet:/test?disableStreamCache=true")
+                        .process(exchange -> {
+                            HttpServletRequest httpServletRequest = 
exchange.getIn().getBody(HttpServletRequest.class);
+                            
exchange.getIn().setBody(httpServletRequest.getPart("file").getName());
+                        });
+                    }
+                 });
+              }
+    @Test
+    public void testMultipartRequest() throws Exception {
+        HttpHeaders httpHeaders = new HttpHeaders();
+        httpHeaders.setContentType(MediaType.MULTIPART_FORM_DATA);
+        LinkedMultiValueMap<String, Object> message = new 
LinkedMultiValueMap<>();
+        message.add("file","Multipart Test");
+        HttpEntity<LinkedMultiValueMap<String, Object>> httpEntity = new 
HttpEntity<>(message,httpHeaders);
+        Assert.assertEquals("file", 
restTemplate.postForEntity("/camel/test",httpEntity,String.class).getBody());
+    }
+
+}
+

Reply via email to