xero by membranedev/application-skills
npx skills add https://github.com/membranedev/application-skills --skill xeroXero 是一款基于云的会计软件平台。它主要被小型企业及其会计师用于管理簿记、发票、薪资和其他财务任务。
官方文档:https://developer.xero.com/
根据需要使用的操作名称和参数。
广告位招租
在这里展示您的产品或服务
触达数万 AI 开发者,精准高效
此技能使用 Membrane CLI 与 Xero 交互。Membrane 会自动处理身份验证和凭证刷新——因此您可以专注于集成逻辑,而无需处理身份验证的底层细节。
安装 Membrane CLI,以便您可以从终端运行 membrane 命令:
npm install -g @membranehq/cli
membrane login --tenant
浏览器窗口将打开以进行身份验证。
无头环境: 运行该命令,复制打印出的 URL 供用户在浏览器中打开,然后使用 membrane login complete <code> 完成。
创建新连接:
membrane search xero --elementType=connector --json
从 output.items[0].element?.id 中获取连接器 ID,然后:
membrane connect --connectorId=CONNECTOR_ID --json
用户在浏览器中完成身份验证。输出包含新的连接 ID。
当您不确定连接是否已存在时:
检查现有连接:
membrane connection list --json
如果存在 Xero 连接,请记下其 connectionId。
当您知道要做什么但不知道确切的操作 ID 时:
membrane action list --intent=QUERY --connectionId=CONNECTION_ID --json
这将返回包含 id 和 inputSchema 的操作对象,以便您了解如何运行它。
| 名称 | 键 | 描述 |
|---|---|---|
| 列出发票 | list-invoices | 从 Xero 检索发票列表,支持可选筛选和分页 |
| 列出联系人 | list-contacts | 从 Xero 检索联系人列表,支持可选筛选和分页 |
| 列出账户 | list-accounts | 从 Xero 检索账户列表(会计科目表) |
| 列出银行交易 | list-bank-transactions | 从 Xero 检索银行交易列表 |
| 列出采购订单 | list-purchase-orders | 从 Xero 检索采购订单列表 |
| 列出项目 | list-items | 从 Xero 检索项目(产品/服务)列表 |
| 获取发票 | get-invoice | 根据 ID 从 Xero 检索单个发票 |
| 获取联系人 | get-contact | 根据 ID 从 Xero 检索单个联系人 |
| 获取账户 | get-account | 根据 ID 检索单个账户 |
| 获取银行交易 | get-bank-transaction | 根据 ID 从 Xero 检索单个银行交易 |
| 获取采购订单 | get-purchase-order | 根据 ID 从 Xero 检索单个采购订单 |
| 获取项目 | get-item | 根据 ID 从 Xero 检索单个项目 |
| 创建发票 | create-invoice | 在 Xero 中创建新发票(销售发票或账单) |
| 创建联系人 | create-contact | 在 Xero 中创建新联系人 |
| 创建银行交易 | create-bank-transaction | 创建新的银行交易(支出或收款) |
| 创建采购订单 | create-purchase-order | 在 Xero 中创建新采购订单 |
| 创建项目 | create-item | 在 Xero 中创建新项目(产品/服务) |
| 更新发票 | update-invoice | 在 Xero 中更新现有发票 |
| 更新联系人 | update-contact | 在 Xero 中更新现有联系人 |
| 更新采购订单 | update-purchase-order | 在 Xero 中更新现有采购订单 |
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json
传递 JSON 参数:
membrane action run --connectionId=CONNECTION_ID ACTION_ID --json --input "{ \"key\": \"value\" }"
当可用操作无法满足您的用例时,您可以通过 Membrane 的代理直接向 Xero 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 调用可能遗漏的分页、字段映射和边界情况。每周安装数
129
代码仓库
GitHub 星标数
18
首次出现
13 天前
安全审计
安装于
opencode129
github-copilot129
codex129
kimi-cli129
gemini-cli129
amp129
Xero is a cloud-based accounting software platform. It's primarily used by small businesses and their accountants to manage bookkeeping, invoicing, payroll, and other financial tasks.
Official docs: https://developer.xero.com/
Use action names and parameters as needed.
This skill uses the Membrane CLI to interact with Xero. 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 xero --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 Xero 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 Invoices | list-invoices | Retrieve a list of invoices from Xero with optional filtering and pagination |
| List Contacts | list-contacts | Retrieve a list of contacts from Xero with optional filtering and pagination |
| List Accounts | list-accounts | Retrieve a list of accounts (chart of accounts) from Xero |
| List Bank Transactions | list-bank-transactions | Retrieve a list of bank transactions from Xero |
| List Purchase Orders | list-purchase-orders | Retrieve a list of purchase orders from Xero |
| List Items | list-items | Retrieve a list of items (products/services) from Xero |
| Get Invoice | get-invoice | Retrieve a single invoice by ID from Xero |
| Get Contact | get-contact | Retrieve a single contact by ID from Xero |
| Get Account |
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 Xero 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
129
Repository
GitHub Stars
18
First Seen
13 days ago
Security Audits
Gen Agent Trust HubPassSocketPassSnykWarn
Installed on
opencode129
github-copilot129
codex129
kimi-cli129
gemini-cli129
amp129
Skills CLI 使用指南:AI Agent 技能包管理器安装与管理教程
36,300 周安装
| get-account |
| Retrieve a single account by ID |
| Get Bank Transaction | get-bank-transaction | Retrieve a single bank transaction by ID |
| Get Purchase Order | get-purchase-order | Retrieve a single purchase order by ID |
| Get Item | get-item | Retrieve a single item by ID |
| Create Invoice | create-invoice | Create a new invoice in Xero (sales invoice or bill) |
| Create Contact | create-contact | Create a new contact in Xero |
| Create Bank Transaction | create-bank-transaction | Create a new bank transaction (spend or receive money) |
| Create Purchase Order | create-purchase-order | Create a new purchase order in Xero |
| Create Item | create-item | Create a new item (product/service) in Xero |
| Update Invoice | update-invoice | Update an existing invoice in Xero |
| Update Contact | update-contact | Update an existing contact in Xero |
| Update Purchase Order | update-purchase-order | Update an existing purchase order in Xero |
| 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" |