/**
 * 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.
 */


JBI Internal Provider/External Consumer Demo 
============================================

This demo illustrate how external a $SUBSTITUTE_NAME_UPPER$ client can communicate with 
an internal $SUBSTITUTE_NAME_LOWER$ server that is deployed into the $SUBSTITUTE_NAME_UPPER$ 
service engine through a generic JBI binding component (acting as a router). 

The demo consists of a $SUBSTITUTE_NAME_UPPER$ Service Engine and a ServiceMix SOAP
binding component. A $SUBSTITUTE_NAME_UPPER$ service unit (the service provider) is 
deployed into the $SUBSTITUTE_NAME_UPPER$ Service Engine. A ServiceMix SOAP binding 
service unit (the transport router) is deployed into the ServiceMix SOAP binding
component. The $SUBSTITUTE_NAME_UPPER$ service unit and ServiceMix SOAP binding service
unit are wrapped in the $SUBSTITUTE_NAME_UPPER$ demo service assembly.

A standalone $SUBSTITUTE_NAME_UPPER$ client (the service consumer) invokes the ServiceMix 
SOAP binding service unit using SOAP/HTTP, the ServiceMix SOAP binding service
routes this request to the $SUBSTITUTE_NAME_UPPER$ service unit using the JBI 
Normalized Message Router (NMR). Here the ServiceMix SOAP binding service unit 
acts as a router, connecting the $SUBSTITUTE_NAME_UPPER$ service consumer and service 
provider.

Prerequisites
-------------

The demo requires Apache ServiceMix 3.1, which you can download from:

  http://incubator.apache.org/servicemix/servicemix-31.html

It assumes some familiarity with the Java Business Integration (JBI)
specification. See the following URL for details: 

  http://java.sun.com/integration/



Building the demo
-----------------

Set the SERVICEMIX_HOME environment variable.

From the samples/integration/JBI/external_provider_external_consumer directory, 
build the demo by running:

   ant build



Installing and deploying
------------------------

Ensure that $SERVICEMIX_HOME/bin is in your path.

Start ServiceMix by running:

  servicemix


Install the $SUBSTITUTE_NAME_UPPER$ Service Engine:

   ant -f $SERVICEMIX_HOME/ant/servicemix-ant-task.xml install-component 
       -Dsm.install.file=./service-engine/build/lib/cxf-service-engine.jar  
       -Dsm.username=smx -Dsm.password=smx

Start the $SUBSTITUTE_NAME_UPPER$ Service Engine:

   ant -f $SERVICEMIX_HOME/ant/servicemix-ant-task.xml start-component 
       -Dsm.component.name=CXFServiceEngine -Dsm.username=smx -Dsm.password=smx

Install and start the ServiceMix SOAP/JMS binding component by copying the 
following files from the $SERVICEMIX_HOME/components directory to the ServiceMix 
deploy directory:

- servicemix-http-3.1-incubating-installer.zip
- servicemix-shared-3.1-incubating-installer.zip


Deploy the $SUBSTITUTE_NAME_UPPER$ demo service assembly:

   ant -f $SERVICEMIX_HOME/ant/servicemix-ant-task.xml  deploy-service-assembly 
       -Dsm.deploy.file=./service-assembly/build/lib/cxf-service-assembly.zip  
       -Dsm.username=smx -Dsm.password=smx
 
 Start the the $SUBSTITUTE_NAME_UPPER$ demo service assembly:
 
   ant -f $SERVICEMIX_HOME/ant/servicemix-ant-task.xml start-service-assembly 
       -Dsm.service.assembly.name=cxf-demo-service-assembly 
       -Dsm.username=smx -Dsm.password=smx

Start the $SUBSTITUTE_NAME_UPPER$ client

   ant client




