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 <[email protected]>
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());
+ }
+
+}
+