Wave MCP Server

Wave MCP Server

MCP server for Wave accounting that provides tools for managing chart of accounts, invoices, customers, vendors, products, and reports via the Wave GraphQL API.

Category
Visit Server

README

Wave MCP Server

MCP server for Wave accounting — 6 tools, 52 operations covering the full Wave GraphQL API.

Built with FastMCP and httpx. Mirrors the architecture of quickbooks-mcp.

Quick Start

# Install dependencies
uv sync

# Configure credentials
cp .env.example .env
# Edit .env — add your WAVE_ACCESS_TOKEN from Wave > Settings > API Applications

# Discover your business ID
uv run python auth_flow.py

# Run (STDIO for Claude Desktop / MCP clients)
uv run python server.py

# Run (SSE on port 3076)
uv run python server.py sse

Configuration

Variable Description
WAVE_ACCESS_TOKEN Full Access token from Wave app settings
WAVE_BUSINESS_ID Set automatically by auth_flow.py, or manually

Tools & Operations

account — Chart of Accounts

Operation Description
list List accounts with optional type/subtype filters, pagination
get Get account by ID
create Create account (name, subtype, currency, description)
update Update account fields
archive Archive an account
search Client-side name search

party — Customers & Vendors

Operation Customer Vendor
list Yes Yes
get Yes Yes
create Yes Read-only
update Yes Read-only
delete Yes Read-only
search Yes Yes

transaction — Invoices & Money Transactions

Invoice operations: list, get, create, update, delete, clone, send, approve, mark_sent, create_payment, search

Money transaction operations: create, bulk_create (BETA)

item — Products & Services

list, get, create, update, archive, search

reference — Lookup Data & Settings

list_businesses, get_business, get_user, list_currencies, list_countries, list_account_types, list_account_subtypes, list_sales_taxes, get_sales_tax, create_sales_tax, update_sales_tax, archive_sales_tax, list_estimates, get_estimate

report — Synthesized Summaries

Operation Description
business_summary Business info + accounts grouped by type with counts
account_balances All accounts with name, type, balance, balanceInBusinessCurrency
customer_balances All customers with outstanding and overdue amounts

MCP Client Configuration

Claude Desktop / Claude Code (STDIO)

{
  "mcpServers": {
    "wave": {
      "command": "uv",
      "args": ["run", "--directory", "/path/to/wave-mcp", "python", "server.py"]
    }
  }
}

SSE (remote / multi-client)

{
  "mcpServers": {
    "wave": {
      "url": "http://localhost:3076/sse"
    }
  }
}

Key Differences from QuickBooks MCP

Wave QuickBooks
API GraphQL REST
Auth Static Bearer token OAuth 2.0 + token refresh
IDs Base64 strings Integers
Pagination Page-based (page/pageSize) Offset-based (start_position)
Search Client-side name filtering Server-side WHERE queries
Vendors Read-only Full CRUD
Reports Synthesized from account data Native report API
Money Transactions Create-only (BETA) N/A

Known Limitations

  • Vendors are read-only — no create/update/delete mutations in the Wave API
  • Money transactions are create-only (BETA) — no list/get/update/delete
  • No server-side text search — client-side filtering, limited to first ~250 results per query
  • No financial reports API — synthesized account balance summaries only
  • Estimates are read-only — no create/update mutations
  • Rate limit: 60 requests/minute (automatic exponential backoff on 429)

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
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
Qdrant Server

Qdrant Server

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

Official
Featured