pocketsmith-mcp

pocketsmith-mcp

Enables interaction with the PocketSmith personal finance API through 43 MCP tools for managing accounts, transactions, budgets, categories, and more.

Category
Visit Server

README

<p align="center"> <h1 align="center">PocketSmith MCP Server</h1> <p align="center"> <strong>A production-ready MCP server for the PocketSmith personal finance API</strong> </p> </p>

<p align="center"> <img src="assets/demo.gif" alt="PocketSmith MCP Demo" width="700"> </p>

<p align="center"> <a href="https://www.python.org/downloads/"><img src="https://img.shields.io/badge/python-3.10%2B-blue.svg" alt="Python 3.10+"></a> <a href="https://opensource.org/licenses/MIT"><img src="https://img.shields.io/badge/license-MIT-green.svg" alt="License: MIT"></a> <a href="https://pypi.org/project/pocketsmith-mcp/"><img src="https://img.shields.io/pypi/v/pocketsmith-mcp?color=blue" alt="PyPI"></a> <img src="https://img.shields.io/badge/tests-180%20passed-brightgreen" alt="Tests: 180 passed"> <img src="https://img.shields.io/badge/coverage-86%25-brightgreen" alt="Coverage: 86%"> </p>

<p align="center"> <a href="#features">Features</a> • <a href="#quick-start">Quick Start</a> • <a href="#available-tools">Tools</a> • <a href="#testing">Testing</a> • <a href="#development">Development</a> </p>


Features

  • 43 MCP Tools - Complete coverage of PocketSmith API v2 endpoints
  • Production Ready - Rate limiting, retry with exponential backoff, circuit breaker
  • Universal Compatibility - Works with Claude Desktop, Cursor, and any MCP-compatible client
  • Type Safe - Pydantic models for all API entities

Quick Start

Installation

# Run directly with uvx (recommended)
uvx pocketsmith-mcp

# Or install with pip
pip install pocketsmith-mcp

Getting Your API Key

  1. Navigate to Security & Integrations - Click your profile icon, then select "Security & integrations"

<p align="center"> <img src="assets/api-key-step1-security-integrations.png" alt="Navigate to Security & Integrations" width="500"> </p>

  1. Create a Developer Key - Go to "Manage developer keys" and click "Create Key"

<p align="center"> <img src="assets/api-key-step2-create-key.png" alt="Create Developer Key" width="500"> </p>

Configuration

  1. Set your environment variable:
export POCKETSMITH_API_KEY=your_api_key_here
  1. Run the server:
uvx pocketsmith-mcp

Claude Desktop Integration

Add to your Claude Desktop config:

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

{
  "mcpServers": {
    "pocketsmith": {
      "command": "uvx",
      "args": ["pocketsmith-mcp"],
      "env": {
        "POCKETSMITH_API_KEY": "your_api_key_here"
      }
    }
  }
}

Available Tools

<details> <summary><strong>User Management</strong></summary>

Tool Description
get_current_user Get authenticated user info
get_user Get user by ID
update_user Update user settings

</details>

<details> <summary><strong>Account Management</strong></summary>

Tool Description
list_accounts List all accounts
get_account Get account details
update_account Update account
delete_account Delete account

</details>

<details> <summary><strong>Transaction Accounts</strong></summary>

Tool Description
list_transaction_accounts List transaction accounts
get_transaction_account Get transaction account details
update_transaction_account Update transaction account

</details>

<details> <summary><strong>Transactions</strong></summary>

Tool Description
list_transactions List transactions with filters
get_transaction Get transaction details
create_transaction Create new transaction
update_transaction Update transaction
delete_transaction Delete transaction

</details>

<details> <summary><strong>Categories</strong></summary>

Tool Description
list_categories List all categories
get_category Get category details
create_category Create new category
update_category Update category
delete_category Delete category

</details>

<details> <summary><strong>Budgeting</strong></summary>

Tool Description
get_budget Get budget data
get_budget_summary Get budget summary
get_trend_analysis Get spending trends
clear_forecast_cache Clear forecast cache

</details>

<details> <summary><strong>Institutions</strong></summary>

Tool Description
list_institutions List financial institutions
get_institution Get institution details
create_institution Create institution
update_institution Update institution
delete_institution Delete institution

</details>

<details> <summary><strong>Events (Budget Calendar)</strong></summary>

Tool Description
list_events List budget events
get_event Get event details
create_event Create budget event
update_event Update event
delete_event Delete event

</details>

<details> <summary><strong>Attachments</strong></summary>

Tool Description
list_attachments List attachments
get_attachment Get attachment details
create_attachment Upload attachment
update_attachment Update attachment
delete_attachment Delete attachment

</details>

<details> <summary><strong>Labels & Searches</strong></summary>

Tool Description
list_labels List all labels
list_saved_searches List saved searches

</details>

<details> <summary><strong>Utilities</strong></summary>

Tool Description
list_currencies List supported currencies
list_time_zones List supported time zones

</details>


Testing

Running Tests

# Run all tests
uv run pytest

# Run with coverage report
uv run pytest --cov=src/pocketsmith_mcp --cov-report=term-missing

# Run specific test file
uv run pytest tests/unit/tools/test_transactions.py

# Run tests by marker
uv run pytest -m unit          # Unit tests only
uv run pytest -m integration   # Integration tests only
uv run pytest -m e2e           # End-to-end tests (requires API key)

Test Structure

tests/
├── unit/                 # Fast, isolated tests with mocked API
│   ├── test_api_client.py
│   ├── test_errors.py
│   ├── test_rate_limiter.py
│   ├── test_circuit_breaker.py
│   ├── test_user_context.py
│   └── tools/            # Tool-specific unit tests
├── integration/          # Tests with mocked HTTP responses
│   ├── test_server.py
│   └── test_tools.py
└── conftest.py           # Shared fixtures

Coverage

The project maintains a 70% coverage threshold. Coverage reports are generated automatically:

uv run pytest --cov=src/pocketsmith_mcp --cov-report=html
open htmlcov/index.html

Development

Setup

# Clone the repository
git clone https://github.com/ajanderson1/mcp_pocketsmith.git
cd pocketsmith-mcp

# Install dependencies (including dev)
uv sync --dev

# Copy environment template
cp .env.example .env
# Edit .env and add your API key

Architecture

pocketsmith-mcp/
├── src/pocketsmith_mcp/
│   ├── __main__.py       # Entry point
│   ├── server.py         # FastMCP server setup
│   ├── config.py         # Environment configuration
│   ├── client/           # API client with resilience patterns
│   │   ├── api_client.py     # HTTP client wrapper
│   │   ├── rate_limiter.py   # Token bucket algorithm
│   │   ├── circuit_breaker.py # Fault tolerance
│   │   └── retry.py          # Exponential backoff
│   ├── models/           # Pydantic data models
│   └── tools/            # MCP tool implementations
└── tests/                # Unit and integration tests

API Resilience

The client includes production-grade resilience:

  • Rate Limiting - Token bucket algorithm (60 req/min default)
  • Retry Logic - Exponential backoff with jitter for transient failures
  • Circuit Breaker - Prevents cascade failures during outages

Environment Variables

Variable Required Default Description
POCKETSMITH_API_KEY Yes - Your PocketSmith API key
DEBUG No false Enable debug logging
API_TIMEOUT No 30 Request timeout (seconds)
MAX_RETRIES No 3 Retry attempts for failed requests
RATE_LIMIT_PER_MINUTE No 60 API rate limit

License

This project is licensed under the MIT License - see the LICENSE file for details.


<p align="center"> Made with Python and FastMCP </p>

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