Gatherings
A server for managing gatherings and sharing expenses.
gatherings MCP Server
A Model Context Protocol server for managing gatherings and expense sharing.
This is a TypeScript-based MCP server that helps track expenses and payments for social events, making it easy to calculate reimbursements and settle balances between friends.
Architecture Note
Important: This project uses a non-standard architecture for a Node.js application. The TypeScript MCP server acts as a wrapper around a Python backend implementation. The Node.js server receives MCP requests, translates them to command-line calls to the Python script, and returns the results.
While this architecture works for our current needs, it's not the most efficient or maintainable approach for a production application.
TODO
- Refactor the implementation to use a more standard architecture:
- Either fully migrate the backend to TypeScript/JavaScript
- Or implement proper inter-process communication between Node.js and Python components
- Or replace with a REST API approach where the Python backend provides an API that the MCP server consumes
- Improve error handling between the Node.js and Python components
- Add automated tests for the integration between components
- Optimise Dockerfile
Features
Tools
create_gathering- Create a new gathering- Takes
gathering_idandmembersas required parameters
- Takes
add_expense- Add an expense for a member- Takes
gathering_id,member_name, andamountas required parameters
- Takes
calculate_reimbursements- Calculate reimbursements for a gathering- Takes
gathering_idas a required parameter
- Takes
record_payment- Record a payment made by a member- Takes
gathering_id,member_name, andamountas required parameters
- Takes
rename_member- Rename an unnamed member- Takes
gathering_id,old_name, andnew_nameas required parameters
- Takes
show_gathering- Show details of a gathering- Takes
gathering_idas a required parameter
- Takes
list_gatherings- List all gatheringsclose_gathering- Close a gathering- Takes
gathering_idas a required parameter
- Takes
delete_gathering- Delete a gathering- Takes
gathering_idas a required parameter, optionalforceparameter
- Takes
add_member- Add a new member to a gathering- Takes
gathering_idandmember_nameas required parameters
- Takes
remove_member- Remove a member from a gathering- Takes
gathering_idandmember_nameas required parameters
- Takes
Development
Install dependencies:
npm install
Build the server:
npm run build
For development with auto-rebuild:
npm run watch
Installation
Configuration
To use with Claude Desktop, add the server config:
{
"mcpServers": {
"gatherings": {
"command": "node",
"args": ["/path/to/gatherings-server/build/index.js"],
"env": {
"GATHERINGS_DB_PATH": "gatherings.db",
"GATHERINGS_SCRIPT": "/path/to/gatherings-server/gatherings.py"
},
"disabled": false,
"autoApprove": [],
"alwaysAllow": [
"create_gathering",
"add_expense",
"calculate_reimbursements",
"record_payment",
"rename_member",
"show_gathering",
"list_gatherings",
"close_gathering",
"delete_gathering",
"add_member",
"remove_member"
],
"timeout": 300
}
}
}
Configuration Options
commandandargs: Specifies how to run the serverenv: Environment variablesGATHERINGS_DB_PATH: Path to the database fileGATHERINGS_SCRIPT: Path to the Python script for handling gathering operations
alwaysAllow: List of tools that will be automatically allowed without promptingtimeout: Maximum execution time in seconds
Debugging
Since MCP servers communicate over stdio, debugging can be challenging. We recommend using the MCP Inspector, which is available as a package script:
npm run inspector
The Inspector will provide a URL to access debugging tools in your browser.
関連サーバー
Ledger CLI
Execute commands for Ledger, a powerful command-line accounting system. Requires Ledger CLI to be installed.
Nexs MCP
NEXS MCP Server is a high-performance implementation of the Model Context Protocol, designed to manage AI elements with enterprise-grade architecture. Built with the official MCP Go SDK v1.1.0, it provides a robust foundation for AI system management.
Notion
Search, read, create, and update pages and databases in your Notion workspace.
MCP Voice Assistant
A voice-enabled AI personal assistant that integrates multiple tools and services through natural voice interactions using MCP.
Todoist
Manage Todoist projects, sections, tasks, and labels using natural language with AI assistants.
Linear Issues
Provides read-only access to issues within the Linear project management tool.
Jira Weekly Reporter
Connects to a Jira instance to generate weekly reports based on issue activity.
Atlassian-mcp-server
MCP server for Atlassian Cloud (Confluence & Jira) with seamless OAuth 2.0 authentication.
MCP SuperAssistant Chrome Extension
A Chrome extension that integrates MCP tools with AI platforms like ChatGPT and Gemini, allowing users to execute tools and insert results directly into conversations.
Outline
Interact with Outline, the open-source knowledge base and wiki, directly through your AI assistant.