installing_scripts_by_asana.mp4
- Inside of a project, navigate to > "Customize" > "Rules" > "Create custom rule"
- Navigate to "Do this..." > "External actions" > "Run script" > "Connect to Scripts by Asana"
- A new tab will open, displaying the Grant Permission page for the app. Click on "Allow"
- You should now be authenticated and are now ready to start creating automation rules with Script Actions
default_script.mp4
-
Inside of a project navigate to > "Customize" > "Rules" > "Create custom rule"
-
Select a trigger (e.g., "Task is assigned"):
-
Configure a condition for the "+ Check if..." step or delete that step
-
Navigate to "Do this..." > "External actions" > "Run script" you should be presented with the script editor. This is where you will want to write/provide your script.
Script Actions utilizes the node-asana (v3.X.X) client library to make API calls to Asana.
In each script action run, we provide you with the following variables:
project_gid
: The project's gidtask_gid
: The gid of the task that the rule triggered onworkspace_gid
: The workspace gid
You can utilize this information to write a Script Action scripts using the node-asana (v3.X.X) client library.
For this example, we will just uncomment the provided sample script. The sample script fetches the information about the triggered task and appends the text "longer name" to the end of the task name.
-
Click on the "Publish rule" button
-
Trigger your rule. In this scenario, we configured our rule to trigger when a task is assigned to a user in our project.
The following is a way to write/test your script on your computer. You can copy the code below into your code editor and start working through the TODOs.
Pre-requisite:
- Make sure you have Node.js installed on your computer
- Make sure you have
v3.X.X
version of node-asana (npm) installed on your computer - Create a file for your script. Copy and paste the below script into that file. EX:
test.js
- Go through the TODOs outlined in the below script
- Test your script
node <YOUR_SCRIPT_FILE_NAME>.js
. EX:node test.js
TIP: You can reference the "Documentation for API Endpoints" section of node-asana README.md
to reference sample code and endpoints for your script.
/*
This is template code for you to test your script actions locally on your computer
1. Make sure you have Node.js installed on your computer
2. Make sure you have v3.X.X version of the node-asana client library installed on your computer
3. Create a file and copy this code over to that file (EX: test.js)
4. Go through the TODOs outlined in this script
5. Test your script by running "node test.js" in your terminal
*/
const Asana = require('asana');
let client = Asana.ApiClient.instance;
let token = client.authentications['token'];
// TODO: Replace <YOUR_PERSONAL_ACCESS_TOKEN> with your Personal Access Token (PAT)
// NOTE: This is only used for testing your script locally
token.accessToken = "<YOUR_PERSONAL_ACCESS_TOKEN>";
const log = console.log;
// Set your project, task and workspace gid here
// These will be provided to you when the script gets executed.
// We want to emulate that so we set those values here
//
// TODO: Set these values
const project_gid = "123";
const task_gid = "456";
const workspace_gid = "789";
// Set up the resource instances that you plan on using for your script here
// Script actions will make these available for you in the script editor
//
// TODO: instantiate the Asana resources that you plan on using in your script
// EX: If you want to make API calls to the tasks endpoint, uncomment the line below
// let tasksApiInstance = new Asana.TasksApi();
/*
----------------------------------------------------------------------------------------
Write your script below, then COPY and PASTE your script into the script editor
----------------------------------------------------------------------------------------
*/
/**
* What's in scope?
* 1. (number) project_gid, workspace_gid, task_gid (only if triggered on a task)
* 2. (function) log - this behaves like console.log and takes any number of parameters
* 3. (object) *ApiInstance - for each group of APIs, an object containing functions to call the APIs; for example:
* tasksApiInstance.getTask(...)
* goalsApiInstance.addFollowers(...)
* For more info, see https://github.com/Asana/node-asana
*/
const run = async () => {
// TODO: YOUR SCRIPT HERE
};
run();
Example use case
/*
This is template code for you to test your script locally on your computer
1. Make sure you have Node.js installed on your computer
2. Make sure you have v3.X.X version of the node-asana client library installed on your computer
3. Create a file and copy this code over to that file (EX: test.js)
4. Go through the TODOs outlined in this script
5. Test your script by running "node test.js" in your terminal
*/
const Asana = require('asana');
let client = Asana.ApiClient.instance;
let token = client.authentications['token'];
// TODO: Replace <YOUR_PERSONAL_ACCESS_TOKEN> with your Personal Access Token (PAT)
// NOTE: This is only used for testing your script locally
token.accessToken = "<YOUR_PERSONAL_ACCESS_TOKEN>";
const log = console.log;
// Set your project, task and workspace gid here
// These will be provided to you when the script gets executed.
// We want to emulate that so we set those values here
//
// TODO: Set these values
const project_gid = "123";
const task_gid = "456";
const workspace_gid = "789";
// Set up the resource instances that you plan on using for your script here
// Script actions will make these available for you in the script editor
let tasksApiInstance = new Asana.TasksApi();
/*
----------------------------------------------------------------------------------------
Write your script below, then COPY and PASTE your script into the script editor
----------------------------------------------------------------------------------------
*/
/**
* What's in scope?
* 1. (number) project_gid, workspace_gid, task_gid (only if triggered on a task)
* 2. (function) log - this behaves like console.log and takes any number of parameters
* 3. (object) *ApiInstance - for each group of APIs, an object containing functions to call the APIs; for example:
* tasksApiInstance.getTask(...)
* goalsApiInstance.addFollowers(...)
* For more info, see https://github.com/Asana/node-asana
*/
const run = async () => {
// Generate a random number
const randomNum = Math.random();
// Get information about the triggered task
const task = await tasksApiInstance.getTask(task_gid, {});
// Update the task name. Append random number to name of the triggered task
await tasksApiInstance.updateTask(
{
data: {
name: `${task.data.name} - ${randomNum}`
}
},
task_gid
);
};
run();
testing_locally.mov
debugging_errors.mov
If your script executes but doesn't yield the expected outcome, it might be due to encountering an error.
When this happens you can use the log
function to assist in diagnosing your issue.
You can view your logs by going to your script actions rule's "Run history" tab.
Note
- Logs have a character limit of 5,000 and will be truncated if they exceed this limit.
- Script action scripts are enclosed in their own
try...catch
statement. If your script also contains atry...catch
statement, errors may not appear as errors but may instead be displayed as logs in the "Run history" tab.
Example script action script with error:
/**
* What's in scope?
* 1. (number) project_gid, workspace_gid, task_gid (only if triggered on a task)
* 2. (function) log - this behaves like console.log and takes any number of parameters
* 3. (object) *ApiInstance - for each group of APIs, an object containing functions to call the APIs; for example:
* tasksApiInstance.getTask(...)
* goalsApiInstance.addFollowers(...)
* For more info, see https://github.com/Asana/node-asana
*/
const run = async () => {
// Generate a random number
const randomNum = Math.random();
// Get information about the triggered task
// The error here is that we provided a gid that does not exist in our domain
const task = await tasksApiInstance.getTask("123");
};
run();
Example error shown in logs:
Encountered an error: {"name":"PromiseRejected","message":"Bad Request","stack":" at run (eval.js:15)\n"}
Finished in N/A ms.