Plane MCP Server
A Model Context Protocol server that enables AI interfaces to seamlessly interact with Plane's project management system, allowing management of projects, issues, states, and other work items through a standardized API.
README
Plane MCP Server
The Plane MCP Server is a Model Context Protocol (MCP) server that provides seamless integration with Plane APIs, enabling projects, work items, and automations capabilities for develops and AI interfaces.
Use Cases
- Create, update Projects and Work items
- Assign People, Properties, and Write Comments to progress on the Work
- Move and observe with various Work items in States
- Add Labels to the Work items
- Extracting and analyzing data from Projects and Members inside Plane
- Building AI powered tools and applications that interact with Plane's ecosystem
Configuration Parameters
PLANE_API_KEY- The user's API token. This can be obtained from the/settings/api-tokens/page in the UI.PLANE_WORKSPACE_SLUG- The workspace slug for your Plane instance.PLANE_API_HOST_URL(optional) - The host URL of the Plane API Server. Defaults to https://api.plane.so/
Tools
Users
get_user- Get the current user's information- No parameters required
Projects
-
get_projects- Get all projects for the current user- No parameters required
-
create_project- Create a new projectname: Project name (string, required)
Issue Types
-
list_issue_types- Get all issue types for a specific projectproject_id: UUID of the project (string, required)
-
get_issue_type- Get details of a specific issue typeproject_id: UUID of the project (string, required)type_id: UUID of the issue type (string, required)
-
create_issue_type- Create a new issue type in a projectproject_id: UUID of the project (string, required)issue_type_data: Object containing:name: Name of the issue type (string, required)description: Description of the issue type (string, required)
-
update_issue_type- Update an existing issue typeproject_id: UUID of the project (string, required)type_id: UUID of the issue type (string, required)issue_type_data: Fields to update on the issue type (object)
-
delete_issue_type- Delete an issue typeproject_id: UUID of the project (string, required)type_id: UUID of the issue type (string, required)
States
-
list_states- Get all states for a specific projectproject_id: UUID of the project (string, required)
-
get_state- Get details of a specific stateproject_id: UUID of the project (string, required)state_id: UUID of the state (string, required)
-
create_state- Create a new state in a projectproject_id: UUID of the project (string, required)state_data: Object containing:name: Name of the state (string, required)color: Color code for the state (string, required)
-
update_state- Update an existing stateproject_id: UUID of the project (string, required)state_id: UUID of the state (string, required)state_data: Fields to update on the state (object)
-
delete_state- Delete a stateproject_id: UUID of the project (string, required)state_id: UUID of the state (string, required)
Labels
-
list_labels- Get all labels for a specific projectproject_id: UUID of the project (string, required)
-
get_label- Get details of a specific labelproject_id: UUID of the project (string, required)label_id: UUID of the label (string, required)
-
create_label- Create a new label in a projectproject_id: UUID of the project (string, required)label_data: Object containing:name: Name of the label (string, required)color: Color code for the label (string, required)
-
update_label- Update an existing labelproject_id: UUID of the project (string, required)label_id: UUID of the label (string, required)label_data: Fields to update on the label (object)
-
delete_label- Delete a labelproject_id: UUID of the project (string, required)label_id: UUID of the label (string, required)
Issues
-
get_issue_using_readable_identifier- Get issue details using readable identifier (e.g., PROJ-123)project_identifier: Project identifier (e.g., "PROJ") (string, required)issue_identifier: Issue number (e.g., "123") (string, required)
-
get_issue_comments- Get all comments for a specific issueproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)
-
add_issue_comment- Add a comment to an issueproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)comment_html: HTML content of the comment (string, required)
-
create_issue- Create a new issueproject_id: UUID of the project (string, required)issue_data: Object containing:name: Title of the issue (string, required)description_html: HTML description of the issue (string, required)
-
update_issue- Update an existing issueproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)issue_data: Fields to update on the issue (object)
Modules
-
list_modules- Get all modules for a specific projectproject_id: UUID of the project (string, required)
-
get_module- Get details of a specific moduleproject_id: UUID of the project (string, required)module_id: UUID of the module (string, required)
-
create_module- Create a new module in a projectproject_id: UUID of the project (string, required)module_data: Object containing:name: Name of the module (string, required)
-
update_module- Update an existing moduleproject_id: UUID of the project (string, required)module_id: UUID of the module (string, required)module_data: Fields to update on the module (object)
-
delete_module- Delete a moduleproject_id: UUID of the project (string, required)module_id: UUID of the module (string, required)
Module Issues
-
list_module_issues- Get all issues for a specific moduleproject_id: UUID of the project (string, required)module_id: UUID of the module (string, required)
-
add_module_issues- Add issues to a moduleproject_id: UUID of the project (string, required)module_id: UUID of the module (string, required)issues: Array of issue UUIDs to add (string[], required)
-
delete_module_issue- Remove an issue from a moduleproject_id: UUID of the project (string, required)module_id: UUID of the module (string, required)issue_id: UUID of the issue to remove (string, required)
Cycles
-
list_cycles- Get all cycles for a specific projectproject_id: UUID of the project (string, required)
-
get_cycle- Get details of a specific cycleproject_id: UUID of the project (string, required)cycle_id: UUID of the cycle (string, required)
-
create_cycle- Create a new cycle in a projectproject_id: UUID of the project (string, required)cycle_data: Object containing:name: Name of the cycle (string, required)start_date: Start date (YYYY-MM-DD) (string, required)end_date: End date (YYYY-MM-DD) (string, required)
-
update_cycle- Update an existing cycleproject_id: UUID of the project (string, required)cycle_id: UUID of the cycle (string, required)cycle_data: Fields to update on the cycle (object)
-
delete_cycle- Delete a cycleproject_id: UUID of the project (string, required)cycle_id: UUID of the cycle (string, required)
Cycle Issues
-
list_cycle_issues- Get all issues for a specific cycleproject_id: UUID of the project (string, required)cycle_id: UUID of the cycle (string, required)
-
add_cycle_issues- Add issues to a cycleproject_id: UUID of the project (string, required)cycle_id: UUID of the cycle (string, required)issues: Array of issue UUIDs to add (string[], required)
-
delete_cycle_issue- Remove an issue from a cycleproject_id: UUID of the project (string, required)cycle_id: UUID of the cycle (string, required)issue_id: UUID of the issue to remove (string, required)
Work Logs
-
get_issue_worklogs- Get all worklogs for a specific issueproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)
-
get_total_worklogs- Get total logged time for a projectproject_id: UUID of the project (string, required)
-
create_worklog- Create a new worklog for an issueproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)worklog_data: Object containing:description: Description of the work done (string, required)duration: Duration in minutes (integer, required)
-
update_worklog- Update an existing worklogproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)worklog_id: UUID of the worklog (string, required)worklog_data: Fields to update on the worklog (object)
-
delete_worklog- Delete a worklogproject_id: UUID of the project (string, required)issue_id: UUID of the issue (string, required)worklog_id: UUID of the worklog (string, required)
Usage
Claude Desktop
Add Plane to Claude Desktop by editing your claude_desktop_config.json.
{
"mcpServers": {
"plane": {
"command": "npx",
"args": [
"-y",
"@makeplane/plane-mcp-server"
],
"env": {
"PLANE_API_KEY": "<YOUR_API_KEY>",
"PLANE_API_HOST_URL": "<HOST_URL_FOR_SELF_HOSTED",
"PLANE_WORKSPACE_SLUG": "<YOUR_WORKSPACE_SLUG>"
}
}
}
}
VSCode
Add Plane to VSCode by editing your .vscode.json/mcp.json.
{
"servers": {
"plane": {
"command": "npx",
"args": [
"-y",
"@makeplane/plane-mcp-server"
],
"env": {
"PLANE_API_KEY": "<YOUR_API_KEY>",
"PLANE_API_HOST_URL": "<HOST_URL_FOR_SELF_HOSTED",
"PLANE_WORKSPACE_SLUG": "<YOUR_WORKSPACE_SLUG>"
}
}
}
}
License
This project is licensed under the terms of the MIT open source license.
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。
mcp-server-qdrant
这个仓库展示了如何为向量搜索引擎 Qdrant 创建一个 MCP (Managed Control Plane) 服务器的示例。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。