Developing Your First Integration Solution

Integration developers need efficient tools to build and test all the integration use cases required by the enterprise before pushing them into a production environment. The following topics will guide you through the process of building and running an example integration use case using WSO2 Integration Studio. This tool contains an embedded WSO2 Micro Integrator instance as well as other capabilities that allows you to conveniently design, develop, and test your integration artifacts before deploying them in your production environment.

Use case

We are going to use the same use case we considered in the Quick Start Guide. In the quick start guide, we just executed the already-built integration scenario. Here, we are going to build the integration scenario from scratch. Let’s recall the business scenario:

Integration Scenario

The scenario is about a basic healthcare system where WSO2 Micro Integrator is used as the integration middleware. Most healthcare centers use a system to help patients book doctor appointments. To check the availability of doctors, patients will typically use each and every online system that is dedicated for a particular healthcare center or personally visit the healthcare centers.

We will simplify this process of booking doctor appointments by building an integration solution that orchestrates the isolated systems in each healthcare provider and exposes a single interface to the users.

Both the Grand Oak service and Pine Valley service are exposed over the HTTP protocol.

  • The Grand Oak service accept GET requests in the following service endpoint url:

    http://<HOST_NAME>:<PORT>/grandOak/doctors/<DOCTOR_TYPE>

  • The Pine Vallery service accepts POST requests in the following service endpoint url:

    http://<HOST_NAME>:<PORT>/pineValley/doctors

    The expected payload should be in the following JSON format:

    {
            "doctorType": "<DOCTOR_TYPE>"
    }

Let’s implement a simple Rest API that can be used to query the availability of doctors for a particular category from all the available healthcare centers.

Set up the workspace

Download the relevant WSO2 Integration Studio based on your operating system. For more information, see Installing WSO2 Integration Studio.

Develop the integration artifacts

Step 1: Create projects

Let's create the required project directories (to store artifacts) in WSO2 Integration Studio.

  1. Open WSO2 Integration Studio.
  2. Go to Integration and click Create Integration Project in the Getting Started view.

    Getting Started Dashboard

  3. In the New Integration Project wizard that opens, enter HealthcareConfigProject as the project name.

    Tip

    Be sure to leave the Create Composite Application Project check box selected.

  4. Click Finish to save the projects. The projects are listed in the project explorer as shown below.

    The HealthcareConfigProject folder stores the integration (synapse) artifacts and the HealthcareConfigProjectCompositeApplication folder stores the composite application project that is used for packaging the integration artifacts.

Step 2: Create Endpoints

The actual back-end services (healthcare services) are logically represented in the integration solution as Endpiont artifacts.

Let's create two Endpoint artifacts for the two healthcare services:

  1. Right-click HealthcareConfigProject and go to NewEndpoint to open the New Endpoint Artifact dialog box.

  2. Select Create a New Endpoint and click Next.

  3. For the ‘Grand Oak hospital service’, let’s use the following values:

    Parameter Value
    Endpoint Name GrandOakEndpoint
    Endpoint Type HTTP Endpoint
    URI Template http://localhost:9090/grandOak/doctors/{uri.var.doctorType}
    Method GET

  4. Click Finish to save the endpoint configuration.

  5. Follow the same steps to create an endpoint for ‘Pine Valley Hospital’. Use the following parameter values:

    Parameter Value
    Endpoint Name PineValleyEndpoint
    Endpoint Type HTTP Endpoint
    URI Template http://localhost:9091/pineValley/doctors
    Method POST

Step 3: Create the REST API

We are orchestrating multiple services and exposing a single API to the clients. The main integration artifact is going to be a REST API.

  1. Right-click HealthcareConfigProject in the project explorer and go to NewREST API to open the API Artifact Creation Options dialog box.
  2. Select Create A New API Artifact and click Next.
  3. Specify values for the required REST API properties:

    Parameter Value
    Name HealthcareAPI
    Context /healthcare

  4. Click Finish. The REST API is created in the src/main/synapse-config/api folder under HealthcareConfigProject.

  5. Open the new artifact from the project explorer. You will see the graphical view of the HealthcareAPI with its default API Resource.

    API Resource

    To the left of the editor, you will see the Mediators palette containing various mediators that can be dragged and dropped into the canvas of the API Resource.

  6. Double-click the API resource to open the Properties view:

    Resource Properties

    Specify values for the required resource properties:

    Parameter Value
    Url Style URL_TEMPLATE
    Uri Template /doctor/{doctorType}

    Note that '{doctorType}' is a uri variable that gets resolved to the path parameter value in the runtime. We can access the value of the uri variable in the mediation flow using the variable (property) called ‘uri.var.doctorType’.
    Methods Get

