ClickUp MCP Server
Enables integration with ClickUp's task management platform, allowing users to retrieve, create, update, and manage tasks and lists through the Model Context Protocol.
README
ClickUp MCP Server
A Model Context Protocol (MCP) server that provides integration with the ClickUp API, allowing clients to interact with ClickUp tasks and lists through standardized MCP tools.
Overview
This server implements the MCP protocol to expose ClickUp functionality as tools that can be called by MCP-compatible clients. It supports retrieving, creating, updating, and getting details of tasks in ClickUp lists.
Origin
This MCP server implementation originated from the need to connect KiloCode with ClickUp, enabling seamless integration between the AI-powered code assistant and ClickUp's task management platform.
Features
- Task Management: Get, create, and update ClickUp tasks
- List Integration: Work with specific ClickUp lists
- MCP Compliant: Full MCP protocol implementation using the official SDK
- TypeScript: Written in TypeScript for type safety
Installation
- Clone or download this repository
- Install dependencies:
npm install - Build the project:
npm run build
Configuration
Environment Variables
Set the following environment variable before running the server:
CLICKUP_ACCESS_TOKEN: Your ClickUp API access token. You can generate this from your ClickUp account settings under "Apps" > "API Token".
Example:
export CLICKUP_ACCESS_TOKEN=your_clickup_token_here
Usage
Running the Server
After building, run the server:
node build/index.js
The server communicates via stdio (standard input/output), making it suitable for integration with MCP clients.
Client Integration
MCP clients connect to this server and can call the available tools. The server uses JSON-RPC 2.0 protocol for communication.
Client Configuration
To connect an MCP client to this server, configure the client with the server's command and environment variables.
For example, in Claude Desktop, add the following to your claude_desktop_config.json:
{
"mcpServers": {
"clickup": {
"command": "node",
"args": ["path/to/clickup-mcp-server/build/index.js"],
"env": {
"CLICKUP_ACCESS_TOKEN": "your_clickup_token_here"
}
}
}
}
Replace path/to/clickup-mcp-server with the actual path to this project directory.
Tool: get_tasks
Retrieves a list of tasks from a ClickUp list.
Parameters:
list_id(string, required): The ClickUp List IDlimit(number, optional): Number of tasks to retrieve (max 100, default 50)
Example Request:
{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/call",
"params": {
"name": "get_tasks",
"arguments": {
"list_id": "987654321",
"limit": 25
}
}
}
Example Response:
{
"jsonrpc": "2.0",
"id": 1,
"result": {
"content": [
{
"type": "text",
"text": "[{\"id\": \"abc123\", \"name\": \"Sample Task\", \"status\": \"open\", \"assignees\": [], \"due_date\": null}, ...]"
}
]
}
}
Tool: create_task
Creates a new task in a ClickUp list.
Parameters:
list_id(string, required): The ClickUp List IDname(string, required): Task namedescription(string, optional): Task descriptionassignees(array of numbers, optional): Array of assignee user IDsdue_date(string, optional): Due date as Unix timestamp in milliseconds
Example Request:
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "create_task",
"arguments": {
"list_id": "987654321",
"name": "New Task",
"description": "Task description",
"due_date": "1640995200000"
}
}
}
Tool: update_task
Updates an existing ClickUp task.
Parameters:
task_id(string, required): The ClickUp Task IDname(string, optional): New task namedescription(string, optional): New task descriptionstatus(string, optional): New statusassignees(array of numbers, optional): New array of assignee user IDsdue_date(string, optional): New due date as Unix timestamp in milliseconds
Example Request:
{
"jsonrpc": "2.0",
"id": 3,
"method": "tools/call",
"params": {
"name": "update_task",
"arguments": {
"task_id": "abc123",
"status": "in progress"
}
}
}
Tool: get_task
Retrieves details of a specific ClickUp task.
Parameters:
task_id(string, required): The ClickUp Task ID
Example Request:
{
"jsonrpc": "2.0",
"id": 4,
"method": "tools/call",
"params": {
"name": "get_task",
"arguments": {
"task_id": "abc123"
}
}
}
Finding ClickUp IDs
- List ID: In ClickUp, navigate to your list. The URL will be something like
https://app.clickup.com/1234567/v/li/987654321. The number after/li/is the list ID. - Task ID: Task URLs contain the task ID, or you can get it from the API responses.
- User IDs: Use ClickUp's API or interface to find user IDs for assignees.
Error Handling
If an API call fails, the response will include an isError: true field with the error message:
{
"jsonrpc": "2.0",
"id": 1,
"result": {
"content": [
{
"type": "text",
"text": "ClickUp API error: Invalid list ID"
}
],
"isError": true
}
}
Testing
A test script is provided to verify that the MCP server is working correctly.
-
Set your ClickUp access token:
export CLICKUP_ACCESS_TOKEN=your_clickup_token_here -
Run the test with a valid list ID:
node test-mcp.js <list_id>Replace
<list_id>with a valid ClickUp list ID (e.g.,901110500007).
The test will:
- Verify that the server initializes correctly
- Check that all tools are available
- Test the
get_taskstool with the provided list ID
For more comprehensive testing of other tools, you can modify test-mcp.js to include calls to create_task, update_task, and get_task. Note that create_task will create real tasks in ClickUp, so use with caution.
Development
To run in development mode with TypeScript watching:
npm run dev
Dependencies
@modelcontextprotocol/sdk: MCP protocol implementationaxios: HTTP client for ClickUp APIzod: Schema validationtypescript: TypeScript compiler
License
This project is open source. Please check the license file for details.
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.
E2B
Using MCP to run code via e2b.