Introduction
As we know how to expose a WCF service as RESTFul service using the POST method. That is direct as we are doing for the exposing normal WCF service.
I tried with the POST method for the RestFull service and I have created it in an hour. But doing the GET endpoint is painful. As we don’t have much document Online. So I have done so much research and found a very good post provide by Steef Jan Wiggers (Microsoft Azure MVP).
Background
Scenario:
Client need to trigger the service without any input, our RestAPI service should send back the response with JSON format by executing the SQL StoredProcedure.
Using the code
Solution:
- Create two Schema for the WCF Service Request and Response
- Create a Table and Stored procedure to retrieve the details from the table without passing a parameter.
- Create a Stored procedure schema from the created Storedprocedure.
- Create a Map to Map the SP Response to WCF Response
- Create a Custom Receive Pipeline to promote a fields. Get from the below URL:
https://github.com/BizTalkComponents/HttpDisassembler
- Create a Custom Send Pipeline with JSON Encode to send JSON message back to the service.
- Create an Orchestration to execute the Stored proc and convert the Storedprocedure response to WCF Rest Service response.
Steps to Create Solution:
- Create a Schema and promote the field as property promotion.
data:image/s3,"s3://crabby-images/3fb37/3fb37bbde4790c33d8bc22ff19f43ea24aa8f696" alt="Image 1"
Promote the tenantId field as a Property promotion.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 2"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 3"
- Add SQL StoredProcedure Schema à Add Generated Item à Consume Adapter service à Add
Provide the corresponding SQL connection string and select Strongly Typed Stored procedure, It create a Schema.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 4"
- Create a Map, StoredProcedure Response to RestAPI response.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 5"
- Create Orchestration to retrieve stored procedure and map the SP response to the WCF Service response and send back to the same req-resp port.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 6"
- Create a Receive Pipeline to promote the fields which we promoted.
Get the HTTP disassembler Pipeline component from the below URL:
https://github.com/BizTalkComponents/HttpDisassembler
Folder: src\HttpDisassembler\
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 7"
- Create a Send pipeline JSON Encoder to convert the xml to JSON.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 8"
- Build and Deploy the solution to Admin Console.
- Create a Service by following the below steps.
Select BizTalk WCF Service Publishing wizard .
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 9"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 10"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 11"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 12"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 13"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 14"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 15"
Goto IIS HTTPRestServiceDemo Directory Browsing Enable
Then Browse the Service
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 16"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 17"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 18"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 19"
DocumentSpecname : <Name>, <Assembly>
Eg: DemoSchema.JsonCarrier, DemoSchema, Version=1.0.0.0, Culture=neutral, PublicKeyToken=36c63864bb129606
Provide the above details in the DocumentSpecName and Enable the Receive Location by selecting appropriate Pipeline.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 20"
To Enable the MetaData follow below steps:
Goto C:\inetpub\wwwroot\HTTPRestServiceDemo Web.config
<behavior name="ServiceBehaviorConfiguration">
<serviceDebug httpHelpPageEnabled="true" httpsHelpPageEnabled="false" includeExceptionDetailInFaults="false" />
<serviceMetadata httpGetEnabled="True" httpsGetEnabled="false" />
</behavior>
Make httpGetEnabled= True as above sample.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 21"
Now we successfully Published the RestService.
- By Default the Exposed service is enabled for the POST method, now we need to change to GET method.
- Follow the below steps to make the GET Endpoint.
GOTO Receive Location Configuration
Under HTTP Method Copy paste the below code:
<BtsHttpUrlMapping>
<Operation Method="GET" Url="/tenantId/{pid}" />
<Operation Method="GET" Url="/tenantId" />
</BtsHttpUrlMapping>
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 22"
Goto Edit (Variable Mapping)
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 23"
propertyNameSpace == https://Carrier.Schema.PropertySchema
Now we converted the POST as GET method successfully.
- Now we need to Test the Service.
We can test using Soap UI:
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 24"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 25"
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 26"
Change the Resource URL from /HTTPRestServiceDemo/Service1.svc to /HTTPRestServiceDemo/Service1.svc/tenantId/34 As we promoted the tenantId so the message will automatically triggered to BizTalk.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 27"
You will get the response as the above screenshot.
Points of Interest
1. How to Expose the WCF service as a Rest/Json Service.
2. How to Use GET endpoint using BizTalk Server
3. Learn to expose BizTalk Schema as WCF Rest service thro JSON.
Reference:
https://social.msdn.microsoft.com/Forums/en-US/3680aec0-c8be-4f25-8e49-5088e6d37ef6/biztalk-jsonrest-service-with-the-get-method?forum=biztalkgeneral
http://blog.ibiz-solutions.se/integration/exposing-a-rest-get-endpoint-using-biztalk-server-2013/