Step 4: Create the mediation logic

  1. Create two parallel message flows:

    In this scenario, the Healthcare API receives an HTTP GET request, which should be delivered to two different back-end services. That is, we need to clone the message into two branches and process them in parallel. To do that, we can use the Clone Mediator.

    Drag the Clone mediator from the mediator palette and drop it into the request path (inSequence) of the API Resource canvas.

    Clone

    Right-click the Clone mediator and select Add/Remove Target... In the Add Target Branches window, set the number of branches to 2. You will now see two branches inside the Clone mediator.

    Clone Branches

  2. Invoke the GrandOak Endpoint:

    The Call mediator is used to invoke a back-end service. In Step 2, we have already created an Endpoint to represent the GrandOak endpoint.

    Drag the Call mediator from the mediator palette into one branch of the Clone mediator.

    Call Mediator

    Then, drag the already-defined GrandOak endpoint artifact, which is available under the Defined Endpoints section of the palette, into the Call mediator.

    Call Mediator EP

  3. Construct message payload for the PineValley Endpoint:

    Unlike the GrandOAK endpoint, which accepts a simple GET request, the PineValley endpoint requires a POST request with the following JSON message:

    {
        "doctorType": "<DOCTOR_TYPE>"
    }

    Therefore, we need to first construct the required message payload. There are several Transformation mediators available for constructing messages. Let's use the PayloadFactory mediator. Drag the PayloadFactory mediator into the 2nd branch of the Clone mediator as shown below.

    PayloadFactory Mediator

    Specify values for the required PayloadFactory properties:

    Parameter Value
    Payload Format Inline
    Media Type json
    Payload { "doctorType": "$1" }
    Args $ctx:uri.var.doctorType

    Note the $1 in the Payload format. It denotes a parameter that can get a value assigned dynamically. The value for the parameters need to be assigned using Arguments (Args). Args can be added using the PayloadFactoryArgument dialog box, which appears when you click the + sign.

    PayloadFactory Mediator Args

    In the PayloadFactoryArgument dialog box, select Expression as the Argument Type, and click Argument Expression. You will then see the Expression Selector dialog box. Enter $ctx:uri.var.doctorType as the value for the expression.

  4. Invoke the PineValley Endpoint:

    Use the Call mediator to invoke the PineVallery Endpoint. Follow the same steps you used under ‘Invoke GrandOak Endpoint’.

  5. Aggregating response messages:

    Since we are cloning the messages and delivering into two different services, we will receive two responses. So we need to aggregate those two responses and construct a single response. To do that, we can use the Aggregate mediator.

    Drag the Aggregate mediator and drop it next to the Clone mediator as shown below.

    Aggregate Mediator

    Specify values for the required Aggregate mediator properties.

    Parameter Value
    Aggregation Expression json-eval($.doctors.doctor)
  6. Send a response back to the client:

    To send the response back to the client, we can use the Respond mediator. Place the Respond mediator inside the Aggregate mediator as shown below.

    Respond Mediator

The final mediation configuration looks similar to the above diagram.
Following is what you will see in the Source View of WSO2 Integration Studio.

<?xml version="1.0" encoding="UTF-8"?>
<api context="/healthcare" name="HealthcareAPI" xmlns="http://ws.apache.org/ns/synapse">
<resource methods="GET" uri-template="/doctor/{doctorType}">
    <inSequence>
  <clone>
      <target>
    <sequence>
        <call>
      <endpoint key="GrandOakEndpoint"/>
        </call>
    </sequence>
      </target>
      <target>
    <sequence>
        <payloadFactory media-type="json">
      <format>{
            "doctorType": "$1"
               }
      </format>
      <args>
          <arg evaluator="xml" expression="$ctx:uri.var.doctorType"/>
      </args>
        </payloadFactory>
        <call>
      <endpoint key="PineValleyEndpoint"/>
        </call>
    </sequence>
      </target>
  </clone>
  <aggregate>
      <completeCondition>
    <messageCount max="-1" min="-1"/>
      </completeCondition>
      <onComplete expression="json-eval($.doctors.doctor)">
    <respond/>
      </onComplete>
  </aggregate>
    </inSequence>
    <outSequence/>
    <faultSequence/>
