What is a Function?
Definition 📚​
- Function is a reusable piece of components that can be invoked by other Actions, Triggers, Events and Datatypes.
- You can use Functions to encapsulate logic that you want to reuse across multiple Actions, Triggers, Events and Datatypes.
How to use a Function?​
Let's say you have a Function named addFuction
that takes two input parameters a
and b
and returns the sum of a
and b
.
let sum = await service.fn.addFuction({ "a": 1, "b": 2 })
You can use the addFuction
Function in any Action, Trigger, Event or Datatype by calling the service.fn.addFuction
method.
How to create a Function?​
You can create a Function using the Interactor Engine UI
or REST API
.
1. Creating Function using Interactor Engine UI​
Let's try to create a Function using the Interactor Engine UI.​
-
Go to the Functions Page in Interactor Engine UI.
-
Click on the
Create Function
button.
data:image/s3,"s3://crabby-images/3d499/3d499e13dde1fde0a2e7858d408cfa992bae4cda" alt="interactorEngine"
- Set the Function Name and Label.
- Write the Function Name and Label that you want to create.
data:image/s3,"s3://crabby-images/c6c3e/c6c3e9c883ec9584fe3a411ccda6f452deda749d" alt="interactorEngine"
- Set Output and Input Variables.
- Set the
Output
and InputVariables
for the Function. I will setOutput
as number andVariables
as number and number.
data:image/s3,"s3://crabby-images/c7bc2/c7bc2fe18f4ae55e1a4d0cb418cfa6e6790789d1" alt="interactorEngine"
I just set up the Output
below way.
data:image/s3,"s3://crabby-images/92545/9254561b2b0925f0750839a2992b283f31110f50" alt="interactorEngine"
Then I set up the Variables
below way.
data:image/s3,"s3://crabby-images/c6c2d/c6c2d680b142e0a25f8c5f34fedd3937b7fdf33a" alt="interactorEngine"
- Set up the Function Logic.
First, Click on the Add Logic
button.
data:image/s3,"s3://crabby-images/bb1d9/bb1d955e643935bae2711be5c67b10f71b9b3269" alt="interactorEngine"
Then, Write the Function Logic. I will write the logic that returns the sum of two input numbers.
return arg.a + arg.b
Then Click on the Save
button.
data:image/s3,"s3://crabby-images/ea0c2/ea0c2e97facf7a0b4e994a34e4aee9f30b481c1f" alt="interactorEngine"
Done! ✨
You have successfully created a Function using the Interactor Engine UI.
2. Creating Function using Interactor Engine REST API​
You can also create a Function using the Interactor Engine REST API.
Read the Create Function for more information.
Let's try to create a Function using the Interactor Engine REST API.
curl --location 'localhost:1290/v1/connector/51055cba-4f5d-463e-9b86-c17ece94dd73/function?userId=test@interactor.com' \
--header 'Content-Type: application/json' \
--header 'api_key: default' \
--data-raw '{
"label": {
"en": "addFuction"
},
"name": "addFuction",
"argument": "arg",
"language": "javascript",
"schema": {
"output": {
"type": "number"
},
"variables": [
{
"title": "a",
"type": "number",
"x-label": {
"en": "a"
},
"x-required": true
},
{
"title": "b",
"type": "number",
"x-label": {
"en": "b"
},
"x-required": true
}
]
},
"logic": {
"execute": {
"@type": "script",
"input": {
"@type": "reference",
"operation": "source",
"path": []
},
"language": "javascript",
"script": "return arg.a + arg.b"
}
}
}'
Done! ✨
You have successfully created an Event using the Interactor Engine REST API.