Skip to main content

MCP server for OpenAccountants tax skills

Project description

OpenAccountants MCP Server

A read-only Model Context Protocol server that gives Claude, Cursor, and any MCP client on-demand access to 134 countries of open-source tax skills — no manual file uploads.

Why this exists

Without MCP, using OpenAccountants means downloading a country folder and dragging .md files into your LLM by hand, every conversation. With MCP, your AI assistant discovers and fetches the right skills automatically:

You:    "Help me with my Malta taxes. Here's my bank statement."
          ↓
Claude: calls list_jurisdictions → sees "malta"
Claude: calls list_files("malta") → foundation.md, malta-vat.md, …
Claude: calls get_file("malta", "foundation.md") → full skill in context
Claude: calls get_file("malta", "malta-vat.md") → VAT rules loaded
          ↓
Claude: now processes your bank statement with the right tax rules

Install once, configure once — skills are available in every conversation from that point on.

Tools

Tool Description
list_jurisdictions Returns every country slug that has at least one .md skill file under packages/.
list_files Given a jurisdiction slug (e.g. malta), returns the .md / .json filenames in that package.
get_file Given a jurisdiction + filename, returns the full UTF-8 text of that skill file (capped at 2 MB).

All access is read-only and path-sandboxed to the packages/ directory.

Quick start

1. Clone and install

Requires Python 3.10+.

git clone https://github.com/openaccountants/openaccountants.git
cd openaccountants
pip install ./mcp

Or with uv (recommended):

uv pip install ./mcp

2. Connect to your AI client

Pick one of the following.

Claude Desktop

Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS):

{
  "mcpServers": {
    "openaccountants": {
      "command": "openaccountants-mcp"
    }
  }
}

If installed in a virtualenv or with uv:

{
  "mcpServers": {
    "openaccountants": {
      "command": "uv",
      "args": ["run", "--directory", "/path/to/openaccountants/mcp", "openaccountants-mcp"]
    }
  }
}

Cursor

Add to .cursor/mcp.json in the project (or via Cursor Settings > MCP):

{
  "mcpServers": {
    "openaccountants": {
      "command": "openaccountants-mcp"
    }
  }
}

Any other MCP client

Run openaccountants-mcp (or python -m openaccountants_mcp) as a stdio transport server.

3. Start chatting

Help me with my 2025 taxes. Here's my bank statement.

The AI will call the MCP tools behind the scenes to load the right country skills, then classify transactions and produce a working paper — all without you uploading a single file.

Environment variables

Variable Default Description
OPENACCOUNTANTS_ROOT Auto-detected repo root (parent of mcp/) Path to your OpenAccountants checkout. The server reads $OPENACCOUNTANTS_ROOT/packages/.

What changes vs manual upload

Before (manual) After (MCP)
Download folder, upload files by hand One-time install, always available
Pick the right files yourself Model discovers what's available
Repeat for every new conversation Persistent — server always running
Can't easily switch countries mid-chat Model calls list_jurisdictions and pivots

Smoke test

Run from the repo root to verify everything works:

python mcp/smoke_test.py

All 14 checks should pass (path safety, tool outputs, jurisdiction count).

Disclaimer

All skills and outputs are for informational and computational purposes only. Not tax advice. Not a replacement for professional judgment. Content quality is tiered (Q1-Q5) — most skills are not practitioner battle-tested. Always have a qualified professional review before filing.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openaccountants_mcp-0.1.1.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openaccountants_mcp-0.1.1-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file openaccountants_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: openaccountants_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for openaccountants_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 8da77e4b2f16e7e5c82aacc0fa6a7191851c4a258d3ffc2bcfc42fc074b7928b
MD5 f1de063a4640a714241b41393179e7bb
BLAKE2b-256 77770c72988e9dc3d035aa23443b8a739a260f78d52b8e7cde93f633c827b68d

See more details on using hashes here.

File details

Details for the file openaccountants_mcp-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for openaccountants_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 281ff9948cc0684215a223d33270a7d5dcc96d017ba657ac3303f30841dfbeda
MD5 ed32acb930aba8b2a7380630617aca58
BLAKE2b-256 e9ffe85204e69770dcf880dc25383848bcde916e524bbcb52d57f0688ea646d3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page