invokeAPI
To check out examples of the invokeAPI action, go to the Ensemble Kitchen Sink (opens in a new tab).
API response object
Both the onResponse
and onError
actions provide reference to the API response object. The response
object has the following propertuies available to you.
Property | Type | Description |
---|---|---|
statusCode | number | Http status code. See details here (opens in a new tab) |
body | String | the actual body of the response. This is where you are mostly interested in. JSON responses are automatically parsed and made available. Other content-types are available as strings. |
headers | array | Key value pairs of http response headers |
reasonPhrase | String | Phrase that describes the statusCode. Http response statusCode is a 3 digit number and reasonPhrase describes that number. For example - reasonPhrase for statusCode between 200 and 299 (inclusive) is Successful. More here (opens in a new tab) |
type | String | By default the invokeAPI action is used to call http(s) APIs whether REST o GraphQL APIs. However, Ensemble has a deep integration with firestore. if the type is specificed as firestore , this action will invoke firestore APIs. For details and examples, see Firestore Operations |
API/invokeAPI properties
Property | Type | Description |
---|---|---|
id | String | Give the API an ID allows you to bind to its result. e.g. ${apiId.body...} |
name | String | Name of the API defined in the API section |
inputs | Object | Key value pairs ofinputs to be passed to API definition |
onResponse | Action | The action to handle the response. This action can access the response object. For example - response.body or event overwrite the body as response.body = myJsonObject; |
onError | Action | The action to handle errors. Just like onResponse, you have the response object available here so you can check response.statusCode to see what error was sent by the server and then use response.body to access the error response |
Content Types
The API supports different content types for request bodies:
-
JSON (Default)
- If no Content-Type is specified, the body is sent as JSON
- Content-Type: application/json
-
URL Encoded Form Data
- Set Content-Type: application/x-www-form-urlencoded
- Body will be automatically encoded in URL-encoded format
Example with URL-encoded form data:
API:
loginUser:
uri: https://api.example.com/login
method: POST
headers:
Content-Type: application/x-www-form-urlencoded
body:
username: ${username}
password: ${password}
invokeAPI is used for calling an API. You can call an API on events such as a button tap or on screen load. First, you have to declare an API:
API:
getPeople:
uri: https://randomuser.me/api/?results=8
method: GET
Usage examples of InvokeAPI
Now to call the API on screen load, use the onLoad
property of the view, there are two ways to call invokeAPI as well
1. Using ensemble invokeAPI action.
View:
onLoad:
invokeAPI:
name: getPeople
body:
Column:
styles: { gap: 16, padding: 24 }
children:
- Text:
text: ${getPeople.body.results.length} records were retrieved from API
- Markdown:
text: |
Here's the API response body:
```
${getPeople.body}
```
API:
getPeople:
uri: https://randomuser.me/api/?results=8
method: GET
2. Using JavaScript code block to execute invokeAPI action.
View:
onLoad: |
//@code
ensemble.invokeAPI("getPeople");
body:
Column:
styles: { gap: 16, padding: 24 }
children:
- Text:
text: ${getPeople.body.results.length} records were retrieved from API
- Markdown:
text: |
Here's the API response body:
```
${getPeople.body}
```
API:
getPeople:
uri: https://randomuser.me/api/?results=8
method: GET
- Its similar to previous only that we are now using Javascript code block.
To call an API on button tap, inside the body add a Button with onTap
property:
View:
body:
Column:
styles: { gap: 16, padding: 24 }
children:
- Button:
label: Call API
onTap:
invokeAPI:
name: getPeople
- Column:
item-template:
data: ${getPeople.body.results}
name: item
template:
Text:
text: ${item.name.first}
API:
getPeople:
uri: https://randomuser.me/api/?results=8
method: GET
POST calls with input parameters
You can also create a POST request and pass parameters to the API like this
View:
body:
Column:
styles: { gap: 16, padding: 24 }
children:
- Button:
label: Call API
onTap:
invokeAPI:
name: createToDo
inputs:
name: "some value"
onResponse: |
//@code
var id = response.body.records[0].id;
postStatus.text = 'Record created: ' + id;
- Text:
id: postStatus
API:
createToDo:
inputs:
- name
uri: "https://api.airtable.com/v0/appDbkGS4VOiPVQR5/ToDo?api_key=keyyWz426zsnMKavb"
method: "POST"
body:
records:
- fields:
desc: "${name}"
Handing errors
To handle Errors, you can use the onError
property:
- Text:
text: Handle error
- Button:
label: Call API
onTap:
invokeAPI:
name: createToDoError
onResponse: |
//@code
apiStatus.text = 'Call was successful';
//you have the response object available here so you access its properties. See top of the page for response object
console.log(response.body);//this will print out the full body of the response object. See above for all the properties of a response object
onError: |
//@code
apiStatus.text = 'API returned an error';
//you have the response object available here so you access its properties. See top of the page for response object
console.log(response.statusCode);//this will print out the http status code of the response object. See above for all the properties of a response object
- Text:
id: apiStatus
API:
createToDoError:
inputs:
- name
uri: 'https://api.airtable.com/v0/appDbkGS4VOiPVQR5/ToDo?api_key=keyyWz426zsnMKavb'
method: 'POST'
body:
records: "this is not what the API expects"
Use in code
You can also call an API in code block.
- Button:
label: Call API
onTap:
executeCode:
body: |
//@code
// no inputs
ensemble.invokeAPI("getNewYorkTime");
- Text:
visible: ${getNewYorkTime.body != null}
text: Current time in NYC is ${getNewYorkTime.body.datetime}
API:
getNewYorkTime:
uri: https://worldtimeapi.org/api/timezone/America/New_York
method: GET
Properties for invokeAPI
Property | Type | Description |
---|---|---|
id | String | Give the API an ID allows you to bind to its result. e.g. ${apiId.body...} |
name | String | Name of the API defined in the API section |
inputs | Object | Key value pairs ofinputs to be passed to API definition |
onResponse | Action | The action to handle the response |
onError | Action | The action to handle errors |
Details about API here