Hi Claus,

Thanks for the review, I just update the code by removing the try ... catch codes.

On Thu Jun 14 11:34:45 2012, Claus Ibsen wrote:
Hi

In the converter code, you do a try .. catch and then swallow the caused
exception.
You should not do this, but throw the exception. And remove the logging.


On Wed, Jun 13, 2012 at 5:20 PM,<ningji...@apache.org>  wrote:

Author: ningjiang
Date: Wed Jun 13 15:20:35 2012
New Revision: 1349901

URL: http://svn.apache.org/viewvc?rev=1349901&view=rev
Log:
CAMEL-5365 Added SOAPMessage to InputStream coverter

Added:

  
camel/trunk/components/camel-cxf/src/test/resources/org/apache/camel/component/cxf/SoapMessageProviderStreamContext.xml
Modified:

  
camel/trunk/components/camel-cxf/src/main/java/org/apache/camel/component/cxf/converter/CxfConverter.java

  
camel/trunk/components/camel-cxf/src/test/java/org/apache/camel/component/cxf/SoapTargetBean.java

Modified:
camel/trunk/components/camel-cxf/src/main/java/org/apache/camel/component/cxf/converter/CxfConverter.java
URL:
http://svn.apache.org/viewvc/camel/trunk/components/camel-cxf/src/main/java/org/apache/camel/component/cxf/converter/CxfConverter.java?rev=1349901&r1=1349900&r2=1349901&view=diff

==============================================================================
---
camel/trunk/components/camel-cxf/src/main/java/org/apache/camel/component/cxf/converter/CxfConverter.java
(original)
+++
camel/trunk/components/camel-cxf/src/main/java/org/apache/camel/component/cxf/converter/CxfConverter.java
Wed Jun 13 15:20:35 2012
@@ -28,6 +28,7 @@ import org.apache.camel.Exchange;
  import org.apache.camel.FallbackConverter;
  import org.apache.camel.TypeConverter;
  import org.apache.camel.component.cxf.DataFormat;
+import org.apache.camel.converter.stream.CachedOutputStream;
  import org.apache.camel.spi.TypeConverterRegistry;
  import org.apache.cxf.message.MessageContentsList;
  import org.slf4j.Logger;
@@ -89,6 +90,19 @@ public final class CxfConverter {
     }

     @Converter
