Starting a workflow from an API
Overview
Infor OS Platform features a robust API Gateway, which includes the powerful ION API Suite complete with workflow endpoints. This functionality enables seamless integration of your applications, allowing you to trigger workflows effortlessly. By leveraging these capabilities, you can enhance your system’s interoperability, streamline business processes, and achieve greater efficiency across your enterprise solutions. Join us as we uncover the potential of Infor OS Platform and its API-driven approach to modern workflow management.
Requirements
- Access to ION API Gateway
- Security role: IONAPI-Administrator
- Security role: IONAPI-User
- Infor U courses.
Tutorial
Difficulty: Medium
Estimated completion time: 30 Minutes
In this tutorial, we’ll explore the powerful capabilities of Infor OS’s API Gateway. You’ll see how its robust ION API Suite, complete with workflow endpoints, enables seamless application integration to easily trigger workflows. Discover how to enhance interoperability and streamline processes with Infor OS.
Let’s examine how to call a workflow from an API. Log in to the Infor OS Portal and select the API Gateway tab at the top of the page.
data:image/s3,"s3://crabby-images/cd7dd/cd7dd26aeebc29d71e236cd8b000362ecb7c281d" alt=""
The Available APIs option is in the navigation menu in the upper left corner. Clicking this will take you to the menu where all the accessible APIs are listed.
data:image/s3,"s3://crabby-images/155fa/155fa9588bf6a98be5e8cf44658a4c50e7cf1b53" alt=""
Using the search function at the top, Type in Infor ION and double click the Infor ION Suite.
data:image/s3,"s3://crabby-images/47e69/47e69c01a2eb27e4b8f55c8114ed461fbb140684" alt=""
It reveals a comprehensive list of endpoints, including two workflow-specific ION process endpoints. Our focus is on the IONSERVICES/process/application endpoint; proceed by clicking on its documentation.
data:image/s3,"s3://crabby-images/4b479/4b479cec70e034ba6a9d72fdc981d3601fecc3c8" alt=""
The Swagger UI interface for this endpoint is displayed.
NOTE: Swagger is a standardized UI developed by an industry group that ensures consistency across various API gateways and connection points.
What’s excellent about Swagger is its Dynamic documentation, which allows users to test the API directly from this page.
Scrolling down we find the workflow /v1/workflow/start API listed among the available methods. Click on it.
data:image/s3,"s3://crabby-images/dec03/dec0386d9abc34360c1be97aa2cea08fdf30be99" alt=""
Expanding the details revealing essential information such as required inputs. Specifically a logicalid and JSON body, it also provides a helpful example demonstrating how to structure the JSON.
data:image/s3,"s3://crabby-images/e59d3/e59d3e9b03b2b10eac3b14165f07ddbae00e8d13" alt=""
Now let’s click the try it out button.
data:image/s3,"s3://crabby-images/b4ce2/b4ce21a199db78584657c9a277572ae3f52a9627" alt=""
To execute this API, input the Logical ID following this format: lid://infor.iondesk.iondesk.It’s important to consult your system administrator to confirm your environment setup. Additionally, input the JSON body.
A generic JSON is displayed as a default example or guide. We will paste the JSON using the following example, which specifies the workflowName of WF_DEMO and the pre-assigned instanceName of TestInstance. Even though this workflow doesn’t require any inputs, we’ll include one for demonstration.
data:image/s3,"s3://crabby-images/53b4f/53b4f8ca7c25a832ede4b3fb7eec0c418ddbfe98" alt=""
Click the Execute button.
data:image/s3,"s3://crabby-images/0a002/0a0020dda454eccc2c6e10a017302c94d76a5006" alt=""
Below in the server response section, we’ve achieved a Code 200, signifying a successful execution. The response body reveals the ID of the workflow that’s up and running.
data:image/s3,"s3://crabby-images/7e734/7e7347c75772691c58485f00e9bf7f6a13e6e4dd" alt=""
We’ll be using Postman to make a request call. Postman is a popular and freely available API client that can be found online.
First, on the OS portal, we must build an Authorized App using the Web Application type for the request in Postman’s OAuth2 Authentication setup. In this case, the application has not yet been authenticated within the Gateway. The user must authorize the mobile application to call the ION API on their behalf. This type of interaction uses the OAuth2 Authorization Code Grant.
data:image/s3,"s3://crabby-images/c5215/c52158ce8e5bc216d3d7266cb38cc8d44c13801c" alt=""
On the navigation menu select Authorized Apps, then select the + button to create a new authorized app.
data:image/s3,"s3://crabby-images/4b86a/4b86a4f04e4bb1eba8c3bdbfa870ee32cfb05dd9" alt=""
In the Name field enter Postman Web App Demo. For the Type, choose Web Application, and in the Description field, enter Postman Web App. Enter the Postman Redirect URL In this example, we will use this https://oauth.pstmn.io/v1/browser-callback. The Authorized JavaScript Origins field will be the same callback URL.
NOTE: In this tutorial, we signed in and configured Postman through the browser. https://web.postman.co/
data:image/s3,"s3://crabby-images/e050b/e050b5435ccec568bc928fc7becd79ea1f7043fd" alt=""
Click Save.
data:image/s3,"s3://crabby-images/58d8b/58d8b1bc99f083e3225516238110530341f71917" alt=""
The Gateway will generate your Client ID and Client Secret, click the Download Credentials button to download the credentials file.
data:image/s3,"s3://crabby-images/49992/49992aa1b63aa50efb1a6b947a10a59922b59304" alt=""
Open and view the Postman Web App Demo.ionapi credentials file, which will look like this. The file holds the details to call the API and Postman.
data:image/s3,"s3://crabby-images/821d9/821d91a65ae0a23de8652676a6fede7a8dfb1a6d" alt=""
Log into Postman and create a new request collection using the Authorization methods template; click the + sign in the top left corner and select the View more templates link, or you can click the + sign in the tab section.
NOTE: Again, in this tutorial, we signed in and configured Postman through the browser. https://web.postman.co/
data:image/s3,"s3://crabby-images/97bd1/97bd1b8d384b1b0396e856af41835565247b08d8" alt=""
Click the Authorization methods button.
data:image/s3,"s3://crabby-images/41bc1/41bc17c73a8128015a946b5d95ff8bd026d6766b" alt=""
Click the Use Template button.
data:image/s3,"s3://crabby-images/add18/add183119185a686540d1c20c26a8717e233a766" alt=""
On the Authorization methods collection, click on the eclipsis and select Add request.
data:image/s3,"s3://crabby-images/639e8/639e8c3ca074df9468aa5c9ed0195366e88d149e" alt=""
On the New Request collection, click on the ellipsis and select Rename. Give the Collection a new name.
data:image/s3,"s3://crabby-images/29657/29657a4ac852aad77f610f99e08f01947bd8baaf" alt=""
We will name it API Workflow Demo.
data:image/s3,"s3://crabby-images/ccf0b/ccf0b1122577f3dab8e5fabd940e47624847cf96" alt=""
Within the Params tab, enter the IFS Service /application/V1/workflow/start ION API URL in the POST parameters field.
In this example we will enter https://mingle-ionapi.inforcloudsuite.com/STARGATE_DEM/IONSERVICES/process/application/v1/workflow/start?logicalId=lid://infor.iondesk.iondesk
NOTE: We’ve chosen the POST operation because the API Gateway specifies that the workflow start method is a POST
method.
The key named logicalId will be filled in with the required value for our API. lid://infor.iondesk.iondesk
data:image/s3,"s3://crabby-images/c6e39/c6e39dbd1c9e50c79a8da84076d339e6f4aab9c1" alt=""
Select the Authorization tab, and in the Auth Type field, choose OAuth 2.0.
data:image/s3,"s3://crabby-images/696f6/696f65d27a0f0df8b599f5b96c9f771c18674530" alt=""
To acquire a new access token, scroll down to the Configure New Token section and enter the following Postman Mapping information from the downloaded Postman Web App Demo.ionapi credentials file performed in the previous steps.
data:image/s3,"s3://crabby-images/c3faf/c3faf1e7c0ed39d915169ce8f742c93ad434d11d" alt=""
Enter the relevant credentials into the required input parameter. In the Token Name field, enter Auth Code Token and set Grant type to Authorization Code. The Callback URL is the embedded Postman link (https://oauth.pstmn.io/v1/browser-callback). The Auth URL is a concatenation of values pu + oa, similarly, the Access Token URL is a concatenation of pu + ot, The Client ID is value ci and the Client Secret is cs.
data:image/s3,"s3://crabby-images/d42de/d42deab893c18e95425967a2d70a685da12360f3" alt=""
Scroll to the bottom of the page and click the Get New Access Token button.
data:image/s3,"s3://crabby-images/81a1e/81a1e1273fe83d9a8ef5b41ca0dfb822b7b769a7" alt=""
Postman will initiate a handshake with Infor’s Cloud OAuth authentication and take you to a login screen, where you must sign in.
NOTE: Remember this is an activity in which the user must be present. The sign on must be performed, and the user is required to authorize the application I.E Postman, to call the API.
Once signed in you can see infor OS is prompting the Request For Approval regarding Postman using our credentials. Click the Allow button.
data:image/s3,"s3://crabby-images/855d8/855d8ceb2570afa7b351bfb5b241d1c374b49fd7" alt="This image has an empty alt attribute; its file name is image-77.png"
You will get the following message. You can click the Proceed button or wait a few seconds. The Manage Access Token screen will then appear.
data:image/s3,"s3://crabby-images/f6a7f/f6a7fe3f4719208e3ae68f8a892211c0e7b701ff" alt=""
This will provide a new token within the Postman application. On the Manage Access Tokens screen, click the Use Token button.
data:image/s3,"s3://crabby-images/94001/94001a780aaa4b60175b8a276bff9210cca765b6" alt=""
NOTE: When you click the Use Token button, a message will appear in the lower right hand corner saying that the Token was added.
data:image/s3,"s3://crabby-images/da6df/da6dfda0a6a04cebee7ae077aed6e4d787a62be5" alt=""
Click on the Body tab where we’ll enter our JSON to call the API and kick off the workflow. Ensure the format is set to raw and JSON is selected from the dropdown.
Paste in the script we successfully tested previously when we did the “try it out” in the ION API section of this tutorial.
data:image/s3,"s3://crabby-images/53b4f/53b4f8ca7c25a832ede4b3fb7eec0c418ddbfe98" alt=""
data:image/s3,"s3://crabby-images/8139b/8139b1b12fff35114b5493ecaf18f5135f01d66f" alt=""
Click the Send button, to trigger the chain of events we’ve set up.
data:image/s3,"s3://crabby-images/5229d/5229d2f11515840f40604575215655db68985c0c" alt=""
You can see that the call was successful. Error Code 200 and a job ID of 56903.
data:image/s3,"s3://crabby-images/67e9c/67e9c9c194b1d0271d1a3dd909fd01250b200a89" alt=""
Go back to the OS Portal, and view active workflows in ION.
Click the ION tab, and in the navigation menu expand Monitors and Workflows and select Active Workflows.
data:image/s3,"s3://crabby-images/97ac7/97ac795ade5f9df300b47d7338b49fb27f2e9d63" alt=""
Searching for the WF_DEMO workflow. You can see the last one has a status of Running.
data:image/s3,"s3://crabby-images/3554e/3554e9ae73ea4fd9a5d9c1b5a9b6dc1273cd0e6e" alt=""
Let’s confirm it’s the one we executed in Postman by clicking on Workflow Instances.
data:image/s3,"s3://crabby-images/a5389/a5389fcced1affa0c863370cb8230149326ccdba" alt=""
There’s the matching job ID of 56903 we got from Postman.
data:image/s3,"s3://crabby-images/2be79/2be79596c77c3b3ab94c2f42ef5721040e46bed8" alt=""
This Concludes this Tutorial on how to Start a workflow from an API.
Watch the following video to view all the steps that were covered.
Resources
Help Documents and User Guides