</resource>
</api>

Build and run the artifacts

There are several ways to deploy and run the integration scenario.

Option 1: Using WSO2 Integration Studio

  1. Right-click HealthcareConfigProjectCompositeApplication and click Export Project Artifacts and Run.

  2. You will see the following dialog box. Select the HealthcareConfigProject in the artifact list and click Finish.

    The embedded Micro Integrator starts with the deployed artifacts.

Option 2: Using a local Micro Integrator instance

Before you begin, be sure to install the Micro Integrator on your machine:

  1. Go to the website to download the Micro Integrator.
  2. Click Download and see that the installation options are listed. You can either download and run the installer, or use the binary file. The home directory of your Micro Integrator installation will be referred to as <MI_HOME> from hereon.

Once you have downloaded and set up the Micro Integrator locally, follow the steps given below.

  1. Export the artifacts as a deployable CAR file: Right-click HealthcareConfigProjectProjectCompositeApplication in WSO2 Integration Studio and select Export Composite Application Project.

  2. Deploy the Healthcare service: Copy the exported CAR file of the Healthcare service to the MI_HOME/repository/deployment/server/carbonapps directory.

  3. Start the Micro Integrator:

    If you set up the product using the installer, follow the steps relevant to your OS as shown below.

    • On MacOS/Linux/CentOS, open a terminal and execute the following command:
      sudo wso2mi
    • On Windows, go to Start Menu -> Programs -> WSO2 -> Micro Integrator. This will open a terminal and start the Micro Integrator.

    If you set up the product using the binary distribution, open a terminal, navigate to the <MI_HOME>/bin directory, and execute the command relevant to your OS as shown below.

    • On MacOS/Linux/CentOS:
      sh micro-integrator.sh
    • On Windows:
      micro-integrator.bat

Start back-end services

Let's start the mock back-end services for this use case:

  1. Download the DoctorInfo.jar file. This contains two healthcare services.
  2. Open a terminal, navigate to the location of the downloaded DoctorInfo.jar file, and execute the following command to start the services:

    java -jar DoctorInfo.jar

You will see the following printed on your terminal:

[ballerina/http] started HTTP/WS listener 0.0.0.0:9090
[ballerina/http] started HTTP/WS listener 0.0.0.0:9091

Invoke the Healthcare service

You can use the HTTP client in WSO2 Integration Studio or any other external client.

Option 1: Using WSO2 Integration Studio

Let's invoke the API from the embedded HTTP Client of WSO2 Integration Studio as follows:

  1. Open the HTTP Client of WSO2 Integration Studio:

    Tip

    If you don't see the HTTP Client tab, go to Window -> Show View - Other and select HTTP Client to enable the client tab.

  2. Enter the request information as given below and click the Send icon ().

    Method GET
    URL http://localhost:8290/healthcare/doctor/Ophthalmologist

The response is printed in the HTTP Response section.

[
    [
        {
            "name": "John Mathew",
            "time": "03:30 PM",
            "hospital": "Grand Oak"
        },
        {
            "name": "Allan Silvester",
            "time": "04:30 PM",
            "hospital": "Grand Oak"
        }
    ],
    [
        {
            "name": "John Mathew",
            "time": "07:30 AM",
            "hospital": "pineValley"
        },
        {
            "name": "Roma Katherine",
            "time": "04:30 PM",
            "hospital": "pineValley"
        }
    ]
]

Option 2: Using your terminal

If you want to send the client request from your terminal:

  1. Install and set up cURL as your REST client.
  2. Open a terminal and execute the following curl command to invoke the service:

    curl -v http://localhost:8290/healthcare/doctor/Ophthalmologist

What's Next

Top