You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@camel.apache.org by cm...@apache.org on 2010/07/14 12:48:51 UTC

svn commit: r964005 - in /camel/trunk/examples/camel-example-reportincident-ws-security-osgi: ./ src/ src/main/ src/main/java/ src/main/java/org/ src/main/java/org/apache/ src/main/java/org/apache/camel/ src/main/java/org/apache/camel/example/ src/main...

Author: cmoulliard
Date: Wed Jul 14 10:48:50 2010
New Revision: 964005

URL: http://svn.apache.org/viewvc?rev=964005&view=rev
Log:
CAMEL-2948 : Add a camel example using webservice and ws-security.

Added:
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/README.txt
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/pom.xml
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/FilenameGenerator.java
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/MyBean.java
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/ReportIncidentRoutes.java
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/UTPasswordCallback.java
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/LICENSE.txt
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/NOTICE.txt
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/spring/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/spring/camel-context.xml
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/MailBody.vm
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/report_incident.wsdl
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/log4j.properties
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/reportincident/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/reportincident/ReportIncidentRoutesTest.java
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/resources/
    camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/resources/log4j.properties

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/README.txt
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/README.txt?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/README.txt (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/README.txt Wed Jul 14 10:48:50 2010
@@ -0,0 +1,114 @@
+Report Incident Example
+=======================
+
+An example based on real life use case for reporting incidents using webservice
+that are transformed and send as emails to a backing system. WS-security has been
+implemented. So, the user must generates a SOAP envelope containing a SOAP header
+with wsse xml tag. A simple property map has been created containing user and password.
+We use Apache CXF WSS4JInterceptor to get the user/password and timestamp and authenticate
+the user using the WSS4J callback
+
+You will need to compile this example first:
+  mvn install
+
+Remarks : 
+- During the compilation phase, a unit test will be performed, this unit test simulates the
+communication between a client calling the web services exposed by our camel/cxf routes. During the call,
+the user "charles" is used to authenticate the web service call and the SOAP message created can be 
+retrieved from log file target/camel-example-reportincident-wssecurity.log
+- A mock SMTP server is used during unit test
+- In Eclipse, I have used the following option when starting the junit test case. This option tells
+ CXF that it must use log4j : -Dorg.apache.cxf.Logger=org.apache.cxf.common.logging.Log4jLogger
+
+To run the example on Apache ServiceMix 4.x or Apache Karaf 1.x / 2.x
+
+  1) launch the server
+  karaf.bat
+  
+  2) Add features required
+  features:install http
+  features:install camel
+  features:install camel-cxf
+  features:install camel-mail
+  features:install camel-velocity
+  
+  remark : As the camel route sends email to a SMTP server, you must configure a user/password in your favorite
+  SMTP Server (James by example). User = someone and password = secret
+  
+  3) Deploy our example
+  osgi:install -s mvn:org.apache.example.reportincident/camel-example-reportincident-wssecurity
+  
+  4) Verify that your service is available using in the browser the following url
+  http://localhost:9080/camel-example-reportincident/webservices/incident?wsdl
+
+  5) Start SOAPUI (2.x)
+  Create a new project called camel-example-reportincident-wssecurity
+  Point to the following url : http://localhost:9080/camel-example-reportincident/webservices/incident?wsdl
+  Open the request 1 (under camel-example-reportincident-wssecurity --> ReportIncidentBinding --> ReportIncident) and copy/paste the SOAP
+  message generated by the unit test
+  
+  ex :
+  
+	2010-07-14 09:57:54,403 [main           ] INFO  LoggingOutInterceptor          - Outbound Message
+	---------------------------
+	ID: 1
+	Address: http://localhost:9080/camel-example-reportincident/webservices/incident
+	Encoding: UTF-8
+	Content-Type: text/xml
+	Headers: {SOAPAction=["http://reportincident.example.camel.apache.org/ReportIncident"], Accept=[*/*]}
+	Payload: <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"><soap:Header><wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" soap:mustUnderstand="1"><wsu:Timestamp xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="Timestamp-2"><wsu:Created>2010-07-14T07:57:54.387Z</wsu:Created><wsu:Expires>2010-07-14T08:02:54.387Z</wsu:Expires></wsu:Timestamp><wsse:UsernameToken xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="UsernameToken-1"><wsse:Username>charles</wsse:Username><wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordDigest">0U5uXRYukYG5PF82gsmncH+yWEE=</wsse:Password><wsse:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-20040
 1-wss-soap-message-security-1.0#Base64Binary">/Ka8O+F8cyufohiJFp8wjA==</wsse:Nonce><wsu:Created>2010-07-14T07:57:54.387Z</wsu:Created></wsse:UsernameToken></wsse:Security></soap:Header><soap:Body><ns2:inputReportIncident xmlns:ns2="http://reportincident.example.camel.apache.org"><incidentId>123</incidentId><incidentDate>2008-08-18</incidentDate><givenName>Claus</givenName><familyName>Ibsen</familyName><summary>Bla</summary><details>Bla bla</details><email>davsclaus@apache.org</email><phone>0045 2962 7576</phone></ns2:inputReportIncident></soap:Body></soap:Envelope>
+	--------------------------------------
+	2010-07-14 09:57:54,403 [main           ] DEBUG HTTPConduit                    - Sending POST Message with Headers to http://localhost:9080/camel-example-reportincident/webservices/incident Conduit :{http://reportincident.example.camel.apache.org}ReportIncidentEndpointPort.http-conduit
+  
+  --> and the message formatted that you copy in SOAPUI
+  
+		<?xml version="1.0" encoding="UTF-8"?>
+		<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
+			<soap:Header>
+				<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" soap:mustUnderstand="1">
+					<wsu:Timestamp xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="Timestamp-2">
+						<wsu:Created>2010-07-14T09:40:29.637Z</wsu:Created>
+						<wsu:Expires>2010-07-14T09:45:29.637Z</wsu:Expires>
+					</wsu:Timestamp>
+					<wsse:UsernameToken xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="UsernameToken-1">
+						<wsse:Username>charles</wsse:Username>
+						<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordDigest">TVzWGxNvhlixNVWol8poD9DHxl8=</wsse:Password>
+						<wsse:Nonce EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary">WsMNSm/C4dzdPS3OhUi94Q==</wsse:Nonce>
+						<wsu:Created>2010-07-14T09:40:29.637Z</wsu:Created>
+					</wsse:UsernameToken>
+				</wsse:Security>
+			</soap:Header>
+			<soap:Body>
+				<ns2:inputReportIncident xmlns:ns2="http://reportincident.example.camel.apache.org">
+					<incidentId>111</incidentId>
+					<incidentDate>2010-07-14</incidentDate>
+					<givenName>Charles</givenName>
+					<familyName>Moulliard</familyName>
+					<summary>Bla</summary>
+					<details>Bla bla</details>
+					<email>cmoulliard@apache.org</email>
+					<phone>0011 22 33 44</phone>
+				</ns2:inputReportIncident>
+			</soap:Body>
+		</soap:Envelope>
+
+  
+ You can use another user : james, claus and retry. 
+ 
+ 6) Check email
+ Check through a POP request that a message has been published in the mailbox of someone (email address : incident@mycompany.com)
+ 
+For the latest & greatest documentation on how to use this example please see
+  http://camel.apache.org/tutorial-example-reportincident-wssecurity.html
+
+If you hit any problems please let us know on the Camel Forums
+  http://camel.apache.org/discussion-forums.html
+
+Please help us make Apache Camel better - we appreciate any feedback you may
+have.  Enjoy!
+
+------------------------
+The Camel riders!
+
+
+

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/pom.xml
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/pom.xml?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/pom.xml (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/pom.xml Wed Jul 14 10:48:50 2010
@@ -0,0 +1,277 @@
+<?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.
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+
+  <modelVersion>4.0.0</modelVersion>
+
+   <parent>
+       <groupId>org.apache.camel</groupId>
+       <artifactId>examples</artifactId>
+       <version>2.5-SNAPSHOT</version>
+   </parent>
+  
+  <!-- USED TO TEST camel 2.4.0 on Karaf/SMX
+    <parent>
+      <groupId>org.apache.camel</groupId>
+      <artifactId>camel-parent</artifactId>
+      <version>2.4.0</version>
+  </parent>
+   -->
+  
+  <artifactId>camel-example-reportincident-wssecurity</artifactId>
+  <name>Camel :: Example :: Report Incident :: WS-Security</name>
+  <description>An example based on real life use case for reporting incidents using webservice that are transformed
+      and send as emails to a backing system. Client calling the WebService is authentified through WS-Security
+  </description>
+  <packaging>bundle</packaging>
+  
+	<dependencies>
+		<dependency>
+			<groupId>org.apache.camel</groupId>
+			<artifactId>camel-core</artifactId>
+		</dependency>
+
+		<dependency>
+			<groupId>org.apache.camel</groupId>
+			<artifactId>camel-spring</artifactId>
+		</dependency>
+		
+		<dependency>
+			<groupId>org.apache.camel</groupId>
+			<artifactId>camel-test</artifactId>
+			<scope>test</scope>
+		</dependency>
+
+		<dependency>
+			<groupId>org.apache.camel</groupId>
+			<artifactId>camel-cxf</artifactId>
+		</dependency>
+
+		<dependency>
+			<groupId>org.apache.camel</groupId>
+			<artifactId>camel-velocity</artifactId>
+		</dependency>
+
+		<dependency>
+			<groupId>org.apache.camel</groupId>
+			<artifactId>camel-mail</artifactId>
+		</dependency>
+		
+	    <dependency>
+		  <groupId>org.fusesource.commonman</groupId>
+		  <artifactId>commons-management</artifactId>
+		</dependency>
+
+        <!-- mock mail server so we do not send an email for real -->
+        <dependency>
+            <groupId>org.jvnet.mock-javamail</groupId>
+            <artifactId>mock-javamail</artifactId>
+            <version>1.7</version>
+            <exclusions>
+              <exclusion>
+                <groupId>javax.mail</groupId>
+                <artifactId>mail</artifactId>
+              </exclusion>
+            </exclusions>
+            <scope>test</scope>
+        </dependency>
+        
+       <dependency>
+			<groupId>org.springframework</groupId>
+			<artifactId>spring-context-support</artifactId>
+			<scope>test</scope>
+		</dependency>
+
+		<!-- cxf -->
+		<dependency>
+			<groupId>org.apache.cxf</groupId>
+			<artifactId>cxf-rt-core</artifactId>
+			<version>${cxf-version}</version>
+		</dependency>
+		<dependency>
+			<groupId>org.apache.cxf</groupId>
+			<artifactId>cxf-rt-frontend-jaxws</artifactId>
+			<version>${cxf-version}</version>
+		</dependency>
+
+
+		<!-- regular http transport -->
+		<dependency>
+			<groupId>org.apache.cxf</groupId>
+			<artifactId>cxf-rt-transports-http</artifactId>
+			<version>${cxf-version}</version>
+		</dependency>
+		
+		<!-- ws-security -->
+		<dependency>
+		    <groupId>org.apache.ws.security</groupId>
+		    <artifactId>wss4j</artifactId>
+		    <version>1.5.8</version>
+		</dependency>
+		<dependency>
+			<groupId>org.apache.cxf</groupId>
+			<artifactId>cxf-rt-ws-security</artifactId>
+			<version>${cxf-version}</version>
+		</dependency>
+		
+		
+		<!-- logging -->
+		<dependency>
+			<groupId>log4j</groupId>
+			<artifactId>log4j</artifactId>
+		</dependency>
+        <dependency>
+           <groupId>org.slf4j</groupId>
+           <artifactId>slf4j-log4j12</artifactId>
+         </dependency>
+
+		<!-- cxf web container for unit testing -->
+		<dependency>
+			<groupId>org.apache.cxf</groupId>
+			<artifactId>cxf-rt-transports-http-jetty</artifactId>
+			<version>${cxf-version}</version>
+		</dependency>
+
+		<dependency>
+			<groupId>junit</groupId>
+			<artifactId>junit</artifactId>
+			<scope>test</scope>
+		</dependency>
+		
+		<dependency>
+			<groupId>org.apache.cxf</groupId>
+			<artifactId>cxf-rt-frontend-jaxrs</artifactId>
+			<version>${cxf-version}</version>
+			<scope>test</scope>
+		</dependency>
+		
+		<dependency>
+			<groupId>org.apache.velocity</groupId>
+			<artifactId>velocity</artifactId>
+			<version>${velocity-version}</version>
+			<scope>test</scope>
+		</dependency>
+
+	</dependencies>
+
+    <build>
+        <plugins>
+
+            <!-- to compile with 1.5 -->
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-compiler-plugin</artifactId>
+                <configuration>
+                    <source>1.5</source>
+                    <target>1.5</target>
+                </configuration>
+            </plugin>
+       
+            <!-- CXF wsdl2java generator, will plugin to the compile goal -->
+            <plugin>
+                <groupId>org.apache.cxf</groupId>
+                <artifactId>cxf-codegen-plugin</artifactId>
+                <version>${cxf-version}</version>
+                <executions>
+                    <execution>
+                        <id>generate-sources</id>
+                        <phase>generate-sources</phase>
+                        <configuration>
+                            <sourceRoot>${basedir}/target/generated/src/main/java</sourceRoot>
+                            <wsdlOptions>
+                                <wsdlOption>
+                                    <wsdl>${basedir}/src/main/resources/etc/report_incident.wsdl</wsdl>
+                                </wsdlOption>
+                            </wsdlOptions>
+                        </configuration>
+                        <goals>
+                            <goal>wsdl2java</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <!-- so we can run mvn jetty:run -->
+            <plugin>
+                <groupId>org.mortbay.jetty</groupId>
+                <artifactId>jetty-maven-plugin</artifactId>
+                <version>${jetty-version}</version>
+                <configuration>
+                   <connectors>
+                      <connector implementation="org.eclipse.jetty.server.nio.SelectChannelConnector">
+                        <port>9080</port>
+                        <maxIdleTime>60000</maxIdleTime>
+                      </connector>
+                   </connectors>                   
+                </configuration>
+            </plugin>
+            
+            <!-- to generate the MANIFEST-FILE of the bundle -->
+			<plugin>
+				<groupId>org.apache.felix</groupId>
+				<artifactId>maven-bundle-plugin</artifactId>
+				<extensions>true</extensions>
+				<configuration>
+					<manifestLocation>META-INF</manifestLocation>
+					<instructions>
+						<Bundle-SymbolicName>${project.artifactId}</Bundle-SymbolicName>
+						<Export-Package>org.apache.camel.example.reportincident*</Export-Package>
+						<Import-Package>
+						    META-INF.cxf,
+				  			org.apache.cxf,
+							org.apache.cxf.binding,
+							org.apache.cxf.binding.corba,
+							org.apache.cxf.binding.soap,
+							org.apache.cxf.binding.soap.spring,
+							org.apache.cxf.bus,
+							org.apache.cxf.bus.resource,
+							org.apache.cxf.bus.spring,
+							org.apache.cxf.buslifecycle,
+							org.apache.cxf.catalog,
+							org.apache.cxf.configuration,
+							org.apache.cxf.configuration.spring,
+							org.apache.cxf.endpoint,
+							org.apache.cxf.headers,
+							org.apache.cxf.management,
+							org.apache.cxf.management.jmx,
+							org.apache.cxf.phase,
+							org.apache.cxf.resource,
+							org.apache.cxf.transport,
+							org.apache.cxf.transport.http,
+							org.apache.cxf.transport.http.policy,
+							org.apache.cxf.transport.http_jetty,
+							org.apache.cxf.transport.http_osgi,
+							org.apache.cxf.transport.jms,
+							org.apache.cxf.transports.http,
+							org.apache.cxf.workqueue,
+							org.apache.cxf.wsdl,
+							org.apache.cxf.wsdl11,
+							org.apache.ws.security.action,
+							org.apache.ws.security.processor,
+							org.springframework.beans.factory.config,
+							org.springframework.mail.javamail,
+						    *
+					    </Import-Package>
+					</instructions>
+				</configuration>
+			</plugin>
+            
+
+        </plugins>
+    </build>
+</project>

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/FilenameGenerator.java
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/FilenameGenerator.java?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/FilenameGenerator.java (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/FilenameGenerator.java Wed Jul 14 10:48:50 2010
@@ -0,0 +1,29 @@
+/**
+ * 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.example.reportincident;
+
+/**
+ * Plain java class to be used for filename generation based on the reported incident
+ */
+public class FilenameGenerator {
+
+    public String generateFilename(InputReportIncident input) {        
+        // compute the filename
+        return "incident-" + input.getIncidentId() + ".txt";
+    }
+
+}

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/MyBean.java
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/MyBean.java?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/MyBean.java (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/MyBean.java Wed Jul 14 10:48:50 2010
@@ -0,0 +1,29 @@
+/**
+ * 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.example.reportincident;
+
+/**
+ * 
+ */
+public class MyBean {
+    public OutputReportIncident getOK() {
+        OutputReportIncident ok = new OutputReportIncident();
+        ok.setCode("0");
+        return ok;
+    }
+}

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/ReportIncidentRoutes.java
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/ReportIncidentRoutes.java?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/ReportIncidentRoutes.java (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/ReportIncidentRoutes.java Wed Jul 14 10:48:50 2010
@@ -0,0 +1,85 @@
+/**
+ * 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.example.reportincident;
+
+import org.apache.camel.CamelContext;
+import org.apache.camel.Exchange;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.impl.DefaultCamelContext;
+import org.apache.camel.language.bean.BeanLanguage;
+
+/**
+ * Our routes that we can build using Camel DSL as we extend the RouteBuilder class.
+ * <p/>
+ * In the configure method we have all kind of DSL methods we use for expressing our routes.
+ */
+public class ReportIncidentRoutes extends RouteBuilder {
+    private boolean usingServletTransport = true;
+    
+    public void setUsingServletTransport(boolean flag) {
+        usingServletTransport = flag;
+    }
+
+    public void configure() throws Exception {
+        // webservice response for OK
+        OutputReportIncident ok = new OutputReportIncident();
+        ok.setCode("0");
+
+        // endpoint to our CXF webservice  
+        // We should use the related path to publish the service, when using the ServletTransport
+        // so we need to configure set the bus which is configured to use the ServletTranspot
+        String cxfEndpointAddress = "cxf:/incident?bus=#cxf&";
+        // Using the full http address for stand alone running
+        if (!usingServletTransport) {
+            cxfEndpointAddress = "cxf://http://localhost:9080/camel-example-reportincident/webservices/incident?";
+        }
+        String cxfEndpoint = cxfEndpointAddress
+                + "serviceClass=org.apache.camel.example.reportincident.ReportIncidentEndpoint"
+                + "&wsdlURL=etc/report_incident.wsdl";
+
+        // first part from the webservice -> file backup
+        from(cxfEndpoint)
+            // we need to convert the CXF payload to InputReportIncident that FilenameGenerator and velocity expects
+            .convertBodyTo(InputReportIncident.class)
+            // then set the file name using the FilenameGenerator bean
+            .setHeader(Exchange.FILE_NAME, BeanLanguage.bean(FilenameGenerator.class, "generateFilename"))
+            // and create the mail body using velocity template
+            .to("velocity:etc/MailBody.vm")
+            // and store the file
+            .to("file://target/subfolder")
+            // return OK as response
+            .log("Wrote ${file:name} and returning OK response")
+            .transform(constant(ok));
+
+        // second part from the file backup -> send email
+        from("file://target/subfolder")
+            // set the subject of the email
+            .setHeader("subject", constant("new incident reported"))
+            // send the email
+            .log("Sending email to incident@mycompany.com:\n${body}")
+            .to("smtp://someone@localhost?password=secret&to=incident@mycompany.com");
+    }
+    
+    public static void main(String args[]) throws Exception {
+        CamelContext camel = new DefaultCamelContext();
+        ReportIncidentRoutes routes = new ReportIncidentRoutes();
+        routes.setUsingServletTransport(false);
+        camel.addRoutes(routes);
+        camel.start();
+    }
+
+}

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/UTPasswordCallback.java
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/UTPasswordCallback.java?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/UTPasswordCallback.java (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/java/org/apache/camel/example/reportincident/UTPasswordCallback.java Wed Jul 14 10:48:50 2010
@@ -0,0 +1,78 @@
+/**
+ * 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.example.reportincident;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.security.auth.callback.Callback;
+import javax.security.auth.callback.CallbackHandler;
+import javax.security.auth.callback.UnsupportedCallbackException;
+
+import org.apache.ws.security.WSPasswordCallback;
+
+/**
+ */
+
+public class UTPasswordCallback implements CallbackHandler {
+
+    private Map<String, String> passwords =
+        new HashMap<String, String>();
+
+    public UTPasswordCallback() {
+        passwords.put("claus", "sualc");
+        passwords.put("charles", "selrahc");
+        passwords.put("james", "semaj");
+    	passwords.put("abcd", "dcba");
+    }
+
+    /**
+     * Here, we attempt to get the password from the private
+     * alias/passwords map.
+     */
+    public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException {
+    	
+    	String user = "";
+    	
+        for (int i = 0; i < callbacks.length; i++) {
+        	WSPasswordCallback pc = (WSPasswordCallback)callbacks[i];
+        	user = pc.getIdentifier();
+        	
+            String pass = passwords.get(user);
+            if (pass != null) {
+                pc.setPassword(pass);
+                return;
+            }
+        }
+
+        //
+        // Password not found
+        //
+        throw new IOException("Password does not exist for the user : " + user);
+
+    }
+
+    /**
+     * Add an alias/password pair to the callback mechanism.
+     */
+    public void setAliasPassword(String alias, String password) {
+        passwords.put(alias, password);
+    }
+}

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/LICENSE.txt
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/LICENSE.txt?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/LICENSE.txt (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/LICENSE.txt Wed Jul 14 10:48:50 2010
@@ -0,0 +1,203 @@
+
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed 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.
+

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/NOTICE.txt
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/NOTICE.txt?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/NOTICE.txt (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/NOTICE.txt Wed Jul 14 10:48:50 2010
@@ -0,0 +1,11 @@
+   =========================================================================
+   ==  NOTICE file corresponding to the section 4 d of                    ==
+   ==  the Apache License, Version 2.0,                                   ==
+   ==  in this case for the Apache Camel distribution.                    ==
+   =========================================================================
+
+   This product includes software developed by
+   The Apache Software Foundation (http://www.apache.org/).
+
+   Please read the different LICENSE files present in the licenses directory of
+   this distribution.

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/spring/camel-context.xml
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/spring/camel-context.xml?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/spring/camel-context.xml (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/META-INF/spring/camel-context.xml Wed Jul 14 10:48:50 2010
@@ -0,0 +1,111 @@
+<?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:camel="http://camel.apache.org/schema/spring"
+       xmlns:cxf="http://camel.apache.org/schema/cxf"       
+       xsi:schemaLocation="
+       http://www.springframework.org/schema/beans
+       http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
+       http://camel.apache.org/schema/spring
+       http://camel.apache.org/schema/spring/camel-spring.xsd
+       http://camel.apache.org/schema/cxf
+       http://camel.apache.org/schema/cxf/camel-cxf.xsd">
+
+ <import resource="classpath:META-INF/cxf/cxf.xml"/>
+ <import resource="classpath:META-INF/cxf/cxf-extension-soap.xml"/>
+ <import resource="classpath:META-INF/cxf/cxf-extension-http-jetty.xml"/>
+ 
+   <bean id="loggingOutInterceptor" class="org.apache.cxf.interceptor.LoggingOutInterceptor">
+        <!--  it really should have been user-prestream but CXF does have such phase! -->
+        <constructor-arg value="write"/> 
+   </bean>
+   
+   <bean id="loggingInInterceptor" class="org.apache.cxf.interceptor.LoggingInInterceptor" />
+   
+  <bean id="wss4jInInterceptor" class="org.apache.cxf.ws.security.wss4j.WSS4JInInterceptor">
+    <constructor-arg>
+		<map>
+			<entry key="action" value="UsernameToken Timestamp"/>
+			<entry key="passwordType" value="PasswordDigest"/>
+			<entry key="passwordCallbackClass" value="org.apache.camel.example.reportincident.UTPasswordCallback"/>
+		</map>
+	</constructor-arg>    
+  </bean>
+   
+  <!--          
+  <bean id="wss4jOutInterceptor" class="org.apache.cxf.ws.security.wss4j.WSS4JOutInterceptor">
+    <constructor-arg>
+		<map>
+			<entry key="action" value="UsernameToken Timestamp"/>
+			<entry key="passwordType" value="PasswordText"/>
+			<entry key="user" value="Alice"/>
+			<entry key="passwordCallbackClass" value="org.apache.camel.example.reportincident.UTPasswordCallback"/>
+		</map>
+	</constructor-arg>
+  </bean>
+   -->
+
+ <cxf:cxfEndpoint id="reportIncident"
+                     address="http://localhost:9080/camel-example-reportincident/webservices/incident"
+                     wsdlURL="etc/report_incident.wsdl"
+                     serviceClass="org.apache.camel.example.reportincident.ReportIncidentEndpoint">
+                     
+        <cxf:inInterceptors>
+          <ref bean="loggingInInterceptor"/>
+          <ref bean="wss4jInInterceptor"/>
+        </cxf:inInterceptors>
+        	
+        <cxf:outInterceptors>
+          <ref bean="loggingOutInterceptor"/>
+          <!--  <ref bean="wss4jOutInterceptor"/> -->
+        </cxf:outInterceptors>
+ 
+ </cxf:cxfEndpoint>
+ 
+ <bean id="myBean" class="org.apache.camel.example.reportincident.MyBean"/>
+ <bean id="filenameGenerator" class="org.apache.camel.example.reportincident.FilenameGenerator"/>
+ 
+ <camel:camelContext id="camel">
+	<camel:route>
+		<camel:from uri="cxf:bean:reportIncident" />
+		<camel:convertBodyTo
+			type="org.apache.camel.example.reportincident.InputReportIncident" />
+	    <camel:setHeader headerName="CamelFileName">
+          	<camel:method bean="filenameGenerator" method="generateFilename" />
+        </camel:setHeader>		
+        <camel:to uri="velocity:etc/MailBody.vm"/>        
+        <camel:to uri="file://target/subfolder"/>		
+		<camel:transform>
+			<camel:method bean="myBean" method="getOK" />
+		</camel:transform>
+	</camel:route>
+	
+
+	<camel:route>
+        <camel:from uri="file://target/subfolder"/>
+        <camel:setHeader headerName="subject">
+          	<camel:constant>new incident reported</camel:constant>
+        </camel:setHeader>
+        <camel:to uri="log:com.mycompany.incident?level=INFO"/>
+        <camel:to uri="smtp://someone@localhost?password=secret&amp;to=incident@localhost"/>        
+	</camel:route>
+
+</camel:camelContext>
+</beans>

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/MailBody.vm
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/MailBody.vm?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/MailBody.vm (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/MailBody.vm Wed Jul 14 10:48:50 2010
@@ -0,0 +1,12 @@
+Incident $body.incidentId has been reported on the $body.incidentDate by $body.givenName $body.familyName.
+
+The person can be contacted by:
+- email: $body.email
+- phone: $body.phone
+
+Summary: $body.summary
+
+Details:
+$body.details
+
+This is an auto generated email. You cannot reply.
\ No newline at end of file

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/report_incident.wsdl
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/report_incident.wsdl?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/report_incident.wsdl (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/etc/report_incident.wsdl Wed Jul 14 10:48:50 2010
@@ -0,0 +1,92 @@
+<?xml version="1.0" encoding="ISO-8859-1"?>
+<!--
+    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.
+-->
+
+<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
+	xmlns:tns="http://reportincident.example.camel.apache.org"
+	xmlns:xs="http://www.w3.org/2001/XMLSchema"
+	xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"
+	xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
+	targetNamespace="http://reportincident.example.camel.apache.org">
+
+    <!-- Type definitions for input- and output parameters for webservice -->
+    <wsdl:types>
+        <xs:schema targetNamespace="http://reportincident.example.camel.apache.org">
+            <xs:element name="inputReportIncident">
+                <xs:complexType>
+                    <xs:sequence>
+                        <xs:element type="xs:string" name="incidentId"/>
+                        <xs:element type="xs:string" name="incidentDate"/>
+                        <xs:element type="xs:string" name="givenName"/>
+                        <xs:element type="xs:string" name="familyName"/>
+                        <xs:element type="xs:string" name="summary"/>
+                        <xs:element type="xs:string" name="details"/>
+                        <xs:element type="xs:string" name="email"/>
+                        <xs:element type="xs:string" name="phone"/>
+                    </xs:sequence>
+                </xs:complexType>
+            </xs:element>
+            <xs:element name="outputReportIncident">
+                <xs:complexType>
+                    <xs:sequence>
+                        <xs:element type="xs:string" name="code"/>
+                    </xs:sequence>
+                </xs:complexType>
+            </xs:element>
+        </xs:schema>
+    </wsdl:types>
+
+    <!-- Message definitions for input and output -->
+    <wsdl:message name="inputReportIncident">
+        <wsdl:part name="in" element="tns:inputReportIncident"/>
+    </wsdl:message>
+    <wsdl:message name="outputReportIncident">
+        <wsdl:part name="out" element="tns:outputReportIncident"/>
+    </wsdl:message>
+
+    <!-- Port (interface) definitions -->
+    <wsdl:portType name="ReportIncidentEndpoint">
+        <wsdl:operation name="ReportIncident">
+            <wsdl:input message="tns:inputReportIncident"/>
+            <wsdl:output message="tns:outputReportIncident"/>
+        </wsdl:operation>
+    </wsdl:portType>
+
+    <!-- Port bindings to transports and encoding - HTTP, document literal encoding is used -->
+    <wsdl:binding name="ReportIncidentBinding" type="tns:ReportIncidentEndpoint">
+        <soap:binding transport="http://schemas.xmlsoap.org/soap/http"/>
+        <wsdl:operation name="ReportIncident">
+            <soap:operation
+                    soapAction="http://reportincident.example.camel.apache.org/ReportIncident"
+                    style="document"/>
+            <wsdl:input>
+                <soap:body parts="in" use="literal"/>
+            </wsdl:input>
+            <wsdl:output>
+                <soap:body parts="out" use="literal"/>
+            </wsdl:output>
+        </wsdl:operation>
+    </wsdl:binding>
+
+    <!-- Service definition -->
+    <wsdl:service name="ReportIncidentEndpointService">
+        <wsdl:port name="ReportIncidentService" binding="tns:ReportIncidentBinding">
+            <soap:address location="http://localhost:9080/part-five/webservices/incident"/>
+        </wsdl:port>
+    </wsdl:service>
+
+</wsdl:definitions>

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/log4j.properties
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/log4j.properties?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/log4j.properties (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/main/resources/log4j.properties Wed Jul 14 10:48:50 2010
@@ -0,0 +1,40 @@
+## ------------------------------------------------------------------------
+## 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.
+## ------------------------------------------------------------------------
+
+# default properties to initialise log4j
+log4j.rootLogger=INFO, console
+
+# Console appender
+log4j.appender.console=org.apache.log4j.ConsoleAppender
+log4j.appender.console.layout=org.apache.log4j.PatternLayout
+log4j.appender.console.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
+
+# File appender
+log4j.appender.file=org.apache.log4j.FileAppender
+log4j.appender.file.layout=org.apache.log4j.PatternLayout
+log4j.appender.file.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
+log4j.appender.file.file=target/camel-example-reportincident.log
+log4j.appender.file.append=true
+
+# settings for specific packages
+#log4j.logger.org.springframework=WARN
+#log4j.logger.org.apache.cxf=WARN
+
+# Camel logging
+#log4j.logger.org.apache.camel=DEBUG
+
+log4j.throwableRenderer=org.apache.log4j.EnhancedThrowableRenderer
\ No newline at end of file

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/reportincident/ReportIncidentRoutesTest.java
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/reportincident/ReportIncidentRoutesTest.java?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/reportincident/ReportIncidentRoutesTest.java (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/java/org/apache/camel/example/reportincident/ReportIncidentRoutesTest.java Wed Jul 14 10:48:50 2010
@@ -0,0 +1,116 @@
+/**
+ * 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.example.reportincident;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import junit.framework.TestCase;
+import org.apache.camel.CamelContext;
+import org.apache.camel.test.junit4.CamelSpringTestSupport;
+import org.apache.cxf.interceptor.LoggingOutInterceptor;
+import org.apache.cxf.jaxws.JaxWsProxyFactoryBean;
+import org.apache.cxf.ws.security.wss4j.WSS4JOutInterceptor;
+import org.junit.Test;
+import org.jvnet.mock_javamail.Mailbox;
+import org.springframework.context.support.AbstractXmlApplicationContext;
+import org.springframework.context.support.ClassPathXmlApplicationContext;
+import static org.junit.Assert.assertEquals;
+
+/**
+ * Unit test of our routes
+ */
+public class ReportIncidentRoutesTest extends CamelSpringTestSupport {
+	
+    // should be the same address as we have in our route
+    private static final String URL = "http://localhost:9080/camel-example-reportincident/webservices/incident";
+
+    protected CamelContext camel;
+
+    protected static ReportIncidentEndpoint createCXFClient() {
+    	
+        List outInterceptors = new ArrayList();
+    	
+        // Define WSS4j properties for flow outgoing
+        Map<String, Object> outProps = new HashMap<String, Object>();
+        outProps.put("action", "UsernameToken Timestamp");
+
+        outProps.put("passwordType", "PasswordDigest");
+        outProps.put("user", "charles");
+        outProps.put("passwordCallbackClass", "org.apache.camel.example.reportincident.UTPasswordCallback");
+        
+        WSS4JOutInterceptor wss4j = new WSS4JOutInterceptor(outProps);
+
+        // Add LoggingOutInterceptor
+        LoggingOutInterceptor loggingOutInterceptor = new LoggingOutInterceptor (); 
+        
+        outInterceptors.add(wss4j);
+        outInterceptors.add(loggingOutInterceptor);
+        
+        // we use CXF to create a client for us as its easier than JAXWS and works
+        JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();
+        factory.setOutInterceptors(outInterceptors);
+        factory.setServiceClass(ReportIncidentEndpoint.class);
+        factory.setAddress(URL);
+        return (ReportIncidentEndpoint) factory.create();
+    }
+
+    @Test
+    public void testRendportIncident() throws Exception {
+        runTest();
+    }
+    
+    protected void runTest() throws Exception {
+    	
+        // assert mailbox is empty before starting
+        Mailbox inbox = Mailbox.get("incident@localhost");
+        inbox.clear();
+        assertEquals("Should not have mails", 0, inbox.size());
+
+        // create input parameter
+        InputReportIncident input = new InputReportIncident();
+        input.setIncidentId("222");
+        input.setIncidentDate("2010-07-14");
+        input.setGivenName("Charles");
+        input.setFamilyName("Moulliard");
+        input.setSummary("Bla");
+        input.setDetails("Bla bla");
+        input.setEmail("cmoulliard@apache.org");
+        input.setPhone("0011 22 33 44");
+
+        // create the webservice client and send the request
+        ReportIncidentEndpoint client = createCXFClient();
+        OutputReportIncident out = client.reportIncident(input);
+
+        // assert we got a OK back
+        assertEquals("0", out.getCode());
+
+        // let some time pass to allow Camel to pickup the file and send it as an email
+        Thread.sleep(3000);
+
+        // assert mail box
+        assertEquals("Should have got 1 mail", 1, inbox.size());
+
+    }
+
+	@Override
+	protected AbstractXmlApplicationContext createApplicationContext() {
+		return new ClassPathXmlApplicationContext("/META-INF/spring/camel-context.xml");
+	}
+}

Added: camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/resources/log4j.properties
URL: http://svn.apache.org/viewvc/camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/resources/log4j.properties?rev=964005&view=auto
==============================================================================
--- camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/resources/log4j.properties (added)
+++ camel/trunk/examples/camel-example-reportincident-ws-security-osgi/src/test/resources/log4j.properties Wed Jul 14 10:48:50 2010
@@ -0,0 +1,41 @@
+## ------------------------------------------------------------------------
+## 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.
+## ------------------------------------------------------------------------
+
+# default properties to initialise log4j
+log4j.rootLogger=INFO, file
+
+# Console appender
+log4j.appender.console=org.apache.log4j.ConsoleAppender
+log4j.appender.console.layout=org.apache.log4j.PatternLayout
+log4j.appender.console.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
+
+# File appender
+log4j.appender.file=org.apache.log4j.FileAppender
+log4j.appender.file.layout=org.apache.log4j.PatternLayout
+log4j.appender.file.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
+log4j.appender.file.file=target/camel-example-reportincident-wssecurity.log
+log4j.appender.file.append=true
+
+# settings for specific packages
+log4j.logger.org.springframework=WARN
+log4j.logger.org.apache.cxf=WARN
+
+# Camel logging
+log4j.logger.org.apache.camel=DEBUG
+
+# Cxf logging
+log4j.logger.org.apache.cxf=DEBUG
\ No newline at end of file