asana by membranedev/application-skills
npx skills add https://github.com/membranedev/application-skills --skill asanaAsana 是一款项目管理工具,可帮助团队组织、跟踪和管理工作。项目经理、团队和个人使用它来规划和执行任务、项目和工作流。
官方文档:https://developers.asana.com/
根据需要使用操作名称和参数。
此技能使用 Membrane CLI 与 Asana 交互。Membrane 会自动处理身份验证和凭证刷新——因此您可以专注于集成逻辑,而无需处理身份验证的底层细节。
安装 Membrane CLI,以便您可以从终端运行 membrane 命令:
npm install -g @membranehq/cli
membrane login --tenant
浏览器窗口将打开以进行身份验证。
无头环境: 运行该命令,复制打印的 URL 供用户在浏览器中打开,然后使用 完成。
广告位招租
在这里展示您的产品或服务
触达数万 AI 开发者,精准高效
membrane login complete <code>创建新连接:
membrane search asana --elementType=connector --json
从 output.items[0].element?.id 获取连接器 ID,然后:
membrane connect --connectorId=CONNECTOR_ID --json
用户在浏览器中完成身份验证。输出包含新的连接 ID。
当您不确定连接是否已存在时:
检查现有连接:
membrane connection list --json
如果存在 Asana 连接,请记下其 connectionId。
当您知道要做什么但不知道确切的操作 ID 时:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
这将返回包含 id 和 inputSchema 的操作对象,以便您知道如何运行它。
| 名称 | 键 | 描述 |
|---|---|---|
| 列出任务 | list-tasks | 从 Asana 获取多个任务。 |
| 列出项目 | list-projects | 从 Asana 获取多个项目。 |
| 列出用户 | list-users | 获取工作区或组织中的所有用户 |
| 列出标签 | list-tags | 获取工作区中的所有标签 |
| 列出分区 | list-sections | 获取项目中的所有分区 |
| 列出工作区 | list-workspaces | 获取授权用户可见的所有工作区 |
| 列出项目任务 | list-project-tasks | 获取项目中的所有任务 |
| 列出子任务 | list-subtasks | 获取任务的所有子任务 |
| 列出任务评论 | list-task-comments | 获取任务的所有评论(故事) |
| 获取任务 | get-task | 通过其 GID 获取单个任务 |
| 获取项目 | get-project | 通过其 GID 获取单个项目 |
| 获取用户 | get-user | 通过其 GID 获取单个用户,或使用 'me' 获取已验证用户 |
| 创建任务 | create-task | 在 Asana 中创建新任务 |
| 创建项目 | create-project | 在 Asana 中创建新项目 |
| 创建标签 | create-tag | 在工作区中创建新标签 |
| 创建分区 | create-section | 在项目中创建新分区 |
| 更新任务 | update-task | 更新 Asana 中的现有任务 |
| 更新项目 | update-project | 更新 Asana 中的现有项目 |
| 删除任务 | delete-task | 从 Asana 中删除任务 |
| 删除项目 | delete-project | 从 Asana 中删除项目 |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
传递 JSON 参数:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
当可用操作无法满足您的用例时,您可以通过 Membrane 的代理直接向 Asana API 发送请求。Membrane 会自动将基础 URL 附加到您提供的路径,并注入正确的身份验证标头——如果凭证过期,还会透明地刷新。
membrane request CONNECTION_ID /path/to/endpoint
常用选项:
| 标志 | 描述 |
|---|---|
-X, --method | HTTP 方法(GET、POST、PUT、PATCH、DELETE)。默认为 GET |
-H, --header | 添加请求头(可重复),例如 -H "Accept: application/json" |
-d, --data | 请求体(字符串) |
--json | 发送 JSON 正文并设置 Content-Type: application/json 的简写 |
--rawData | 按原样发送正文,不进行任何处理 |
--query | 查询字符串参数(可重复),例如 --query "limit=10" |
--pathParam | 路径参数(可重复),例如 --pathParam "id=123" |
membrane action list --intent=QUERY(将 QUERY 替换为您的意图)以查找现有操作。预构建的操作处理分页、字段映射和原始 API 调用可能遗漏的边缘情况。每周安装数
88
代码仓库
GitHub 星标数
18
首次出现
2026年3月4日
安全审计
安装于
opencode88
github-copilot88
codex88
kimi-cli88
amp88
cline88
Asana is a project management tool that helps teams organize, track, and manage their work. It's used by project managers, teams, and individuals to plan and execute tasks, projects, and workflows.
Official docs: https://developers.asana.com/
Use action names and parameters as needed.
This skill uses the Membrane CLI to interact with Asana. Membrane handles authentication and credentials refresh automatically — so you can focus on the integration logic rather than auth plumbing.
Install the Membrane CLI so you can run membrane from the terminal:
npm install -g @membranehq/cli
membrane login --tenant
A browser window opens for authentication.
Headless environments: Run the command, copy the printed URL for the user to open in a browser, then complete with membrane login complete <code>.
Create a new connection:
membrane search asana --elementType=connector --json
Take the connector ID from output.items[0].element?.id, then:
membrane connect --connectorId=CONNECTOR_ID --json
The user completes authentication in the browser. The output contains the new connection id.
When you are not sure if connection already exists:
Check existing connections:
membrane connection list --json
If a Asana connection exists, note its connectionId
When you know what you want to do but not the exact action ID:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
This will return action objects with id and inputSchema in it, so you will know how to run it.
| Name | Key | Description |
|---|---|---|
| List Tasks | list-tasks | Get multiple tasks from Asana. |
| List Projects | list-projects | Get multiple projects from Asana. |
| List Users | list-users | Get all users in a workspace or organization |
| List Tags | list-tags | Get all tags in a workspace |
| List Sections | list-sections | Get all sections in a project |
| List Workspaces | list-workspaces | Get all workspaces visible to the authorized user |
| List Project Tasks | list-project-tasks | Get all tasks in a project |
| List Subtasks | list-subtasks | Get all subtasks of a task |
| List Task Comments | list-task-comments | Get all comments (stories) on a task |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
To pass JSON parameters:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
When the available actions don't cover your use case, you can send requests directly to the Asana API through Membrane's proxy. Membrane automatically appends the base URL to the path you provide and injects the correct authentication headers — including transparent credential refresh if they expire.
membrane request CONNECTION_ID /path/to/endpoint
Common options:
| Flag | Description |
|---|---|
-X, --method | HTTP method (GET, POST, PUT, PATCH, DELETE). Defaults to GET |
-H, --header | Add a request header (repeatable), e.g. -H "Accept: application/json" |
-d, --data | Request body (string) |
--json | Shorthand to send a JSON body and set Content-Type: application/json |
--rawData |
membrane action list --intent=QUERY (replace QUERY with your intent) to find existing actions before writing custom API calls. Pre-built actions handle pagination, field mapping, and edge cases that raw API calls miss.Weekly Installs
88
Repository
GitHub Stars
18
First Seen
Mar 4, 2026
Security Audits
Gen Agent Trust HubPassSocketPassSnykWarn
Installed on
opencode88
github-copilot88
codex88
kimi-cli88
amp88
cline88
| Get Task | get-task | Get a single task by its GID |
| Get Project | get-project | Get a single project by its GID |
| Get User | get-user | Get a single user by their GID or 'me' for the authenticated user |
| Create Task | create-task | Create a new task in Asana |
| Create Project | create-project | Create a new project in Asana |
| Create Tag | create-tag | Create a new tag in a workspace |
| Create Section | create-section | Create a new section in a project |
| Update Task | update-task | Update an existing task in Asana |
| Update Project | update-project | Update an existing project in Asana |
| Delete Task | delete-task | Delete a task from Asana |
| Delete Project | delete-project | Delete a project from Asana |
| Send the body as-is without any processing |
--query | Query-string parameter (repeatable), e.g. --query "limit=10" |
--pathParam | Path parameter (repeatable), e.g. --pathParam "id=123" |