emma-transactions-mcp
Provides tools to query Emma-app transaction exports stored in Google Sheets, including listing transactions with filters, spending summaries by category/account/month, and sheet metadata.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@emma-transactions-mcpwhat did I spend on groceries this month?"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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.
Related MCP server: mcp-server-spreadsheet
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 buildMCP 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, orTimedescription:
Description,Name,Transaction,Transaction Name, orTitleamount:
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 buildThe test suite uses synthetic fixture rows only. Do not add real transaction exports to tests, issues, screenshots, or docs.
License
MIT
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/accesstechnology-mike/emma-transactions-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server