emma-transactions-mcp
A generic MCP server for querying Emma-app transaction exports stored in Google Sheets, supporting filters, summaries, and metadata via CSV fetching.
README
Emma Transactions MCP Server
A reusable Model Context Protocol server for querying Emma-app transaction exports stored in Google Sheets.
The server is generic: you provide your own Google Sheet URL, published CSV URL, or Sheet ID at runtime. This repository contains no personal transaction data and no hard-coded Sheet IDs.
Features
list_transactions— list normalized transactions, with filters for category, account, search text, and date range.get_spending_summary— totals for income, expenses, net movement, category, account, and month.get_metadata— available accounts, categories, currencies, row count, and date range.validate_sheet— confirms the sheet can be parsed without returning transaction rows.- Google Sheets URL helper — accepts a Sheet ID, a normal
/editURL, a/pub?output=csvURL, or an/export?format=csvURL. - Robust CSV parsing — recognizes common column variants such as
Date,Transaction Date,Description,Name,Amount,Value,Category,Account, andMerchant.
Privacy model
This server does not store transaction data. It fetches the configured CSV when a tool is called and returns the requested result to the MCP client.
You still need to treat your Google Sheet URL as sensitive. If you publish a Google Sheet to the web as CSV, anyone with that URL may be able to access the data. Use a private runtime environment and do not commit your real Sheet URL to version control.
Requirements
- Node.js 20+
- An Emma transaction export in Google Sheets, accessible to the process running the MCP server
Current implementation supports unauthenticated CSV access: published-to-web CSV links and Google Sheet export URLs that the runtime can fetch. OAuth/service-account support is intentionally not bundled yet, because credentials for personal finance data need a sharper knife than a README example.
Install
From a checkout:
git clone https://github.com/accesstechnology-mike/emma-transactions-mcp.git
cd emma-transactions-mcp
npm install
npm run build
MCP client configuration
Use an environment variable:
{
"mcpServers": {
"emma-transactions": {
"command": "node",
"args": ["/absolute/path/to/emma-transactions-mcp/dist/index.js"],
"env": {
"EMMA_SHEET_URL": "https://docs.google.com/spreadsheets/d/YOUR_SHEET_ID/pub?output=csv",
"EMMA_SHEET_GID": "0"
}
}
}
}
Or pass sheet_url in each tool call.
Optional gid selects a specific tab. It defaults to EMMA_SHEET_GID, then 0.
Expected columns
At minimum, the CSV needs:
- date:
Date,Transaction Date,Timestamp, orTime - description:
Description,Name,Transaction,Transaction Name, orTitle - amount:
Amount,Value,Transaction Amount,Money Out, orMoney In
Optional columns include Currency, Category, Account, Merchant, Notes, and Type.
Development
npm install
npm test
npm run build
The test suite uses synthetic fixture rows only. Do not add real transaction exports to tests, issues, screenshots, or docs.
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.