@a-und-b/moco-mcp
v1.2.6
Published
Model Context Protocol (MCP) server for MOCO: time tracking, project management, holidays, and presence monitoring
Maintainers
Readme
📊 MOCO MCP Server
A Model Context Protocol (MCP) server that provides comprehensive access to the MOCO API for time tracking, project management, CRM (companies & contacts), invoicing, holiday tracking, and presence monitoring.
⚡ Quick Start
npx -y @a-und-b/moco-mcpThat's it! The server will start and be ready to connect to your MCP client.
🚀 Installation
Prerequisites
- Node.js ≥ 18.0.0
- MOCO account with API access
- MOCO API key and subdomain
MCP Client Integration
Add to your Claude Desktop claude_desktop_config.json file:
MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@a-und-b/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}Add to your Cursor settings:
MacOS: ~/Library/Application Support/Cursor/User/settings.json
Windows: %APPDATA%\Cursor\User\settings.json
Linux: ~/.config/Cursor/User/settings.json
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@a-und-b/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}Add to your Windsurf MCP configuration:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@a-und-b/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}Add the MCP server to Claude Code:
claude mcp add -e MOCO_API_KEY="your-moco-api-key" -e MOCO_SUBDOMAIN="your-subdomain" moco -- npx -y @a-und-b/moco-mcpConfigure Gemini CLI with MCP support:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@a-und-b/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}- Go to
Kiro>MCP Servers - Add new MCP server by clicking
+ Add - Paste the configuration below:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": [
"-y",
"@a-und-b/moco-mcp"
],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
},
"disabled": false,
"autoApprove": []
}
}
}
- Click
Saveto apply changes
- Go to
Program(right side) >Install>Edit mcp.json - Paste the configuration below:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@a-und-b/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}- Click
Saveto apply changes - Toggle MCP server on/off from the right hand side (under
Program) or by clicking the plug icon at the bottom of the chat box
🔑 MOCO API Setup
Getting Your API Credentials
- Log into your MOCO account
- Navigate to API settings:
- Go to Profile → Integrations
- Or visit:
https://yourcompany.mocoapp.com/profile/integrations
- Copy the listed API key
- Note your subdomain:
- From your MOCO URL:
https://yourcompany.mocoapp.com - Your subdomain is:
yourcompany
- From your MOCO URL:
Environment Variables
You can set environment variables in several ways:
Option 1: System Environment Variables
export MOCO_API_KEY="your-moco-api-key"
export MOCO_SUBDOMAIN="your-subdomain"Option 2: .env File (for local development)
MOCO_API_KEY=your-moco-api-key
MOCO_SUBDOMAIN=your-subdomainOption 3: MCP Client Configuration (recommended)
Use the env section in your MCP client configuration as shown above.
🛠️ Available Tools
Activities (Time Tracking)
| Tool | Description | Parameters |
|------|-------------|------------|
| get_activities | Get activities within a date range with summation | startDate, endDate, projectId (optional) |
| create_activity | Create a new time entry | date, projectId, taskId, hours, description (optional) |
| update_activity | Update an existing time entry | activityId, date, projectId, taskId, hours, description |
| delete_activity | Delete a time entry | activityId |
| start_activity_timer | Start the timer for an activity | activityId |
| stop_activity_timer | Stop the timer for an activity | activityId |
Projects
| Tool | Description | Parameters |
|------|-------------|------------|
| get_user_projects | List all assigned projects or search by query | query (optional) |
| get_user_project_tasks | Get all tasks for a specific project | projectId |
| update_project | Update project details | projectId, various optional fields |
Companies (CRM)
| Tool | Description | Parameters |
|------|-------------|------------|
| get_companies | List companies with optional filtering | type, tags, identifier (all optional) |
| get_company | Get a specific company by ID | companyId |
| create_company | Create a new company | name, type, website, email, etc. |
| update_company | Update an existing company | companyId, various optional fields |
| delete_company | Delete a company | companyId |
Contacts (CRM)
| Tool | Description | Parameters |
|------|-------------|------------|
| get_contacts | List contacts with optional filtering | tags (optional) |
| get_contact | Get a specific contact by ID | contactId |
| create_contact | Create a new contact | firstname, lastname, companyId, email, etc. |
| update_contact | Update an existing contact | contactId, various optional fields |
| delete_contact | Delete a contact | contactId |
Invoices
| Tool | Description | Parameters |
|------|-------------|------------|
| get_invoices | List invoices with optional filtering | status, projectId, companyId (all optional) |
| get_invoice | Get a specific invoice by ID | invoiceId |
| create_invoice | Create a new invoice | customerId, recipientAddress, items, etc. |
| update_invoice_status | Update invoice status | invoiceId, status |
| send_invoice_email | Send invoice via email | invoiceId, emailsTo, subject, text |
| delete_invoice | Delete an invoice | invoiceId, reason (optional) |
Time Off & Presence
| Tool | Description | Parameters |
|------|-------------|------------|
| get_user_holidays | Get holiday overview for a year | year |
| get_user_presences | Get presence data within a date range | startDate, endDate |
| get_user_sick_days | Get sick days overview for a year | year |
| get_public_holidays | Get public holidays for a year | year |
🎯 Available Prompts
The MoCo MCP server provides 8 intelligent prompts that orchestrate multiple tools to deliver comprehensive insights:
| Prompt | Description | Key Parameters |
|--------|-------------|----------------|
| weekly_time_report | Generates detailed weekly time tracking report with project breakdown | week_start, include_billable_analysis |
| vacation_planning_assistant | Assists with vacation planning by analyzing available days and holidays | planned_start_date, planned_end_date |
| personal_productivity_insights | Analyzes work habits and provides productivity recommendations | analysis_period, focus_area |
| monthly_business_review | Creates comprehensive business reports with trends and metrics | month, year, include_comparisons |
| smart_work_life_balance_advisor | Evaluates work-life balance with personalized recommendations | analysis_weeks, target_hours_per_week |
| project_time_analysis | Detailed project time analysis with efficiency metrics | project_ids, time_period |
| team_capacity_overview | Team capacity planning with absence and resource analysis | planning_horizon, include_holidays |
| work_hours_compliance_check | Compliance check for working time regulations | check_period, max_weekly_hours, max_daily_hours |
Prompt Examples
Weekly Time Report:
{
"name": "weekly_time_report",
"arguments": {
"week_start": "2024-01-15",
"include_billable_analysis": true
}
}Vacation Planning:
{
"name": "vacation_planning_assistant",
"arguments": {
"planned_start_date": "2024-07-15",
"planned_end_date": "2024-07-29"
}
}Work-Life Balance Analysis:
{
"name": "smart_work_life_balance_advisor",
"arguments": {
"analysis_weeks": 6,
"target_hours_per_week": 40
}
}Compliance Check:
{
"name": "work_hours_compliance_check",
"arguments": {
"check_period": "last_month",
"max_weekly_hours": 48,
"max_daily_hours": 10
}
}📝 Tool Examples
Get Activities
Filter all activities in a date range:
{
"name": "get_activities",
"arguments": {
"startDate": "2024-01-01",
"endDate": "2024-01-31"
}
}Filter activities for a specific project:
{
"name": "get_activities",
"arguments": {
"startDate": "2024-01-01",
"endDate": "2024-01-31",
"projectId": 123456
}
}Sample Output:
Activities from 2024-01-01 to 2024-01-31:
2024-01-15:
Project 123 (Website Redesign):
Task 456 (Frontend Development): 4.5h (4:30)
Task 789 (Backend API): 3.25h (3:15)
Project total: 7.75h (7:45)
Daily total: 7.75h (7:45)
Grand total: 7.75h (7:45)Get User Projects
List all assigned projects:
{
"name": "get_user_projects",
"arguments": {}
}Search projects:
{
"name": "get_user_projects",
"arguments": {
"query": "website"
}
}Get User Project Tasks
{
"name": "get_user_project_tasks",
"arguments": {
"projectId": 123456
}
}Get User Holidays
{
"name": "get_user_holidays",
"arguments": {
"year": 2024
}
}Sample Output:
Holiday overview for 2024:
Taken holiday days:
- 2024-03-15: 1.0 day
- 2024-04-22: 0.5 day
- 2024-07-08: 1.0 day
Summary:
- Taken vacation: 2.5 days
- Annual entitlement: 25 days
- Utilization: 10% (2.5/25)
- Remaining vacation: 22.5 daysGet User Presences
{
"name": "get_user_presences",
"arguments": {
"startDate": "2024-01-01",
"endDate": "2024-01-07"
}
}Sample Output:
Presences from 2024-01-01 to 2024-01-07:
Daily presences:
- 2024-01-01: 8.25h (8:15)
- 2024-01-02: 7.5h (7:30)
- 2024-01-03: 8.0h (8:00)
Grand total: 23.75h (23:45)
Statistics:
- Working days: 3
- Average per day: 7.92h (7:55)Get User Sick Days
{
"name": "get_user_sick_days",
"arguments": {
"year": 2024
}
}Get Public Holidays
{
"name": "get_public_holidays",
"arguments": {
"year": 2024
}
}Sample Output:
Public holidays for 2024:
Holiday dates:
- 2024-01-01: New Year's Day
- 2024-04-01: Good Friday
- 2024-04-03: Easter Monday
- 2024-05-01: Labor Day
- 2024-05-09: Ascension Day
- 2024-05-20: Whit Monday
- 2024-10-03: German Unity Day
- 2024-12-25: Christmas Day
- 2024-12-26: Boxing Day
Summary:
- Total public holidays: 9 days
- Approximate working days: 251 daysCreate Activity (Time Entry)
{
"name": "create_activity",
"arguments": {
"date": "2024-01-15",
"projectId": 123456,
"taskId": 789,
"hours": 2.5,
"description": "Implemented new feature"
}
}Start/Stop Timer
{
"name": "start_activity_timer",
"arguments": {
"activityId": 12345
}
}Create Company
{
"name": "create_company",
"arguments": {
"name": "Acme Corp",
"type": "customer",
"website": "https://acme.example.com",
"email": "[email protected]",
"country_code": "DE"
}
}Create Contact
{
"name": "create_contact",
"arguments": {
"firstname": "John",
"lastname": "Doe",
"companyId": 123,
"email": "[email protected]",
"phone": "+49 123 456789"
}
}Create Invoice
{
"name": "create_invoice",
"arguments": {
"customerId": 123,
"recipientAddress": "Acme Corp\n123 Main Street\n12345 Berlin",
"items": [
{
"title": "Consulting Services",
"quantity": 10,
"unit": "hours",
"unit_price": 150.00
}
],
"date": "2024-01-15",
"due_date": "2024-02-15"
}
}Send Invoice Email
{
"name": "send_invoice_email",
"arguments": {
"invoiceId": 456,
"emailsTo": ["[email protected]"],
"subject": "Invoice #2024-001",
"text": "Please find attached your invoice."
}
}🔧 Advanced Configuration
If you want to run from source:
git clone https://github.com/a-und-b/moco-mcp.git
cd moco-mcp
npm install
npm run build
npm startThen configure your MCP client to use the local path:
{
"mcpServers": {
"moco": {
"command": "node",
"args": ["/path/to/moco-mcp/dist/index.js"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}FROM node:18-alpine
WORKDIR /app
RUN npm install -g @a-und-b/moco-mcp
ENV MOCO_API_KEY=""
ENV MOCO_SUBDOMAIN=""
CMD ["@a-und-b/moco-mcp"]🔍 Troubleshooting
Common Issues
❌ Authentication Error:
API authentication failed. Please check MOCO_API_KEY.- Verify your API key is correct and has necessary permissions
- Check if the API key is properly set in environment variables
- Ensure the key hasn't expired
❌ Subdomain Error:
MOCO_SUBDOMAIN should only contain the subdomain name- Use only the subdomain part:
company(notcompany.mocoapp.com) - Remove
https://and.mocoapp.comfrom the subdomain
❌ Node.js Version Error:
This package requires Node.js >= 18.0.0- Update Node.js to version 18 or higher
- Check your version:
node --version
❌ npx Connection Issues:
Error: Cannot find module '@a-und-b/moco-mcp'- Ensure you have internet connection
- Try:
npx --yes @a-und-b/moco-mcp - Clear npx cache:
npx clear-npx-cache
❌ MCP Client Not Finding Tools:
- Restart your MCP client after configuration changes
- Check that environment variables are properly set
- Verify JSON configuration syntax is correct
Debug Mode
For debugging, you can run the server with additional logging:
NODE_ENV=development npx -y @a-und-b/moco-mcpTesting Connection
You can test the server manually:
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}' | npx -y @a-und-b/moco-mcp🌟 Features
- ✅ Full CRUD Support: Create, read, update, and delete across all entities
- 🔄 Automatic Pagination: Handles large datasets seamlessly
- 📊 Smart Aggregation: Automatic summation by date, project, and task
- ⏱️ Timer Control: Start and stop activity timers
- 🏢 CRM Integration: Manage companies and contacts
- 💰 Invoice Management: Create, send, and manage invoices
- 🧩 Comprehensive Tools: 26 specialized tools for different use cases
- 🎯 Intelligent Prompts: 8 AI-powered prompts for complex analysis and insights
- 🌐 Multi-Client Support: Works with all major MCP clients
🤝 Contributing
- Fork the repository
- Create a feature branch:
git checkout -b feature-name - Make your changes and add tests
- Run tests:
npm test - Submit a pull request
📄 License
MIT License - see LICENSE file for details.
🙏 Acknowledgments
This project is a fork of niondigital/moco-mcp, extended with comprehensive write operations for Activities, Projects, Companies, Contacts, and Invoices.
🆘 Support
- MOCO API Issues: MOCO API Documentation
- MCP Protocol: MCP Documentation
- Original Package: niondigital/moco-mcp
- This Fork: GitHub Issues
