How to: Transform a Message and Route to a Service Endpoint Using a Request-Response Message Exchange Pattern
Goal
This section demonstrates how to use the ESB Designer domain-specific language (DSL) to create a request-response itinerary that can be used with a two-way on-ramp. You will create a routing slip to receive a message, transform the message, submit the message to a service, and return the service response message to the submitter of the original message.
In this How-to topic, you will complete the following steps:
Create an itinerary routing slip with a transform itinerary service that implements a Microsoft BizTalk Server map.
Configure the itinerary to route the transformed message to a service endpoint.
Configure the itinerary to return the service response message to the original sending party.
Test the itinerary using the Itinerary Test Client sample application.
Prerequisites
The procedures in this How-to topic require the completion of the Prerequisites for the Development Activities.
Steps
To create an ESB itinerary DSL model
In Visual Studio, open C:\HowTos\Patterns\Patterns.sln.
In Solution Explorer, right-click the ItineraryLibrary project, point to Add, and then click New Itinerary.
In the Add New Item dialog box, in the Name box, type RequestResponse, and then click Add.
To configure the properties of the itinerary
In Visual Studio, click the design surface of RequestResponse.itinerary. In the RequestResponse Properties window, configure the following properties:
In the Is Request Response drop-down list, click True.
In the Model Exporter drop-down list, click XML Itinerary Exporter.
In the Extender Settings section, next to the Itinerary XML file property, click the ellipsis button (...).
In the Select XML File dialog box, in the File name box, type C:\HowTos\Itineraries\RequestResponse, and then click Save.
Note
This step enables you to export the itinerary as XML to a local file location. By exporting an itinerary to a local file location, instead of to the itinerary database, enables testing of the itinerary using the ESB Test Client application. You will complete this process later in this How-to topic.
To define the structure of the itinerary
From the Toolbox, drag an On-Ramp model element to the design surface. In the OnRamp1 Properties window, configure the following properties:
Click the Name property, and then type ReceiveNAOrder.
In the Extender drop-down list, click On-Ramp ESB Extender.
In the BizTalk Application drop-down list, click Microsoft.Practices.ESB.
In the Receive Port drop-down list, click OnRamp.Itinerary.Response.
From the Toolbox, drag an Itinerary Service model element to the design surface, and then place it to the right of the On-Ramp model element. In the ItineraryService1 Properties window, configure the following properties:
Click the Name property, and then type MapNAOrderToCNOrder.
In the Itinerary Service Extender drop-down list, click Messaging Extender.
Note
This property defines that the process will take place in a pipeline (messaging). Alternately, if the process will take place in an orchestration, set the Itinerary Service Extender property to Orchestration Extender.
In the Container drop-down list, expand ReceiveNAOrder, and then click Receive Handlers.
In the Service Name drop-down list, click Microsoft.Practices.ESB.Services.Transform.
Right-click the Resolver collection of the MapNAOrderToCNOrder model element, and then click Add new Resolver. In the Resolver1 Properties window, configure the following properties:
Click the Name property, and then type StaticallySpecifyTheMap.
In the Resolver Implementation drop-down list, click Static Resolver Extension.
In the Transform Type drop-down list, click GlobalBank.ESB.DynamicResolution.Transforms.SubmitOrderRequestNA_To_SubmitOrderRequestCN.
In the Toolbox, click Connector. Drag a connection from the ReceiveNAOrder model element to the MapNAOrderToCNOrder model element.
From the Toolbox, drag an Itinerary Service model element to the design surface, and then place it to the right of the MapNAOrderToCNOrder model element. In the ItineraryService1 Properties window, configure the following properties:
Click the Name property, and then type RouteToCNService.
In the Itinerary Service Extender drop-down list, click Messaging Extender.
Note
This property defines that the process will take place in a pipeline (messaging). Alternately, if the process will take place in an orchestration, set the Itinerary Service Extender property to Orchestration Extender.
In the Container drop-down list, expand ReceiveNAOrder, and then click Receive Handlers.
In the Service Name drop-down list, click Microsoft.Practices.ESB.Services.Routing.
Right-click the Resolver collection of the RouteToCNService model element, and then click Add new Resolver. In the Resolver1 Properties window, configure the following properties:
Click the Name property, and then type StaticallySpecifyTheService.
In the Resolver Implementation drop-down list, click Static Resolver Extension.
In the Transport Name drop-down list, click WCF-BasicHttp.
Click the Transport Location property, and then type http://localhost/ESB.CanadianServices/SubmitPOService.asmx.
Click the Target Namespace property, and then type http://globalbank.esb.dynamicresolution.com/canadianservices.
Click the Action property, and then type submitOrder.
In the Toolbox, click Connector. Drag a connection from the MapNAOrderToCNOrder model element to the RouteToCNService model element.
From the Toolbox, drag an Off-Ramp model element to the design surface, and then place it to the right of the RouteToCNService model element. In the OffRamp1 Properties window, configure the following properties:
Click the Name property, and then type InvokeCNService.
In the Extender drop-down list, click Off-Ramp ESB Extender.
In the BizTalk Application drop-down list, click GlobalBank.ESB.
In the Send Port drop-down list, click DynamicResolutionSolicitResp.
From the Toolbox, drag an Itinerary Service model element to the design surface, and then place it between the RouteToCNService model element and the InvokeCNService model element. In the ItineraryService1 Properties window, configure the following properties:
Click the Name property, and then type SendPortFilter.
In the Itinerary Service Extender drop-down list, click Off-Ramp Extender.
In the Off-Ramp drop-down list, expand InvokeCNService, and then click Send Handlers.
In the Toolbox, click Connector. Drag a connection from the RouteToCNService model element to the SendPortFilter model element.
In the Toolbox, click Connector. Drag a connection from the SendPortFilter model element to the InvokeCNService model element.
Right-click the design surface, and then click Validate.
Note
The itinerary validates; it is not necessary to connect the off-ramp back to the on-ramp in order to send the response message back to the requesting party. By using a two-way on-ramp, the final message is automatically returned to the requesting party.
To export the model for use with the Itinerary Test Client
In Visual Studio, right-click the design surface of the RequestResponse itinerary, and then click Export Model.
Note
The XML version of the itinerary opens in Visual Studio.
Save all project artifacts.
In Windows Explorer, browse to C:\HowTos\Itineraries. Notice the creation of your itinerary XML (RequestResponse.xml).
To test the itinerary
Open the Itinerary Test Client sample application using the shortcut created during the Prerequisites for the Development Activities (C:\HowTos\ESB.Itinerary.Test.exe - Shortcut).
In the Itinerary Test Client, clear the Use WCF Service check box.
In the Web Service Options section, select the Two Way Service check box, and then click Load Itinerary.
In the Open Itinerary File dialog box, browse to C:\HowTos\Itineraries. Select RequestResponse.xml, and then click Open to load the itinerary.
Click OK to clear the Itinerary Loaded Successfully message.
In the Itinerary Test Client, click the ellipsis button (...) next to the Load Message box.
In the Select XML Document to load dialog box, browse to C:\HowTos. Select NAOrderDoc.xml, and then click Open to load the test message.
Click the Submit Request button. When the test completes, click OK to dismiss the confirmation that appears.
In the Results box, notice the message's root node is submitOrderResponse and the default namespace is ... canadianservices.
Note
If the response message requires additional transformation before the response is sent to the requesting party, you must use a pipeline that contains the ESB Forwarder component. For an example of this functionality, see the Installing and Running the Multiple Web Services Sample.
Additional Resources
For more information, see the following related topics: