Thursday, April 7, 2022

How to send multipart/form-data from OIC integration to any Endpoint

This is a common requirement where we need to transfer files using OIC integrations.

These files can be transferred for example as octet-stream or multipart/form-data etc.

In this post we will see how we can send file using multipart/form-data in OIC integration.

Let us take example where we want to use OIC Rest API to export integration from one instance and import to target instance using an OIC Integration.

The OIC rest APIs can be found  in below link:

https://docs.oracle.com/en/cloud/paas/integration-cloud/rest-api/index.html

For our example We will be using below operations:

  Retrieve Integrations
  Export an Integration
  Import(Add) an Integration

Let us create connections in OIC using rest adapter :

create one connection for source instance and other for target instance

Below is connection for target env:

We can have the url as per our requirement: 

for eg: 

https://abcd-xyz.integration.ocp.oraclecloud.com/ic/api/integration/v1

or

https://abcd-xyz.integration.ocp.oraclecloud.com/ic/api/integration

or

https://abcd-xyz.integration.ocp.oraclecloud.com/ic/api

or

https://abcd-xyz.integration.ocp.oraclecloud.com/ic

or

https://abcd-xyz.integration.ocp.oraclecloud.com

If we use for eg the last one then while configuring rest adapter in the integration we need to prefix:

/ic/api/integration/v1  along with the endpoint resource.


Below is the sample for source env connection:


Now let us create the integration :

Here in our example we are fetching only active integrations from the source env , so we will be using query parameter to filter the records while getting the list of integration. If we want to fetch all then we don't need to have the query parameter.

Note:-  if we are fetching all integrations and if the total integration number is too  high then we might need to use offset and limt.

 

 

 

 

 

 

 

We can customize the fields we want and remove other fields which we don't want. 

There will be many other fields like connection details, links etc which we don't need so we can have sample response payload like below.

 

 

 

 

 Below is the mapper for above configured adapter:

 

 

This will give us list of all the activated integrations from  source instance.

Now let us have a for each loop for each integration to export from source and import the integration to target env.

 



We can process them in parallel by checking the check box, which would do our job quickly.

Now let  us configure the rest adapter for source env connection to export the current integration in loop:


 

 

 

 

 


 

Below is the mapper for exporting integration:

 

If we observe we have used like this:

concat (substring-before ($CurrentIntToExport/nsmpr1:items/nsmpr1:id, "|" ), "%7C", substring-after ($CurrentIntToExport/nsmpr1:items/nsmpr1:id, "|" ) ) 

We have used %7C for url encoding.

Now let us see the adapter configuration for importing the exported integration in previous step.

We need to do the mapping carefully and correctly otherwise it will give 400 bad request error.

 

 

 

 

 

 

Now let us see the mapper for this:

 

 

 



 We need to mainly map below three fields:

Attachment Reference - Provide the stream reference from exporting integration response

Part Name - This will be the iar file name. We have used like below

                        concat (translate ($CurrentIntToExport/nsmpr0:items/nsmpr0:id, "|", "_" ), ".iar" )

fileInputHtmlFieldName -  For  this we need to give value as  'file' 

 

In our case the target system is configured to read from a body part having name="file" in its content disposition. This is done with the fileInputHtmlFieldName element.

The target system may also be configured to read from a body part having name="image" in its content disposition. in that case we need to provide 'image' to fileInputHtmlFieldName.

The fileInputHtmlFieldName property lets us set the name of the part 
from which the server needs to read the file. This is generally used when  there is an HTML form to   upload the file.

The fileInputHtmlFieldName element is important to consider if the target endpoint expects
attachments under a specific body part name.
The body part name should be specified here.
For example, in our case in the import integration operation, the target endpoint is expecting an iar document under a body part named file in the multipart/form-data request payload.  

 

Now let us run the integration and see the payloads and result:

For testing We have used a new Env where we do not have any integrations. 

 


Now lets run the integration:


Message sent to get activated integrations from source instance:

 

 

 

 

 


Now lets open  message received from get activated integrations:

 

 

 


 

 

 

 

 

Message sent to import int:




Now we can also verify from the target Env: