[jboss-svn-commits] JBL Code SVN: r8217 - in labs/jbossesb/trunk/product/samples/quickstarts: . helloworld_file_action helloworld_file_action/src helloworld_file_action/src/quickstart helloworld_file_action/src/quickstart/test
jboss-svn-commits at lists.jboss.org
jboss-svn-commits at lists.jboss.org
Mon Dec 11 00:19:34 EST 2006
Author: burrsutter
Date: 2006-12-11 00:19:32 -0500 (Mon, 11 Dec 2006)
New Revision: 8217
Added:
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/build.xml
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config-gateway.xml
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config.xml
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jbossesb-properties.xml
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jndi.properties
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/juddi.properties
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/log4j.xml
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/Launcher.java
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/MyAction.java
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/test/
labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/test/CreateTestFile.java
Log:
Initial check-in
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/build.xml
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/build.xml 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/build.xml 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,76 @@
+<project name="Quickstart_helloworld_file_action" default="run" basedir=".">
+
+ <property file="../quickstarts.properties" />
+
+ <property name="build.dir" value="${basedir}/build"/>
+ <property name="src.dir" value="${basedir}/src"/>
+
+ <property name="esb-config" value="${basedir}/esb-config.xml"/>
+ <property name="esb-config-gateway" value="${basedir}/esb-config-gateway.xml"/>
+
+ <path id="classpath">
+ <fileset dir="${basedir}" includes="jbossesb-properties.xml"/>
+ <fileset dir="${basedir}" includes="juddi.properties"/>
+
+ <fileset dir="${esb.product.lib.dir}" includes="*jar"/>
+ <fileset dir="${esb.product.lib.dir}" includes="*xml"/>
+ <fileset dir="${esb.product.lib.dir}/ext" includes="*jar"/>
+ <fileset dir="${jbosshome.dir}/client" includes="*jar"/>
+ <fileset dir="${jbosshome.dir}/server/default/lib">
+ <include name="jboss-j2ee.jar"/> <!-- added this for the JMS client -->
+ </fileset>
+
+ <fileset dir="${basedir}" includes="build/**/*.jar"/>
+ <fileset dir="${basedir}" includes="build/**/*.xml"/>
+ <pathelement location="." />
+
+ </path>
+
+ <property name="cp" refid="classpath"/>
+
+ <target name="echoCP">
+ <echo message="Classpath is ${cp}"/>
+ </target>
+
+ <target name="prepare">
+ <mkdir dir="${build.dir}" />
+ </target>
+
+ <target name="clean">
+ <delete dir="${build.dir}" />
+ </target>
+
+ <target name="compile" depends="prepare">
+ <javac srcdir="${src.dir}"
+ destdir="${build.dir}">
+ <classpath refid="classpath"/>
+ </javac>
+ </target>
+
+ <target name="jars" depends="compile">
+ <delete file="${build.dir}/${ant.project.name}.jar"/>
+ <jar destfile="${build.dir}/${ant.project.name}.jar"
+ basedir="${build.dir}"
+ includes="**/*.class"/>
+ </target>
+
+ <target name="run" depends="jars">
+ <echo>Basic File Gateway and Listener</echo>
+ <java fork="yes" classname="quickstart.Launcher" failonerror="true">
+ <arg value="0"/>
+ <arg value="${esb-config}"/>
+ <arg value="${esb-config-gateway}"/>
+ <classpath refid="classpath"/>
+ </java>
+ </target>
+
+ <target name="runtest">
+ <echo>Runs Test File Creator</echo>
+ <java fork="yes" classname="quickstart.test.CreateTestFile" failonerror="true">
+ <arg value="/tmp/ESBInput"/>
+ <arg value="MyInput.dat"/> <!-- the directory the file should be created in -->
+ <arg value="Hello World In A File"/> <!-- the file contents -->
+ <classpath refid="classpath"/>
+ </java>
+ </target>
+</project>
\ No newline at end of file
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config-gateway.xml
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config-gateway.xml 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config-gateway.xml 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,15 @@
+<esb-config-gateway parameterReloadSecs="180">
+ <esb-file-gateway
+ target-service-category="myCategory"
+ target-service-name="myFileGateway"
+ gatewayClass="org.jboss.soa.esb.listeners.gateway.FileGatewayListener"
+ pollLatencySeconds="5"
+ inputDir="/tmp/ESBInput"
+ inputSuffix=".dat"
+ postSuffix=".sentToEsb"
+ >
+ <!-- no action needed as the inbound message is automatically converted
+ and sent to the queue for the target service -->
+ </esb-file-gateway>
+</esb-config-gateway>
+
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config.xml
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config.xml 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/esb-config.xml 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,24 @@
+<esb-config parameterReloadSecs="180">
+ <esb-listener
+ service-category="myCategory"
+ service-name="myFileGateway"
+ service-description="Simply listens for ESB Messages"
+ epr-description="File Hello World"
+ listenerClass="org.jboss.soa.esb.listeners.message.JmsQueueListener"
+ connection-factory="ConnectionFactory"
+ destination-type="queue"
+ destination-name="queue/B"
+ jndi-context-factory="org.jnp.interfaces.NamingContextFactory"
+ jndi-URL="localhost"
+ >
+ <action class="quickstart.MyAction" process="displayMessage" exceptionMethod="exceptionHandler" />
+ <action class="quickstart.MyAction" process="playWithMessage" exceptionMethod="exceptionHandler" />
+
+ <action class="org.jboss.soa.esb.actions.Notifier" okMethod="notifyOK">
+ <NotificationList type="OK">
+ <target class="NotifyConsole" />
+ <!-- add notify JMS -->
+ </NotificationList>
+ </action>
+ </esb-listener>
+</esb-config>
\ No newline at end of file
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jbossesb-properties.xml
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jbossesb-properties.xml 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jbossesb-properties.xml 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,84 @@
+<?xml version="1.0" encoding="ISO-8859-1"?>
+<!--
+ JBoss, Home of Professional Open Source
+ Copyright 2006, JBoss Inc., and others contributors as indicated
+ by the @authors tag. All rights reserved.
+ See the copyright.txt in the distribution for a
+ full listing of individual contributors.
+ This copyrighted material is made available to anyone wishing to use,
+ modify, copy, or redistribute it subject to the terms and conditions
+ of the GNU Lesser General Public License, v. 2.1.
+ This program is distributed in the hope that it will be useful, but WITHOUT A
+ WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+ PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
+ You should have received a copy of the GNU Lesser General Public License,
+ v.2.1 along with this distribution; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+ MA 02110-1301, USA.
+
+ (C) 2005-2006,
+ @author JBoss Inc.
+-->
+<!-- $Id: jbossesb-unittest-properties.xml $ -->
+<!--
+ These options are described in the JBossESB manual.
+ Defaults are provided here for convenience only.
+
+ Please read through this file prior to using the system, and consider
+ updating the specified entries.
+-->
+<esb
+ xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:noNamespaceSchemaLocation="jbossesb-1_0.xsd">
+ <properties name="core">
+ <property name="org.jboss.soa.esb.jndi.server.type" value="jboss"/>
+ <property name="org.jboss.soa.esb.jndi.server.url" value="localhost"/>
+ <property name="org.jboss.soa.esb.persistence.connection.factory" value="org.jboss.internal.soa.esb.persistence.format.MessageStoreFactoryImpl"/>
+ </properties>
+ <properties name="registry">
+ <property name="org.jboss.soa.esb.registry.queryManagerURI"
+ value="jnp://localhost:1099/InquiryService?org.apache.juddi.registry.rmi.Inquiry#inquire"/>
+ <property name="org.jboss.soa.esb.registry.lifeCycleManagerURI"
+ value="jnp://localhost:1099/PublishService?org.apache.juddi.registry.rmi.Publish#publish" />
+ <property name="org.jboss.soa.esb.registry.implementationClass"
+ value="org.jboss.internal.soa.esb.services.registry.JAXRRegistryImpl"/>
+ <property name="org.jboss.soa.esb.registry.factoryClass"
+ value="org.apache.ws.scout.registry.ConnectionFactoryImpl"/>
+ <property name="org.jboss.soa.esb.registry.user"
+ value="jbossesb"/>
+ <property name="org.jboss.soa.esb.registry.password"
+ value="password"/>
+ <!-- the following parameter is scout specific to set the type of communication between scout and the UDDI (embedded, rmi, soap) -->
+ <property name="org.jboss.soa.esb.scout.proxy.transportClass"
+ value="org.apache.ws.scout.transport.RMITransport"/>
+ </properties>
+ <properties name="transports" depends="core">
+ <property name="org.jboss.soa.esb.mail.smtp.host" value="localhost"/>
+ <property name="org.jboss.soa.esb.mail.smtp.user" value="jbossesb"/>
+ <property name="org.jboss.soa.esb.mail.smtp.password" value=""/>
+ <property name="org.jboss.soa.esb.mail.smtp.port" value="25"/>
+ </properties>
+ <properties name="connection">
+ <property name="min-pool-size" value="5"/>
+ <property name="max-pool=size" value="10"/>
+ <property name="blocking-timeout-millis" value="5000"/>
+ <property name="abandoned-connection-timeout" value="10000"/>
+ <property name="abandoned-connection-time-interval" value="30000"/>
+ </properties>
+ <properties name="dbstore">
+ <property name="org.jboss.soa.esb.persistence.db.connection.url" value="jdbc:hsqldb:hsql://localhost:9001/jbossesb"/>
+ <property name="org.jboss.soa.esb.persistence.db.jdbc.driver" value="org.hsqldb.jdbcDriver"/>
+ <property name="org.jboss.soa.esb.persistence.db.user" value="sa"/>
+ <property name="org.jboss.soa.esb.persistence.db.pwd" value=""/>
+ <property name="org.jboss.soa.esb.persistence.db.pool.initial.size" value="2"/>
+ <property name="org.jboss.soa.esb.persistence.db.pool.min.size" value="2"/>
+ <property name="org.jboss.soa.esb.persistence.db.pool.max.size" value="5"/>
+ <!--table managed by pool to test for valid connections - created by pool automatically -->
+ <property name="org.jboss.soa.esb.persistence.db.pool.test.table" value="pooltest"/>
+ <!-- # of milliseconds to timeout waiting for a connection from pool -->
+ <property name="org.jboss.soa.esb.persistence.db.pool.timeout.millis" value="5000"/>
+ </properties>
+ <properties name="messagerouting">
+ <property name="org.jboss.soa.esb.routing.cbrClass" value="org.jboss.internal.soa.esb.services.routing.cbr.JBossRulesRouter"/>
+ </properties>
+</esb>
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jndi.properties
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jndi.properties 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/jndi.properties 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,5 @@
+java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
+java.naming.provider.url=jnp://localhost:1099
+java.naming.factory.url.pkgs=org.jboss.naming
+java.naming.factory.url.pkgs=org.jnp.interfaces
+
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/juddi.properties
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/juddi.properties 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/juddi.properties 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,69 @@
+# jUDDI Registry Properties (used by RegistryServer)
+# see http://www.juddi.org for more information
+
+# The UDDI Operator Name
+juddi.operatorName = jUDDI.org
+
+# The i18n locale default codes
+juddi.i18n.languageCode = en
+juddi.i18n.countryCode = US
+
+# The UDDI DiscoveryURL Prefix
+juddi.discoveryURL = http://localhost:8080/juddi/uddiget.jsp?
+
+# The UDDI Operator Contact Email Address
+juddi.operatorEmailAddress = admin at juddi.org
+
+# The maximum name size and maximum number
+# of name elements allows in several of the
+# FindXxxx and SaveXxxx UDDI functions.
+juddi.maxNameLength=255
+juddi.maxNameElementsAllowed=5
+
+# The maximum number of UDDI artifacts allowed
+# per publisher. A value of '-1' indicates any
+# number of artifacts is valid (These values can be
+# overridden at the individual publisher level).
+juddi.maxBusinessesPerPublisher=25
+juddi.maxServicesPerBusiness=20
+juddi.maxBindingsPerService=10
+juddi.maxTModelsPerPublisher=100
+
+# jUDDI Authentication module to use
+juddi.auth = org.apache.juddi.auth.DefaultAuthenticator
+
+# jUDDI DataStore module currently to use
+juddi.dataStore = org.apache.juddi.datastore.jdbc.JDBCDataStore
+
+# use a dataSource (if set to false a direct
+# jdbc connection will be used.
+juddi.isUseDataSource=false
+juddi.jdbcDriver=com.mysql.jdbc.Driver
+juddi.jdbcUrl=jdbc:mysql://localhost:3306/juddi
+juddi.jdbcUsername=root
+juddi.jdbcPassword=admin
+# jUDDI DataSource to use
+# juddi.dataSource=java:comp/env/jdbc/MySqlDS
+
+# jUDDI UUIDGen implementation to use
+juddi.uuidgen = org.apache.juddi.uuidgen.DefaultUUIDGen
+
+# jUDDI Cryptor implementation to use
+juddi.cryptor = org.apache.juddi.cryptor.DefaultCryptor
+
+# jUDDI Validator to use
+juddi.validator=org.apache.juddi.validator.DefaultValidator
+
+# jUDDI Proxy Properties (used by RegistryProxy)
+juddi.proxy.adminURL = http://localhost:8080/juddi/admin
+juddi.proxy.inquiryURL = http://localhost:8080/juddi/inquiry
+juddi.proxy.publishURL = http://localhost:8080/juddi/publish
+juddi.proxy.transportClass = org.apache.juddi.proxy.AxisTransport
+juddi.proxy.securityProvider = com.sun.net.ssl.internal.ssl.Provider
+juddi.proxy.protocolHandler = com.sun.net.ssl.internal.www.protocol
+
+# JNDI settings (used by RMITransport)
+java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
+java.naming.provider.url=jnp://localhost:1099
+java.naming.factory.url.pkgs=org.jboss.naming
+
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/log4j.xml
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/log4j.xml 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/log4j.xml 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,78 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
+
+<!-- ===================================================================== -->
+<!-- -->
+<!-- Log4j Configuration -->
+<!-- -->
+<!-- ===================================================================== -->
+
+<!-- $Id: log4j.xml,v 1.26.2.5 2005/09/15 09:31:02 dimitris Exp $ -->
+
+<!--
+ | For more configuration infromation and examples see the Jakarta Log4j
+ | owebsite: http://jakarta.apache.org/log4j
+ -->
+
+<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
+
+ <!-- ============================== -->
+ <!-- Append messages to the console -->
+ <!-- ============================== -->
+
+ <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
+ <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
+ <param name="Target" value="System.out"/>
+
+ <layout class="org.apache.log4j.PatternLayout">
+ <!-- The default pattern: Date Priority [Category] Message\n -->
+ <param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%t][%c{1}] %m%n"/>
+ </layout>
+ </appender>
+
+ <!-- ================================= -->
+ <!-- Preserve messages in a local file -->
+ <!-- ================================= -->
+
+ <!-- A size based file rolling appender -->
+ <appender name="FILE" class="org.jboss.logging.appender.RollingFileAppender">
+ <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
+ <param name="File" value="./listener.log"/>
+ <param name="Append" value="false"/>
+ <param name="MaxFileSize" value="500KB"/>
+ <param name="MaxBackupIndex" value="1"/>
+
+ <layout class="org.apache.log4j.PatternLayout">
+ <param name="ConversionPattern" value="%d %-5p [%t][%c] %m%n"/>
+ </layout>
+ </appender>
+
+ <!-- ================ -->
+ <!-- Limit categories -->
+ <!-- ================ -->
+
+ <category name="org.jboss">
+ <priority value="WARN"/>
+ </category>
+ <category name="org.jboss.soa.esb">
+ <priority value="ERROR"/>
+ </category>
+ <category name="org.jboss.internal.soa.esb">
+ <priority value="ERROR"/>
+ </category>
+ <category name="org.apache">
+ <priority value="ERROR"/>
+ </category>
+ <category name="quickstart">
+ <priority value="INFO"/>
+ </category>
+ <!-- ======================= -->
+ <!-- Setup the Root category -->
+ <!-- ======================= -->
+
+ <root>
+ <appender-ref ref="CONSOLE"/>
+ <appender-ref ref="FILE"/>
+ </root>
+
+</log4j:configuration>
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/Launcher.java
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/Launcher.java 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/Launcher.java 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,81 @@
+package quickstart;
+
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.apache.log4j.Logger;
+import org.jboss.soa.esb.listeners.gateway.GatewayListenerController;
+import org.jboss.soa.esb.listeners.message.EsbListenerController;
+import org.jboss.soa.esb.listeners.message.EsbListenerControllerFactory;
+
+
+public class Launcher {
+ private static Log log = LogFactory.getLog(Launcher.class);
+
+ private EsbListenerController _esbListController;
+ private GatewayListenerController _gatewayController;
+
+
+
+ private Logger _logger = Logger.getLogger(Launcher.class);
+
+ public static void main (String args[]) throws Exception {
+
+ log.info("args passed into Launcher: " + args.length);
+ for (int x=0; x<args.length; x++)
+ log.info("arg[" + x + "]=" + args[x]);
+
+
+ Launcher launcher = new Launcher();
+
+ launcher.triggerListener(Long.valueOf(args[0]).longValue(), args[1], args[2]);
+
+ }
+
+ private void triggerListener(long runTime, String messageAwareConfigFile,
+ String gatewayConfigFile) throws Exception{
+ try
+ {
+
+ if (null != messageAwareConfigFile) {
+ _logger.info("starting message aware listener with config file - " +
+ messageAwareConfigFile);
+ _esbListController = EsbListenerControllerFactory.getInstance(messageAwareConfigFile);
+ Thread.sleep(3000);
+ }
+ if (null != gatewayConfigFile) {
+ _logger.info("starting gateway listener with config file - " +
+ gatewayConfigFile);
+ _gatewayController = new GatewayListenerController(gatewayConfigFile);
+ new Thread(_gatewayController).start();
+ Thread.sleep(2000);
+ }
+
+ System.out.println("**Listener Ready**");
+
+// This code is used to automatically shutdown the listeners which
+// might be useful for automated testing purposes. It is not needed
+// in the quickstart samples.
+// _logger.info("going to sleep now for " + runTime + " milliseconds...");
+// Thread.sleep(runTime);
+// if (null != messageAwareConfigFile) {
+// _logger.info("shutting down message aware listener...");
+// _esbListController.requestEnd();
+// }
+//
+// if (null != gatewayConfigFile) {
+// _logger.info("shutting down gateway listener...");
+// _gatewayController.requestEnd();
+// }
+
+
+ }
+ catch (Exception e) {
+ _logger.error(e);
+ throw(e);
+ }
+
+
+ }
+
+
+}
\ No newline at end of file
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/MyAction.java
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/MyAction.java 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/MyAction.java 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,60 @@
+package quickstart;
+
+import org.jboss.soa.esb.helpers.ConfigTree;
+import org.jboss.soa.esb.message.Message;
+import org.jboss.soa.esb.message.Message;
+import org.jboss.soa.esb.message.Header;
+import org.jboss.soa.esb.message.Body;
+import org.jboss.soa.esb.addressing.Call;
+import org.jboss.soa.esb.addressing.EPR;
+import org.apache.log4j.Logger;
+
+public class MyAction
+{
+
+ protected ConfigTree _config;
+
+ public MyAction(ConfigTree config) { _config = config; }
+
+ public Message noOperation(Message message) { return message; }
+
+ public Message displayMessage(Message message) throws Exception{
+ logHeader();
+ System.out.println("Body: " + new String(message.getBody().getContents()));
+ logFooter();
+ return message;
+ }
+
+ public Message playWithMessage(Message message) throws Exception {
+ Header msgHeader = message.getHeader();
+ Body msgBody = message.getBody();
+ Call theCall = msgHeader.getCall();
+ EPR theEpr = theCall.getFrom();
+ String contents = new String(msgBody.getContents());
+ StringBuffer sb = new StringBuffer();
+ sb.append("\nBEFORE\n");
+ sb.append(contents);
+ sb.append("\nAFTER\n");
+ msgBody.setContents(sb.toString().getBytes());
+ return message;
+ }
+
+ public void exceptionHandler(Message message, Throwable exception) {
+ logHeader();
+ System.out.println("!ERROR!");
+ System.out.println(exception.getMessage());
+ System.out.println("For Message: ");
+ System.out.println(message.getBody().getContents());
+ logFooter();
+ }
+
+ // This makes it easier to read on the console
+ private void logHeader() {
+ System.out.println("\n&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&");
+ }
+ private void logFooter() {
+ System.out.println("&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&\n");
+ }
+
+
+}
\ No newline at end of file
Added: labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/test/CreateTestFile.java
===================================================================
--- labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/test/CreateTestFile.java 2006-12-11 05:18:17 UTC (rev 8216)
+++ labs/jbossesb/trunk/product/samples/quickstarts/helloworld_file_action/src/quickstart/test/CreateTestFile.java 2006-12-11 05:19:32 UTC (rev 8217)
@@ -0,0 +1,27 @@
+package quickstart.test;
+
+import java.io.File;
+import java.io.IOException;
+import java.io.BufferedWriter;
+import java.io.FileWriter;
+
+public class CreateTestFile {
+
+
+ public static void main(String args[]) throws Exception
+ {
+ String inputDirectory = args[0];
+ String fileName = args[1];
+ String fileContents = args[2];
+ File x = new File(inputDirectory + "/" + fileName);
+ try {
+ BufferedWriter out = new BufferedWriter(new FileWriter(x));
+ out.write(fileContents.toCharArray());
+ out.close();
+ } catch (Exception e) {
+ System.out.println("Error while writing the file: " + inputDirectory + "/" + fileName);
+ System.out.println(e.getMessage());
+ }
+ }
+
+}
\ No newline at end of file
More information about the jboss-svn-commits
mailing list