xero mcp

Local 2025-08-31 23:50:14 0

An MCP server allowing Clients to interact with Xero Accounting Software


smithery badge

This MCP server allows Clients to interact with Xero Accounting Software.

Get Started

  1. Make sure node and Claude Desktop are installed.

  2. Create an OAuth 2.0 app in Xero to get a CLIENT_ID and CLIENT_SECRET.

  3. Create a free Xero user account (if you Do not have one)

  4. Login to Xero Developer center https://developer.xero.com/app/manage/
  5. Click New app
  6. Enter a name for your app
  7. Select Web app
  8. Provide a valid URL (can be anything valid eg. https://www.myapp.com)
  9. Enter redirect URI: http://localhost:5000/callback
  10. Tick to Accept the Terms & Conditions and click Create app
  11. On the left-hand side of the screen select Configuration
  12. Click Generate a secret

  13. Modify claude_desktop_config.json file

{
  "mcpServers": {
    "xero-mcp": {
      "command": "npx",
      "args": ["-y", "xero-mcp@latest"],
      "env": {
        "XERO_CLIENT_ID": "YOUR_CLIENT_ID",
        "XERO_CLIENT_SECRET": "YOUR_CLIENT_SECRET",
        "XERO_REDIRECT_URI": "http://localhost:5000/callback"
      }
    }
  }
}
  1. Restart Claude Desktop

  2. When the Client decides to access a Xero tool for the first time, a Xero login page will pop up to ask your consent. Complete the auth flow and manually close the web page (as the Xero page will not auto close in this version)

Privacy alert: after completing the Xero OAuth2 flow, your Xero data may go through the LLM that you use. If you are doing testing you should authorize to your Xero Demo Company.

Tools

  • authenticate

Authenticate with Xero using OAuth2

  • create_bank_transactions

Creates one or more spent or received money transaction

  • create_contacts

Creates one or multiple contacts in a Xero organisation

  • get_balance_sheet

Retrieves report for balancesheet

  • list_accounts

Retrieves the full chart of accounts

  • list_bank_transactions

Retrieves any spent or received money transactions

  • list_contacts

Retrieves all contacts in a Xero organisation

  • list_invoices

Retrieves sales invoices or purchase bills

  • list_journals

Retrieves journals

  • list_organisations

Retrieves Xero organisation details

  • list_payments

Retrieves payments for invoices and credit notes

  • list_quotes

Retrieves sales quotes

Examples

  • "Visualize my financial position over the last month"

  • "Track my spendings over last week"

  • "Add all transactions from the monthly statement into my revenue account (account code 201) as receive money"

License

MIT