Custom actions
Learn how to build custom actions that will listen to your integration triggers and carry out the action of your choosing.
An action is a type of workflow block (which is a part of an integration recipe) that will "do something" after a trigger is invoked. It accomplishes what you’re looking to do with your recipe. It can change your monday data and initiate changes on other platforms too.
Examples of actions are:
- Create an item in monday.com
- Change an item's status in monday.com
- Send an email using Gmail
- Create a row in a spreadsheet
If you take a look at any integration recipe in the features section of one of your apps, you can choose a built-in action:
There are two types of actions: Built-in actions and Custom actions.
Custom actions allow you to perform any action that is not supported by our built-in blocks.
You can use either built-in or custom triggers to perform your desired manipulation and final action (e.g., a Status change on a board can populate some data into your own -- or any third party -- system).
Mechanisms behind custom actions
When an action is triggered in your custom integration recipe, the monday apps server will send a POST request to the run URL configured in your custom action block.
This Run URL will receive an HTTP POST request from monday with a body such as this:
{
"payload": {
"blockKind": "action",
"inboundFieldValues": {
"boardId": 1234567890,
"columnId": "text"
"itemId": 9876543210
},
"inputFields": { // input fields are based on the input fields configuration of your action and depend on the field type
"boardId": 1234567890,
"itemId": 9876543210,
"columnId": "text"
},
"recipeId": 123456, //unique ID of the recipe for your app. if multiple accounts are using the same recipe, the same recipe ID will be sent
"integrationId": 123456 //unique ID of the integration recipe added to your board
},
"runtimeMetadata": {
"actionUuid": "a6676dzce11zd50b25c4871417e1zez1", // uuid that represents the execution of the action
"triggerUuid": "z607d55cc428bb438ba02cbbcde6a25e" // uuid that represents the execution of the entire automation (same as run id in the activity log)
}
}
Receiving this payload, your program should respond with a status of 200 indicating that the action was performed successfully. If your server responds with any other status, or doesn’t respond within a minute, the monday platform will retry calling your endpoint every minute for 30 minutes.
Keep in mind the custom actions you create can also be used in more than one recipe in your custom app! This is important as your actions should be designed for reusability. Some examples of custom actions include: “create a lead in Salesforce,” or “update a status in JIRA,” or even “send SMS via Twilio.”
Configuring your custom action
You can set up a custom action for your recipes in the Workflow Blocks tab of an integration feature.
To better demonstrate this process, we'll be using an example from the Integrations Quickstart template in the following sections. We recommend reviewing the quickstart so you can follow along.
Custom action ownership
Custom actions are linked to the user who created them. They can't be edited by others unless the automation ownership is transferred.
Define action sentence
Your action sentence describes what action or event your app will accomplish. The example from the Quickstart Integrations template is “translate it into {text column, targetColumn}.”
Your action sentence can contain fields that are configurable by the user. In order to add a field to your sentence, use the {FIELD_LABEL, FIELD_KEY}
format.
For example, “When {text column, columnId} changes, translate it {to, transformationType} into {text column, targetColumn}”.
Configure action input fields
The output fields in the trigger block feed into the input fields of your action block. In this way, we are mapping the relevant trigger output fields directly into your action’s input fields.
The “types” of input fields for your custom action are dictated by where the field is coming from. In the dropdown menu for any input field, you can see there are three options:
- Context - Get the value of this field from the context in which the action is executing (for example the userId of the user who set up the recipe, or the boardId of the board in which the recipe was set up).
- Trigger Output - Get the value of this field from one of the output fields of your recipe trigger (for example the itemId of the item whose Status column was used to trigger the recipe).
- Recipe Sentence - Get the value of this field from the configuration chosen by the user in the recipe sentence.
The input fields of this Quickstart Integration recipe action (i.e. the ‘input field settings section’) are as follows:
Field Key | Type | Description |
---|---|---|
boardId | Context | The board where the recipe was created |
itemId | Trigger Output | The item that was selected, and consequently outputted in your trigger |
sourceColumnId | Trigger Output | The first text column selected in your recipe |
targetColumnId | Recipe Sentence | The second text column the user will choose |
transformationType | Recipe Sentence | The type of transformation the user selects for this recipe (either turning their text into uppercase or lowercase) |
This is what it will look like in the action configuration:
NOTE
The max character limit for a custom trigger or action is 255 characters for each one - meaning they can be used together for a total of 510 characters on the entire recipe. As a best practice we recommend making recipes short and easily configurable, breaking the logic into multiple recipes if necessary.
Updated 3 days ago