Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Integrate Asana with Clawdbot via the Asana REST API. Use when you need to list/search/create/update Asana tasks/projects/workspaces, or to set up Asana OAuth (authorization code grant) for a personal local-only integration (OOB/manual code paste).
Integrate Asana with Clawdbot via the Asana REST API. Use when you need to list/search/create/update Asana tasks/projects/workspaces, or to set up Asana OAuth (authorization code grant) for a personal local-only integration (OOB/manual code paste).
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Then review README.md for any prerequisites, environment setup, or post-install checks. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Then review README.md for any prerequisites, environment setup, or post-install checks. Summarize what changed and any follow-up checks I should run.
This skill is designed for a personal local-only Asana integration using OAuth with an out-of-band/manual code paste flow.
A small Node CLI to: generate the Asana authorize URL exchange an authorization code for access/refresh tokens auto-refresh the access token make basic API calls (e.g. /users/me, /workspaces, tasks)
In Asana Developer Console (My apps): Create app Enable scopes you will need (typical: tasks:read, tasks:write, projects:read) Set redirect URI to the OOB value (manual code): urn:ietf:wg:oauth:2.0:oob
Option A (recommended for Clawdbot): save to a local credentials file: node scripts/configure.mjs --client-id "..." --client-secret "..." This writes ~/.clawdbot/asana/credentials.json. Option B: set environment variables (shell/session): ASANA_CLIENT_ID ASANA_CLIENT_SECRET
From the repo root: Print the authorize URL: node scripts/oauth_oob.mjs authorize Open the printed URL, click Allow, copy the code. Exchange code and save tokens locally: node scripts/oauth_oob.mjs token --code "PASTE_CODE_HERE" Tokens are stored at: ~/.clawdbot/asana/token.json
You can use either: Explicit commands: start the message with /asana ... Natural language: e.g. βlist tasks assigned to meβ For Clawdbot, implement the mapping by translating the user request into the appropriate asana_api.mjs command. Examples: /asana tasks-assigned β tasks-assigned --assignee me βlist tasks assigned to meβ β tasks-assigned --assignee me βlist all tasks in <project>β β resolve <project> to a project gid, then tasks-in-project --project <gid> βlist tasks due date from 2026-01-01 to 2026-01-15β β search-tasks --assignee me --due_on.after 2026-01-01 --due_on.before 2026-01-15 (Optional helper) scripts/asana_chat.mjs can map common phrases to a command skeleton.
Sanity check (who am I): node scripts/asana_api.mjs me List workspaces: node scripts/asana_api.mjs workspaces Set a default workspace (optional): node scripts/asana_api.mjs set-default-workspace --workspace <workspace_gid> After that, you can omit --workspace for commands that support it. List projects in a workspace (explicit): node scripts/asana_api.mjs projects --workspace <workspace_gid> List projects using the default workspace: node scripts/asana_api.mjs projects List tasks in a project: node scripts/asana_api.mjs tasks-in-project --project <project_gid> List tasks assigned to me (workspace required by Asana): node scripts/asana_api.mjs tasks-assigned --workspace <workspace_gid> --assignee me Or using the default workspace: node scripts/asana_api.mjs tasks-assigned --assignee me Search tasks (advanced search): node scripts/asana_api.mjs search-tasks --workspace <workspace_gid> --text "release" --assignee me # also supports convenience: --project <project_gid> View a task: node scripts/asana_api.mjs task <task_gid> Mark a task complete: node scripts/asana_api.mjs complete-task <task_gid> Update a task: node scripts/asana_api.mjs update-task <task_gid> --name "New title" --due_on 2026-02-01 Comment on a task: node scripts/asana_api.mjs comment <task_gid> --text "Update: shipped" Create a task: node scripts/asana_api.mjs create-task --workspace <workspace_gid> --name "Test task" --notes "from clawdbot" --projects <project_gid>
OAuth access tokens expire; refresh tokens are used to obtain new access tokens. If you later want multi-user support, replace OOB with a real redirect/callback. Donβt log tokens.
Workflow acceleration for inboxes, docs, calendars, planning, and execution loops.
Largest current source with strong distribution and engagement signals.