Skip to content

Dominicpalaciod/script-actions-examples

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 

Repository files navigation

script-actions-examples

Installation

installing_scripts_by_asana.mp4
  1. Inside of a project, navigate to > "Customize" > "Rules" > "Create custom rule"
  2. Navigate to "Do this..." > "External actions" > "Run script" > "Connect to Scripts by Asana"
  3. A new tab will open, displaying the Grant Permission page for the app. Click on "Allow"
  4. You should now be authenticated and are now ready to start creating automation rules with Script Actions

Usage: Default Script

default_script.mp4
  1. Inside of a project navigate to > "Customize" > "Rules" > "Create custom rule"

  2. Select a trigger (e.g., "Task is assigned"):

  3. Configure a condition for the "+ Check if..." step or delete that step

  4. 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 gid
    • task_gid: The gid of the task that the rule triggered on
    • workspace_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.

  5. Click on the "Publish rule" button

  6. Trigger your rule. In this scenario, we configured our rule to trigger when a task is assigned to a user in our project.

Developing/Testing your script locally on your computer

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:

  1. Make sure you have Node.js installed on your computer
  2. Make sure you have v3.X.X version of node-asana (npm) installed on your computer
  3. Create a file for your script. Copy and paste the below script into that file. EX: test.js
  4. Go through the TODOs outlined in the below script
  5. 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/Logging

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.

More details

logs 1 logs 2 logs 3 logs 3

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 a try...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.

Example Scripts

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 100.0%