actual-budget-mcp

actual-budget-mcp

An MCP server that connects Actual Budget to Claude, enabling users to manage budgets, transactions, and spending insights through natural language.

Category
Visit Server

README

actual-budget-mcp

npm version License: MIT Node.js

Talk to your budget. An MCP server that connects Actual Budget to Claude, so you can ask questions, create transactions, and analyze spending in natural conversation.

Features

  • Ask about your budget in plain language - "How much did I spend on food this month?" or "Am I over budget on anything?"
  • Create and manage transactions - Add expenses, transfers, and edits without opening the app
  • Get spending insights - Projections, trends, and budget vs actual comparisons
  • Manage categories, payees, and rules - Full CRUD without opening the app
  • Use names, not IDs - Say "Cartera" instead of a1b2c3d4-..., with helpful suggestions if ambiguous
  • Natural dates in English and Spanish - "last month", "este mes", "hace 3 meses", "yesterday"
  • Clean formatted output - Aligned tables and clear summaries, not raw JSON
  • Clear error messages - If something's wrong, you'll know exactly what to fix

Prerequisites

Quick Start

The fastest way to get started - copy this into Claude Code or Claude Desktop:

Install the actual-budget-mcp MCP server from npm (https://github.com/henfrydls/actual-budget-mcp).
Configure it with these credentials:
    - My Actual Budget server: http://localhost:5006
    - Password: YOUR_PASSWORD
    - Budget ID: YOUR_BUDGET_ID

Claude will configure everything for you.

Installation

Option 1: Claude Code (one command)

claude mcp add actual-budget-mcp -e ACTUAL_SERVER_URL=http://localhost:5006 -e ACTUAL_PASSWORD=your-password -e ACTUAL_BUDGET_ID=your-budget-id -- npx -y actual-budget-mcp

Option 2: Claude Desktop

Add this to your claude_desktop_config.json:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "actual-budget-mcp": {
      "command": "npx",
      "args": ["-y", "actual-budget-mcp"],
      "env": {
        "ACTUAL_SERVER_URL": "http://localhost:5006",
        "ACTUAL_PASSWORD": "your-password",
        "ACTUAL_BUDGET_ID": "your-budget-sync-id"
      }
    }
  }
}

Option 3: Cursor

Go to Cursor Settings > MCP > Add new MCP server and add:

{
  "mcpServers": {
    "actual-budget-mcp": {
      "command": "npx",
      "args": ["-y", "actual-budget-mcp"],
      "env": {
        "ACTUAL_SERVER_URL": "http://localhost:5006",
        "ACTUAL_PASSWORD": "your-password",
        "ACTUAL_BUDGET_ID": "your-budget-sync-id"
      }
    }
  }
}

Option 4: VS Code (GitHub Copilot)

Add this to your VS Code settings.json:

{
  "mcp": {
    "servers": {
      "actual-budget-mcp": {
        "command": "npx",
        "args": ["-y", "actual-budget-mcp"],
        "env": {
          "ACTUAL_SERVER_URL": "http://localhost:5006",
          "ACTUAL_PASSWORD": "your-password",
          "ACTUAL_BUDGET_ID": "your-budget-sync-id"
        }
      }
    }
  }
}

Option 5: From source (for contributors)

git clone https://github.com/henfrydls/actual-budget-mcp.git
cd actual-budget-mcp
npm install
cp .env.example .env   # Edit with your credentials
npm run build
npm run test:connection # Verify it works

Verify your setup

After installing, you can verify the connection works:

npx -y actual-budget-mcp --verify

This will connect to your Actual Budget server and confirm everything is configured correctly.

Configuration

