ExpenseTracker MCP Server
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., "@ExpenseTracker MCP ServerAdd $45.50 for groceries yesterday under the food category"
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.
š° ExpenseTracker MCP Server
A lightweight and scalable Expense Tracking MCP Server built using FastMCP and SQLite. This server allows you to add, list, and summarize expenses efficiently, making it ideal for personal finance management or integration with MCP-compatible clients like Claude Desktop.
š Features
ā Add expenses with category and notes
š List expenses within a date range
š Summarize expenses by category
š Default categories support (with fallback)
ā” Async database operations using
aiosqliteāļø Cloud-ready (FastMCP deployment compatible)
š ļø Tech Stack
Python
FastMCP
SQLite (aiosqlite for async support)
š Project Structure
.
āāā main.py # Main MCP server file
āāā requirements.txt # Dependencies
āāā categories.json # (Optional) Custom categories
āāā README.mdāļø Setup & Installation
1. Clone the repository
git clone https://github.com/your-username/your-repo-name.git
cd your-repo-name2. Create virtual environment
python -m venv venv
venv\Scripts\activate # Windows3. Install dependencies
pip install -r requirements.txtā¶ļø Running the Server
python main.pyServer will start at:
http://0.0.0.0:8000š MCP Endpoint
Once deployed on FastMCP, your endpoint will look like:
https://your-app-name.fastmcp.app/mcpā ļø Note: Authentication is required to access this endpoint.
š Available Tools
⤠Add Expense
Adds a new expense entry.
Parameters:
date(YYYY-MM-DD)amount(float)category(string)subcategory(optional)note(optional)
⤠List Expenses
Fetch expenses within a date range.
Parameters:
start_dateend_date
⤠Summarize Expenses
Get category-wise expense summary.
Parameters:
start_dateend_datecategory(optional)
š Categories Resource
Endpoint:
expense:///categoriesLoads from
categories.jsonif availableFalls back to default categories if file is missing
š§ How It Works
Uses a temporary directory for database storage
Initializes database on startup
Uses async operations for better performance
Safe fallback mechanisms for missing files
ā ļø Common Issues & Fixes
ā Pre-flight check failed
Ensure your file name is
main.pyMake sure
mcp = FastMCP(...)is correctCheck logs for missing dependencies
ā Module not found
Add missing packages to
requirements.txt
Example:
fastmcp
aiosqliteš” Future Improvements
User authentication system
Dashboard UI
Monthly budget tracking
Data export (CSV/Excel)
šØāš» Author
Built with ā¤ļø for learning and real-world MCP integration.
ā Support
If you like this project:
Star ā the repo
Share with others
Contribute improvements
This server cannot be installed
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/samt439/test-remote-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server