LedgerLink MCP
Connects AI assistants to QuickBooks Online, enabling management of invoices, customers, expenses, and reports through natural language.
README
LedgerLink MCP
An MCP server that connects AI assistants to QuickBooks Online. Manage invoices, customers, expenses, and reports through natural conversation.
"Show me all unpaid invoices" · "Create an invoice for Acme Corp for $5,000" · "What's my P&L for last quarter?"
What It Does
LedgerLink MCP gives AI assistants (Claude Desktop, Cursor, etc.) direct access to your QuickBooks Online data through the Model Context Protocol. Instead of clicking through the QuickBooks UI, you talk to your AI assistant in plain English.
32 tools across 10 QuickBooks entities:
| Category | Tools |
|---|---|
| Invoices | List, get, create, send, void |
| Customers | List, get, create, update |
| Bills | List, get, create |
| Payments | List, record |
| Expenses | List, get, create |
| Reports | Profit & Loss, Balance Sheet, Cash Flow, AR Aging, AP Aging |
| Accounts | List, get, create (Chart of Accounts) |
| Vendors | List, get, create |
| Items | List, get, create (Products & Services) |
| Company | Get company info |
Quick Start
1. Get QuickBooks Credentials
- Create a free account at developer.intuit.com
- Create an app → choose "QuickBooks Online and Payments"
- Note your Client ID and Client Secret
- Add
http://localhost:3847/callbackas a Redirect URI (under Settings)
2. Authenticate
# Clone and install
git clone https://github.com/YOUR_USERNAME/ledgerlink-mcp.git
cd ledgerlink-mcp
npm install
# Authenticate with QuickBooks (opens browser)
QB_CLIENT_ID=your_id QB_CLIENT_SECRET=your_secret npx tsx bin/cli.ts auth
A browser window opens → log in to QuickBooks → authorize → tokens are saved to ~/.ledgerlink/tokens.json.
3. Add to Claude Desktop
Edit your Claude Desktop config:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"ledgerlink": {
"command": "npx",
"args": ["tsx", "/path/to/ledgerlink-mcp/src/index.ts"],
"env": {
"QB_CLIENT_ID": "your_client_id",
"QB_CLIENT_SECRET": "your_client_secret",
"QB_ENVIRONMENT": "sandbox"
}
}
}
}
Restart Claude Desktop. You'll see the tools icon — start talking to your books.
4. Try It
- "Show me all unpaid invoices"
- "Who owes me the most money?"
- "What's my profit and loss for 2024?"
- "Create an invoice for customer ID 1 for $500 consulting"
- "List all bills due this week"
How It Works
You: "Show me unpaid invoices"
↓
Claude Desktop → LedgerLink MCP (stdio) → QuickBooks API
↓
Claude: "You have 4 unpaid invoices totaling $3,200..."
LedgerLink runs as a local process. Claude Desktop spawns it, communicates over stdio (stdin/stdout), and your QuickBooks data never leaves your machine.
Configuration
Environment Variables
| Variable | Required | Description |
|---|---|---|
QB_CLIENT_ID |
Yes | From Intuit developer portal |
QB_CLIENT_SECRET |
Yes | From Intuit developer portal |
QB_REDIRECT_URI |
No | Default: http://localhost:3847/callback |
QB_ENVIRONMENT |
No | sandbox (default) or production |
Token Storage
Tokens are stored in ~/.ledgerlink/tokens.json with owner-only permissions (chmod 600). Access tokens auto-refresh when expired (1-hour lifetime, 100-day refresh token).
Tool Reference
Invoices
list_invoices— Filter by status (Unpaid/Paid/Overdue), customer, date rangeget_invoice— Full invoice details by IDcreate_invoice— Create with customer, line items, due date, memosend_invoice— Email an invoice to the customervoid_invoice— Void an invoice (cannot be undone)
Customers
list_customers— Search by name, filter active/inactiveget_customer— Full customer details by IDcreate_customer— Create with name, email, phone, addressupdate_customer— Update existing customer fields
Bills (Accounts Payable)
list_bills— Filter by status, vendor, due dateget_bill— Full bill details by IDcreate_bill— Create with vendor, line items, due date
Payments
list_payments— Filter by date range, customerrecord_payment— Record payment, optionally applied to an invoice
Expenses
list_expenses— Filter by date range, vendorget_expense— Full expense details by IDcreate_expense— Create with account, payment type, line items
Reports
get_profit_and_loss— P&L for a date range, optionally by month/weekget_balance_sheet— Balance sheet as of a dateget_cash_flow— Cash flow statement for a date rangeget_aging_receivables— Who owes you, grouped by aging bucketget_aging_payables— What you owe, grouped by aging bucket
Chart of Accounts
list_accounts— Filter by type (Bank, Expense, Income, etc.)get_account— Full account details by IDcreate_account— Create new account with type and sub-type
Vendors
list_vendors— Search by name, filter active/inactiveget_vendor— Full vendor details by IDcreate_vendor— Create with name, email, phone
Items (Products & Services)
list_items— Search by name, filter by type (Service/Inventory)get_item— Full item details by IDcreate_item— Create with name, type, price, income account
Company
get_company_info— Company name, address, fiscal year, currency
Development
# Install dependencies
npm install
# Run in development mode
QB_CLIENT_ID=xxx QB_CLIENT_SECRET=xxx npx tsx src/index.ts
# Test with MCP Inspector
QB_CLIENT_ID=xxx QB_CLIENT_SECRET=xxx npx @modelcontextprotocol/inspector npx tsx src/index.ts
# Type check
npx tsc --noEmit
# Build for distribution
npm run build
# Run tests
npm test
Architecture
src/
├── index.ts # Entry point — wires everything together
├── auth/
│ ├── oauth.ts # OAuth 2.0 flow (local callback server)
│ └── token-store.ts # Token persistence (~/.ledgerlink/)
├── quickbooks/
│ ├── client.ts # HTTP client (auth, retry, rate limiting)
│ ├── types.ts # TypeScript types for QB entities
│ ├── invoices.ts # Invoice API operations
│ ├── customers.ts # Customer API operations
│ └── ... # (10 entity modules total)
├── tools/
│ ├── invoice-tools.ts # MCP tool registrations for invoices
│ ├── customer-tools.ts # MCP tool registrations for customers
│ └── ... # (10 tool modules total)
├── resources/
│ └── index.ts # MCP read-only resources
└── utils/
├── rate-limiter.ts # Sliding window (450 req/min)
├── query-builder.ts # QB query builder with sanitization
└── formatters.ts # Report response formatting
Security
- Tokens stored with chmod 600 (owner-only read/write)
- Client credentials passed via environment variables, never committed
- Query builder sanitizes all user input to prevent QB query injection
- All QuickBooks data stays local — no external servers, no telemetry
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.