Variable Required Description
ACTUAL_SERVER_URL Yes Your Actual Budget server URL (e.g., http://localhost:5006)
ACTUAL_PASSWORD Yes Server password (set in Actual Budget under Settings)
ACTUAL_BUDGET_ID Yes Budget Sync ID (found in Settings > Show advanced settings)
ACTUAL_ENCRYPTION_PASSWORD No Only if your budget file is encrypted
ACTUAL_DATA_DIR No Cache directory (default: /tmp/actual-budget-mcp-data)

Finding your Budget ID

  1. Open Actual Budget
  2. Go to Settings (gear icon)
  3. Click Show advanced settings
  4. Copy the Sync ID

Tools (32)

Read (9)

Tool Description Example prompt
list_accounts All accounts with balances "Show me all my accounts"
get_budget_month Budget for a specific month "What does my March budget look like?"
get_transactions Transactions with filters "Show me transactions from last week over 5000"
get_category_balance Category history across months "How has my food spending changed?"
get_budget_summary Executive budget overview "Give me a budget summary for February"
get_categories All category groups and categories "What categories do I have?"
get_payees All payees in the budget "List all my payees"
get_rules All transaction rules "Show me my rules"
balance_history Account balance over time "Show balance history for my checking account"

<details> <summary>Parameters</summary>

get_budget_month - month (optional): YYYY-MM or natural language ("this month", "last month", "enero 2025")

get_transactions - account (optional): account name | start_date / end_date (optional): YYYY-MM-DD or natural language | category (optional): category name | payee (optional): payee name | min_amount / max_amount (optional): filter by amount | limit (optional, default 50)

get_category_balance - category (required): category name or ID | months (optional, default 3): months to look back

get_budget_summary - month (optional): YYYY-MM or natural language

balance_history - account (required): account name or ID | start_date (optional, default 3 months ago) | end_date (optional, default today)

</details>

Analysis (5)

Tool Description Example prompt
budget_vs_actual Budgeted vs spent per category "Am I over budget on anything this month?"
spending_projection End-of-month spending forecast "Will I stay within budget this month?"
category_trends Spending trends over time "What are my spending trends for the last 6 months?"
spending_by_category Spending breakdown by category "Show me spending by category for February"
monthly_summary Income vs expenses vs savings "How have my finances been the last 3 months?"

<details> <summary>Parameters</summary>

budget_vs_actual - month (optional): YYYY-MM or natural language | group (optional): filter by category group

spending_projection - month (optional): YYYY-MM or natural language

category_trends - category (optional): specific category or top spending if omitted | months (optional, default 6)

spending_by_category - start_date / end_date (optional): date range | include_income (optional, default false) | limit (optional, default 20)

monthly_summary - months (optional, default 3): number of months to show

</details>

Write — Transactions (7)

Tool Description Example prompt
create_transaction Add a new transaction "I spent 500 on groceries from Cartera today"
update_transaction Edit an existing transaction "Change the amount on that transaction to 600"
delete_transaction Remove a transaction "Delete that test transaction"
update_budget_amount Change a budget amount "Set my food budget to 15,000 for this month"
recategorize_transaction Move to another category "Move that transaction to Entertainment"
create_transfer Transfer between accounts "Transfer 10,000 from Checking to Savings"
run_bank_sync Sync with linked banks "Sync my bank transactions"

<details> <summary>Parameters</summary>

create_transaction - account (required): account name | amount (required): negative for expenses, positive for income | payee (optional) | category (optional) | date (optional) | notes (optional) | cleared (optional)

update_transaction - transaction_id (required) | amount, payee, category, date, notes, cleared (all optional)

delete_transaction - transaction_id (required)

update_budget_amount - category (required) | amount (required) | month (optional)

recategorize_transaction - transaction_id (required) | category (required)

create_transfer - from_account (required) | to_account (required) | amount (required) | date (optional) | notes (optional)

run_bank_sync - account (optional): sync specific account or all if omitted

</details>

Write — Categories (6)

Tool Description Example prompt
create_category Create a new category "Create a category called Gym in Gastos Variables"
update_category Rename or hide a category "Rename Gym to Fitness"
delete_category Delete a category "Delete the Fitness category"
create_category_group Create a new group "Create a category group called Health"
update_category_group Rename or hide a group "Rename the Health group to Wellness"
delete_category_group Delete a group "Delete the Wellness group"

<details> <summary>Parameters</summary>

create_category - name (required) | group (required): group name or ID

update_category - category (required): name or ID | name (optional): new name | hidden (optional): true/false

delete_category - category (required) | transfer_to (optional): category to move transactions to

create_category_group - name (required)

update_category_group - group (required): name or ID | name (optional): new name | hidden (optional): true/false

delete_category_group - group (required) | transfer_to (required): category for orphaned transactions

</details>

Write — Payees & Rules (5)

Tool Description Example prompt
create_payee Create a new payee "Create a payee called Netflix"
update_payee Rename a payee "Rename Netflix to Netflix Premium"
delete_payee Delete a payee "Delete the Netflix Premium payee"
create_rule Create a transaction rule "Create a rule: when payee contains Amazon, set category to Shopping"
delete_rule Delete a rule "Delete that rule"

<details> <summary>Parameters</summary>

create_payee - name (required)

update_payee - payee (required): name or ID | name (required): new name

delete_payee - payee (required): name or ID

create_rule - condition_field (required): payee, category, amount, notes | condition_op (required): is, contains, oneOf, gt, lt, etc. | condition_value (required) | action_field (required): category, payee, notes | action_value (required) | stage (optional)

delete_rule - rule_id (required)

</details>

Prompts

Built-in prompt templates that guide Claude through multi-step financial analysis:

Prompt Description
monthly-review Complete budget review for any month — spending vs budget, overspending, suggestions
spending-check Quick check: are you on track this month?
spending-patterns Deep analysis of spending trends and patterns over multiple months

Use them in Claude Desktop by clicking the prompt icon, or in Claude Code by asking Claude to use them.

Resources

Pre-loaded data that Claude can reference without calling tools:

Resource URI Description
Accounts actual://accounts All accounts with balances
Categories actual://categories Category groups and categories with IDs
Payees actual://payees All payees sorted alphabetically

Usage Examples

Here are real prompts you can use:

"How much did I spend in February?"

"Show me my top 5 spending categories this month"

"Am I over budget on anything?"

"I spent 1,200 on electricity from my BHD account yesterday"

"What's my savings rate this month?"

"Show me all transactions from Cartera in the last 30 days"

"Transfer 5,000 from Checking to Savings"

"What are my spending trends for food over the last 6 months?"

"Create a category called Gym in Gastos Variables"

"Rename the Gym category to Fitness"

"Create a rule: when payee is Netflix, set category to Suscripciones"

"How have my finances been the last 3 months?"

How is this different?

Compared to other Actual Budget MCP servers:

Feature actual-budget-mcp Others
Natural language dates "last month", "este mes", "hace 3 meses" Only YYYY-MM-DD
Name resolution Type "Cartera" instead of UUIDs Requires exact IDs
Output format Aligned tables, readable text Raw JSON
Error messages Clear instructions on how to fix Generic errors
Analysis tools Budget vs actual, projections, trends Not available
MCP Prompts 3 guided analysis workflows Limited or none
MCP Resources Accounts, categories, payees pre-loaded Not available
Bilingual dates English + Spanish English only
API version @actual-app/api 26.x (current) Often outdated

Security

  • This server connects to your Actual Budget instance using the credentials you provide
  • Credentials are passed as environment variables and never stored by the MCP server
  • All communication with your Actual Budget server happens locally (or to your self-hosted server)
  • The server only accesses budget data through the official @actual-app/api library
  • No data is sent to third parties

Troubleshooting

"Could not connect to Actual Budget server"

  • Make sure Actual Budget is running (open the app or start the server)
  • Check that ACTUAL_SERVER_URL is correct
  • Run npx -y actual-budget-mcp --verify to test your connection

"Authentication failed"

  • Your server requires a password. Set ACTUAL_PASSWORD in your config
  • If you forgot the password, reset it in Actual Budget under Settings > Server

"Budget not found"

  • Check your ACTUAL_BUDGET_ID. Find it in Settings > Show advanced settings > Sync ID

"Budget file is encrypted"

  • Set ACTUAL_ENCRYPTION_PASSWORD with your encryption password

"Ambiguous name: matches X, Y"

  • Be more specific. Instead of "BHD", try "BHD Nomina" or "BHD Mi Pais"

Node.js Requirement

"ReferenceError: navigator is not defined"

  • @actual-app/api (including 26.6) references the navigator global, which is only available on Node.js 21+. On Node.js 20 or earlier it throws at import.
  • Solution: Use Node.js 22 or higher.

Node Version Managers (fnm, nvm, volta)

MCP server shows "Server disconnected" in Claude Desktop

  • Claude Desktop doesn't source your shell profile (.bashrc, .zshrc), so version managers like fnm, nvm, and volta won't work with the default npx command.
  • Solution: Use the absolute path to node in your config. Find it with:
readlink -f $(which node)

Then update your claude_desktop_config.json:

{
  "mcpServers": {
    "actual-budget-mcp": {
      "command": "/home/user/.local/share/fnm/node-versions/v22.22.1/installation/bin/node",
      "args": ["/path/to/actual-budget-mcp/dist/index.js"],
      "env": {
        "ACTUAL_SERVER_URL": "http://localhost:5006",
        "ACTUAL_PASSWORD": "your-password",
        "ACTUAL_BUDGET_ID": "your-budget-sync-id"
      }
    }
  }
}

Alternatively, create a wrapper script mcp-wrapper.sh:

#!/bin/bash
export PATH="$HOME/.local/share/fnm/node-versions/v22.22.1/installation/bin:$PATH"
exec npx -y actual-budget-mcp "$@"

Then use it in your config:

{
  "mcpServers": {
    "actual-budget-mcp": {
      "command": "/path/to/mcp-wrapper.sh"
    }
  }
}

Contributing

Contributions are welcome! Please open an issue or submit a pull request.

git clone https://github.com/henfrydls/actual-budget-mcp.git
cd actual-budget-mcp
npm install
npm run build
npm test               # Run unit tests
npm run test:connection # Needs .env configured

License

MIT - DLSLabs

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured