Passing parameters to a REST URI in BPEL/SOA 12c
In this blog post, I describe how, during the development of an Oracle SOA Suite 12c composite, to pass URL parameters when invoking an external REST service.
In this example, my SOA composite has 2 separate external references. These are both REST services using the GET method. The first one take the format of https://revelationtech.com/rest/v2/subscribers?q=firstname
wherein an explicit query parameter q
is passed in the URL with some value after it. The second reference takes the format of https://revelationtech.com/rest/v2/subscribers/Ahmed
, wherein Ahmed
is a parameterized part of the URL.
data:image/s3,"s3://crabby-images/2ffc1/2ffc1cfade34d3cbfe55bb4cd5206af1a10b39b9" alt=""
Passing a Query Parameter to the REST URI
For the first reference, when creating the REST adapter, it looks like the following:
data:image/s3,"s3://crabby-images/84969/8496925a6e6ff239e1078e3875e053d66edbc0d9" alt=""
When editing the method, it is configured as a GET
method and the URI parameter is defined with a runtime property rest.query.q
:
data:image/s3,"s3://crabby-images/6928b/6928be03773ee9035a881f2b6908451a99cf2c0a" alt=""
Now that the REST adapter is created, double-click on the Invoke activity in your BPEL process, navigate to the Properties tab, and manually add a property as shown. Here, the BPEL variable $inputName
becomes the value that is passed to the rest.query.q
property:
data:image/s3,"s3://crabby-images/ced1f/ced1f4a2df0f9a673e6d765e11e55d0be811ad46" alt=""
Adding a Parameterized Context Path to the REST URI
As for the the second reference, you can see here when creating the REST adapter, the {inputID}
is explicitly defined as a variable in the resource path:
data:image/s3,"s3://crabby-images/bb781/bb7812e7eb81cf3ec4770b8f91bdc26556dcbf46" alt=""
Now when you edit the method, it is also a GET
method, but the runtime property here is now rest.template.inputID
:
data:image/s3,"s3://crabby-images/a147a/a147a21516c02aa3a78f1f897358c532244e3632" alt=""
Similarly, when editing the Invoke activity in your BPEL process, simply add a property to map your BPEL variable (e.g., $input
) to the runtime property (e.g., rest.template.inputID
):
data:image/s3,"s3://crabby-images/68fe2/68fe2c8f944cb8bf7bc1be3279107976b14d1e83" alt=""