API endpoints can be setup to enable external systems to make calls to PhixFlow. API endpoints can be seen in the Repository for your application under API Endpoints and on the Actionflow homepage with the icon.
API Endpoint Setup
API endpoints must be made using the specific option on the Actionflow homepage to ensure a URL is generated and a set of predefined input parameters are configured on the incoming connection point.
Create a new API Endpoint on the Actionflow homepage using the option
Set a unique name and provide a useful description
If you have made your API Endpoint via the Repository, right-click on the API Endpoint name and choose Display
The API Endpoint Properties will open on the right - for the full Properties list, see API Endpoint Properties
In the Basic Settings section, enable Allow Anonymous Connections
This allows anyone with the URL for the API to call it. The audit trail records the system as running performing the API call.
the name of the instance, typically this is phixflow
<<Application Name>>
The name of the application where the Actionflow resides.
<<Actionflow Name>>
The name of the actionflow set in Step 1. Note that if your actionflow has a space in the name this must be replaced with %20. For example "My API" becomes, "My%20API".
Set the API Mode:
Wait for result (Synchronous) (Default): The API waits for the results or the timeout to occur
Note: If the timeout occurs the command is aborted
Poll for result (Asynchronous): The API is called and a response is returned immediately including the process ID
Subsequent API calls can be made using the process ID to fetch the status of the action
The asynchronous mode can be thought of as “fire and forget”
Set aTimeout(optional):
Specify a maximum timein milliseconds that the API will wait for before the command is aborted
When aTimeoutvalue is set, it overrides the default timeout, which is 60 seconds whereAPI ModeisSynchronousand 500 milliseconds where API ModeisAsynchronous
However, if a timeout parameter has been provided in the URL calling this API, that will override both thisTimeoutvalue and the default value
Apply your changes
Configure the Actionflow to perform the required tasks, for example return all company data , or pass in a date and return all companies onboarded after this date
See Worked Example below for an example setup
Input Parameters
API Endpoints have fixed parameters set on the input node (body, headers, contentType and url), and the output node (body, headers, contentType and statusCode) which can be mapped to.
On the Input Connection Point, additional Input Parameters can be created to facilitate query string parameters being passed into the API via the URL.
Click on the input node
The Properties will open on the right and in the Input Parameters section, click the icon to create a new attribute
Enter a Name and Default Value (optional)
The Name set on the input must match the parameter name in the URL, e.g. if an Input Parameter, "field" is created, and the request URL is https://server/phixflow/api/1/action/App/Api/trigger?field=abc then the value "abc" will be used as a parameter. When calling APIs using query string parameters in the URL, care should be taken to ensure that the values are appropriately URL encoded to prevent unexpected behaviour. See HTTP Action Configuration.
If a parameter is missing then it will be marked as unavailable, unless a Default Value has been configured.
“timeout” is a reserved value that controls the timeout of the request and cannot be used as a parameter.
API Status Check (Poll for Result)
If calling a PhixFlow Asynchronous API only, a result will be immediately returned which includes a Process ID for that run
The Process ID is returned on the path:
$.processId
This can be accessed in an Output attribute using, _result.value
The Process ID can be used to call the following URL which will return the current state of the run:
This is set on the HTTP action on the Actionflow calling the API.
To call a PhixFlow API use the HTTP Method GET or POST:
GET simply calls the API with data passed in the body of the request
POST calls the URL and sends data in the body of the request. The body data is passed into the body attribute of the API as an Input Connection point
Returned Data JSON Path
If your API has been configured to return data the path will be in the format:
$.data.<<Output Name>>
Where <<Output Name>> is the Output connection point.
Server Console Responses
The item calling the API endpoint will receive the Response from the API endpoint stating whether it has run successfully (Success) or not (Fail). Responses can be customised to return specific messages.
The response recorded in the SystemConsole:
If you are making the call using PhixFlow the Responses can be access as follows:
Click the Actionflow entry
In the Messages section which is opened below, double-click the lines that begin Response
Click the Message Details tab to see the response
API Endpoint Results
To see the results of the API Endpoint processing in the SystemConsole:
Click the Actionflow entry for the API Endpoint
In the Messages section which is opened below, double-click any of the Messages to see more details
If you are using a debug() statement these will appear here
Failures
An API Endpoint will fail if the logic in the Actionflow fails or if the error() function is used to force a failure.
If records are passed to the API Endpoint individually a failure will only impact the specific record being processed.
Error Codes
200
Occurs if the output of an API Endpoint is not connected
Occurs if the output is connected and a record is returned
400
Occurs if the output is connected but no record is returned
Worked Example
Here's a worked example using the Company Data (available from the Learning Centre).
In this example, we are using:Â Â
A Company Call API screen containing a fixed drop down list of industries, a string fields for the API Status and a multi-line string field for the Results - this screen was created using the Tile with Buttons template
If you are completing this chapter as part of the Actionflow course and using a training instance, the screens have already been pre-loaded into the Actionflow Advanced Application. For this example, we'll be working on the Company Call API screen.
Example 1: Passing Out Data
In this example, we'll configure an API Endpoint that passes out Company ID, Company Name and Industry data from our Companies data.
Create API Endpoint
In this example, we'll set up an API Endpoint to pass out company data.
Create a new API Endpoint on the Actionflow homepage using the option
Name:API Company Data
Click Create
The API Endpoint canvas will display, with the Properties open on the right
In the Basic Settings section, enable Allow Anonymous Connections
Copy the URL and save it locally, to be used later
Apply your changes
Checkpoint
Construct JSON
Create a Calculate action
Name:GetDataAndConstructJSON
Connect the input to the Calculate action
From the Calculate action, create a lookup to the Companies data
How?
Hover over the Calculate action and select Add lookup
Name:getCo
On the Create View window:
Name:CompanyData
Table:Companies
Output Attributes Selection: drag CompanyID, CompanyName and Industry into the Output Attributes section of the View Action properties
Outgoing Mappings: map across CompanyID, CompanyName and Industry
On the Calculate action, create an attribute where the JSON will be constructed
Name:JSON
Type:Structured Data
Expression:
toJson(getCo)
Apply and Close
Checkpoint
Configure the Output
Drag the output connection node onto the Calculate node
Map the JSON attribute from the Calculate action to the body attribute
Example 2: Passing in Parameters
In this example, we'll retrieve data from our Companies API and pass in an industry parameter (e.g. "Telecoms") to filter the results to just companies in that industry.
API End Point Setup
On the API End Point, create a JSON action to receive the parameter
Name:GetIndustry
Input Expression:in.body
Path:$
Create an Output Attribute on the JSON action
Name:IndustryReceived
Type:String
Expression:_result.Industry
Insert the JSON action between the input and Calculate nodes
On the Mappings between the input and JSON nodes, map across body, contentType, headers and url
On the lookup connector, getCo, map the IndustryReceived attribute as an Incoming Mapping
On the View action, add a filter:
Name:ByIndustry
Filter Details:
Call API Actionflow Setup
On the screen, Company Call API, add an Actionflow to the Call API button