
MoCo MCP Server
Provides a Model Context Protocol interface to MoCo time tracking and project management systems, enabling AI assistants to retrieve work activities, projects, tasks, holidays, and presence data.
Tools
get_activities
Get all activities within a date range with automatic summation by date, project, and task. Optionally filter by project ID.
get_projects
Get all projects assigned to the current user or search within assigned projects by name/description. If no query is provided, returns all assigned projects.
get_project_tasks
Get all tasks for a specific assigned project by project ID. Only works for projects assigned to the current user.
get_user_holidays
Get all user holidays for a specific year with utilization calculations and remaining vacation days
get_user_presences
Get user presences within a date range with daily aggregation and total calculations
get_user_sick_days
Get all user sick days for a specific year with daily breakdown and total calculations
get_public_holidays
Get all public holidays for a specific year with daily breakdown and total calculations
README
📊 MOCO MCP Server
A Model Context Protocol (MCP) server that provides employee read access to the MOCO API for time tracking, project management, holiday tracking, and presence monitoring.
⚡ Quick Start
npx -y @niondigital/moco-mcp
That'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
<details> <summary><strong>Claude Desktop</strong></summary>
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", "@niondigital/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}
</details>
<details> <summary><strong>Cursor</strong></summary>
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", "@niondigital/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}
</details>
<details> <summary><strong>Windsurf</strong></summary>
Add to your Windsurf MCP configuration:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@niondigital/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}
</details>
<details> <summary><strong>Claude Code (CLI)</strong></summary>
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 @niondigital/moco-mcp
</details>
<details> <summary><strong>Gemini CLI</strong></summary>
Configure Gemini CLI with MCP support:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@niondigital/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}
</details>
<details> <summary><strong>Kiro</strong></summary>
- Go to
Kiro
>MCP Servers
- Add new MCP server by clicking
+ Add
- Paste the configuration below:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": [
"-y",
"@niondigital/moco-mcp"
],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
},
"disabled": false,
"autoApprove": []
}
}
}
- Click
Save
to apply changes </details>
<details> <summary><strong>LM Studio</strong></summary>
- Go to
Program
(right side) >Install
>Edit mcp.json
- Paste the configuration below:
{
"mcpServers": {
"moco": {
"command": "npx",
"args": ["-y", "@niondigital/moco-mcp"],
"env": {
"MOCO_API_KEY": "your-moco-api-key",
"MOCO_SUBDOMAIN": "your-subdomain"
}
}
}
}
- Click
Save
to 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
</details>
🔑 MoCo API Setup
Getting Your API Credentials
- Log into your MoCo account
- Navigate to API settings:
- Go to Profile → Integrations
- Or visit:
https://niondigital.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-subdomain
Option 3: MCP Client Configuration (recommended)
Use the env
section in your MCP client configuration as shown above.
🛠️ Available Tools
Tool | Description | Parameters |
---|---|---|
get_activities |
Get activities within a date range with summation and optional project filtering | startDate , endDate (ISO 8601), projectId (optional) |
get_user_projects |
List all assigned projects or search by query | query (optional) |
get_user_project_tasks |
Get all tasks for a specific assigned project | projectId |
get_user_holidays |
Get holiday overview for a year with calculations | year |
get_user_presences |
Get presence data within a date range with daily summaries | startDate , endDate (ISO 8601) |
get_user_sick_days |
Get sick days overview for a year with calculations | year |
get_public_holidays |
Get public holidays for a year with working days calculations | 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 days
Get 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 days
🔧 Advanced Configuration
<details> <summary><strong>Local Development</strong></summary>
If you want to run from source:
git clone https://github.com/niondigital/moco-mcp.git
cd moco-mcp
npm install
npm run build
npm start
Then 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"
}
}
}
}
</details>
<details> <summary><strong>Docker Support</strong></summary>
FROM node:18-alpine
WORKDIR /app
RUN npm install -g @niondigital/moco-mcp
ENV MOCO_API_KEY=""
ENV MOCO_SUBDOMAIN=""
CMD ["@niondigital/moco-mcp"]
</details>
🔍 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.com
from 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 '@niondigital/moco-mcp'
- Ensure you have internet connection
- Try:
npx --yes @niondigital/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 @niondigital/moco-mcp
Testing Connection
You can test the server manually:
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/list"}' | npx -y @niondigital/moco-mcp
🌟 Features
- ✅ Read-only Access: Safe API integration with no data modification
- 🔄 Automatic Pagination: Handles large datasets seamlessly
- 📊 Smart Aggregation: Automatic summation by date, project, and task
- 🎯 Project Filtering: Filter activities by specific projects
- ⚡ Fast Performance: Efficient API calls with proper caching
- 🛡️ Type Safety: Full TypeScript implementation
- 🧩 Comprehensive Tools: 7 specialized tools for different use cases
- 🎯 Intelligent Prompts: 8 AI-powered prompts for complex analysis and insights
- 📅 Date Validation: Automatic date format validation
- 🔍 Error Handling: User-friendly error messages
- 🌐 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.
🆘 Support
- MoCo API Issues: MoCo API Documentation
- MCP Protocol: MCP Documentation
- This Package: GitHub Issues
📈 Changelog
v1.0.0
- ✨ Initial release with 7 MCP tools
- 🚀 NPM package with
npx
support - 📚 Multi-client installation guides
- 🔧 Full TypeScript implementation
- ⚡ Automatic pagination and error handling
- 🎯 Project filtering for activities
- 📊 Comprehensive time tracking and project management
- 🎅 Public holidays tracking for working days calculation
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
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.