Generate a REST API from a SOAP Backend¶
You can use WSO2 API Cloud to easily expose legacy SOAP backends as REST APIs. WSO2 API Cloud supports generating REST APIs from WSDL 1.1 based SOAP backends.
Follow the instructions below to generate a REST API using an existing SOAP backend. For the purpose of demonstration, we will use sample values when following the instructions below:
Note
- Before you begin...
- Make sure that you have a valid WSDL URL from the SOAP backend. It should belong to the WSDL 1.1 version.
- Be sure to specify the endpoint when creating a REST service from a SOAP WSDL. This is necessary because the endpoint does not get picked up by the WSDL unless you specify it.
-
Sign in to WSO2 API Cloud. This opens the API Publisher portal.
-
Click CREATE API and then click I Have a SOAP Endpoint.
Info
- You can either select WSDL URL and specify the file URI (i.e., the relative path to the file with the API definition) or you can select WSDL Archive/File and upload your WSDL file.
- Following are the two options you can use to create APIs for SOAP backends:
- Pass Through – Creates a pass-through proxy for SOAP requests coming to the API Gateway. This option is selected by default in the UI
- Generate REST APIs – Generates REST API definitions from the given WSDL URL.
-
Specify the WSDL URL for the SOAP backend and select Generate REST APIs. Let's specify
http://ws.cdyne.com/phoneverify/phoneverify.asmx?wsdl
as the sample WSDL URL. -
Click Start Creating and provide information of the API. Let's provide the following sample values for demonstration:
Field Sample value Name PhoneVerification Context /phoneverify Version 1.0 Access Control All Visibility on Store Unlimited Tags phone -
Click Next:Implement. This takes you to the Implement tab.
-
Click Managed API to expand the section.
-
Select the Endpoint Type as
HTTP/SOAP Endpoint
and specify the production endpoint URL. Let's specifyhttp://ws.cdyne.com/phoneverify/phoneverify.asmx
as the sample production endpoint URL. -
Navigate to the SOAP to REST Mapping section and click on a resource to view the In and Out sequences of the API. Following is an example that shows the generated sample API In-sequence for a POST method:
<header description="SOAPAction" name="SOAPAction" scope="transport" value="http://ws.cdyne.com/PhoneVerify/query/CheckPhoneNumber"/> <property name="REST_URL_POSTFIX" scope="axis2" action="remove"/> <property expression="json-eval($.CheckPhoneNumber.LicenseKey)" name="req.var.CheckPhoneNumber.LicenseKey"/> <property expression="json-eval($.CheckPhoneNumber.PhoneNumber)" name="req.var.CheckPhoneNumber.PhoneNumber"/> <payloadFactory description="transform" media-type="xml"> <format> <soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope" xmlns:web="http://ws.cdyne.com/PhoneVerify/query"> <soapenv:Header/> <soapenv:Body> <web:CheckPhoneNumber xmlns:web="http://ws.cdyne.com/PhoneVerify/query"> <web:LicenseKey>$1</web:LicenseKey> <web:PhoneNumber>$2</web:PhoneNumber> </web:CheckPhoneNumber> </soapenv:Body> </soapenv:Envelope> </format> <args> <arg evaluator="xml" expression="get-property('req.var.CheckPhoneNumber.LicenseKey')"/> <arg evaluator="xml" expression="get-property('req.var.CheckPhoneNumber.PhoneNumber')"/> </args> </payloadFactory> <property description="messageProperty" name="messageType" scope="axis2" type="STRING" value="application/soap+xml"/>
The incoming JSON message parameters are stored using properties. A payload factory mediator is used to generate the SOAP payload required by the backend.
-
Click Next:Manage. This takes you to the Manage tab.
-
On the Manage tab, select required Subscription Tiers for the API and then click Save & Publish to publish the API to the API Store.
-
Navigate to the API Store and subscribe to the API. For detailed instructions on how to subscribe to an API, see Subscribe to an API.
Once you generate the production and sandbox keys, you will receive a valid access token to access the API.
-
Invoke the API. For detailed instructions, see Invoke an API.
Once you successfully invoke the API, you can observe the actual backend response you get.