From sundial-org-awesome-openclaw-skills-4
Integrates Asana REST API with Clawdbot for local OAuth setup (OOB/manual code) and managing tasks/projects/workspaces: list, search, create, update.
npx claudepluginhub joshuarweaver/cascade-ai-ml-agents-misc-2 --plugin sundial-org-awesome-openclaw-skills-4This skill uses the workspace's default tool permissions.
This skill is designed for a **personal local-only** Asana integration using **OAuth** with an **out-of-band/manual code paste** flow.
Guides Next.js Cache Components and Partial Prerendering (PPR) with cacheComponents enabled. Implements 'use cache', cacheLife(), cacheTag(), revalidateTag(), static/dynamic optimization, and cache debugging.
Guides building MCP servers enabling LLMs to interact with external services via tools. Covers best practices, TypeScript/Node (MCP SDK), Python (FastMCP).
Generates original PNG/PDF visual art via design philosophy manifestos for posters, graphics, and static designs on user request.
This skill is designed for a personal local-only Asana integration using OAuth with an out-of-band/manual code paste flow.
/users/me, /workspaces, tasks)In Asana Developer Console (My apps):
tasks:read, tasks:write, projects:read)urn:ietf:wg:oauth:2.0:oobOption 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_IDASANA_CLIENT_SECRETFrom the repo root:
node scripts/oauth_oob.mjs authorize
node scripts/oauth_oob.mjs token --code "PASTE_CODE_HERE"
Tokens are stored at:
~/.clawdbot/asana/token.jsonYou can use either:
/asana ...For Clawdbot, implement the mapping by translating the user request into the appropriate asana_api.mjs command.
Examples:
/asana tasks-assigned → tasks-assigned --assignee metasks-assigned --assignee me<project> to a project gid, then tasks-in-project --project <gid>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>