+    public static InputStream soapMessageToInputStream(final SOAPMessage
soapMessage, Exchange exchange) {
+        CachedOutputStream cos = new CachedOutputStream(exchange);
+        InputStream in = null;
+        try {
+            soapMessage.writeTo(cos);
+            in = cos.getInputStream();
+        } catch (Exception e) {
+            LOG.error("Get the exception when converting the SOAPMessage
into InputStream, the exception is " + e);
+        }
+        return in;
+    }
+
+    @Converter
     public static DataFormat toDataFormat(final String name) {
         return DataFormat.valueOf(name.toUpperCase());
     }

Modified:
camel/trunk/components/camel-cxf/src/test/java/org/apache/camel/component/cxf/SoapTargetBean.java
URL:
http://svn.apache.org/viewvc/camel/trunk/components/camel-cxf/src/test/java/org/apache/camel/component/cxf/SoapTargetBean.java?rev=1349901&r1=1349900&r2=1349901&view=diff

==============================================================================
---
camel/trunk/components/camel-cxf/src/test/java/org/apache/camel/component/cxf/SoapTargetBean.java
(original)
+++
camel/trunk/components/camel-cxf/src/test/java/org/apache/camel/component/cxf/SoapTargetBean.java
Wed Jun 13 15:20:35 2012
@@ -23,11 +23,14 @@ import javax.xml.soap.MessageFactory;
  import javax.xml.soap.SOAPBody;
  import javax.xml.soap.SOAPMessage;

+import org.w3c.dom.Document;
  import org.w3c.dom.Node;

+import org.apache.cxf.helpers.XMLUtils;
+
  public class SoapTargetBean {
-    private static QName sayHi = new QName("
http://apache.org/hello_world_soap_http";, "sayHi");
-    private static QName greetMe = new QName("
http://apache.org/hello_world_soap_http";, "greetMe");
+    private static QName sayHi = new QName("
http://apache.org/hello_world_soap_http/types";, "sayHi");
+    private static QName greetMe = new QName("
http://apache.org/hello_world_soap_http/types";, "greetMe");
     private SOAPMessage sayHiResponse;
     private SOAPMessage greetMeResponse;

@@ -76,4 +79,21 @@ public class SoapTargetBean {
         return response;
     }

+    //Simulates a stream based processor or producer (e.g., file EP)
+    public SOAPMessage invokeStream(InputStream in) {
+        SOAPMessage response = null;
+        try {
+            Document doc = XMLUtils.parse(in);
+            if (doc.getElementsByTagNameNS(greetMe.getNamespaceURI(),
+
sayHi.getLocalPart()).getLength() == 1) {
+                response = sayHiResponse;
+            } else if
(doc.getElementsByTagNameNS(greetMe.getNamespaceURI(),
+
  greetMe.getLocalPart()).getLength() == 1) {
+                response = greetMeResponse;
+            }
+        } catch (Exception ex) {
+            ex.printStackTrace();
+        }
+        return response;
+    }
  }

Added:
camel/trunk/components/camel-cxf/src/test/resources/org/apache/camel/component/cxf/SoapMessageProviderStreamContext.xml
URL:
http://svn.apache.org/viewvc/camel/trunk/components/camel-cxf/src/test/resources/org/apache/camel/component/cxf/SoapMessageProviderStreamContext.xml?rev=1349901&view=auto

==============================================================================
---
camel/trunk/components/camel-cxf/src/test/resources/org/apache/camel/component/cxf/SoapMessageProviderStreamContext.xml
(added)
+++
camel/trunk/components/camel-cxf/src/test/resources/org/apache/camel/component/cxf/SoapMessageProviderStreamContext.xml
Wed Jun 13 15:20:35 2012
@@ -0,0 +1,52 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+    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.
+-->
+<beans xmlns="http://www.springframework.org/schema/beans";
+       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance";
+       xmlns:cxf="http://camel.apache.org/schema/cxf";
+       xsi:schemaLocation="
+       http://www.springframework.org/schema/beans
+       http://www.springframework.org/schema/beans/spring-beans.xsd
+       http://camel.apache.org/schema/cxf
http://camel.apache.org/schema/cxf/camel-cxf.xsd
+       http://camel.apache.org/schema/spring
http://camel.apache.org/schema/spring/camel-spring.xsd
+    ">
+
+<bean
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
+
+<!--
+    If you want to run this example in Tomcat container which need to
used servlet transoprt,
+    please repalce the cxf-extension-http-jetty.xml with cxf-servlet.xml
+    -->
+
+<import resource="classpath:META-INF/cxf/cxf.xml"/>
+
+<bean id = "targetBean"
class="org.apache.camel.component.cxf.SoapTargetBean" />
+
+<cxf:cxfEndpoint id="soapMessageEndpoint"
+
serviceClass="org.apache.camel.component.cxf.SoapMessageProvider"
+               address="http://localhost:
${CXFTestSupport.port1}/CxfSoapMessageProviderTest/SoapContext/SoapProviderPort">
+</cxf:cxfEndpoint>
+
+
+<camelContext id="test_context" xmlns="
http://camel.apache.org/schema/spring";>
+<route>
+<from uri="cxf:bean:soapMessageEndpoint"/>
+<to uri="bean:targetBean?method=invokeStream"/>
+</route>
+</camelContext>
+
+</beans>








--
Willem
----------------------------------
FuseSource
Web: http://www.fusesource.com
Blog:    http://willemjiang.blogspot.com (English)
        http://jnn.javaeye.com (Chinese)
Twitter: willemjiang
Weibo: willemjiang

Reply via email to