todoist-go-mcp-server
The Todoist MCP Server enables integration between Todoist and AI assistants by using the Model Context Protocol. It provides task and project management capabilities, allowing AI to manage user tasks more effectively.
Todoist MCP Server
A Model Context Protocol (MCP) server that provides Todoist API integration for AI assistants.
Overview
The Todoist MCP Server allows AI assistants to interact with Todoist, enabling them to manage tasks and projects on behalf of users. This server implements the Model Context Protocol (MCP), providing a standardized interface for AI systems to access Todoist functionality.
Features
-
Task Management
- Get filter rules and examples for task filtering
- Get tasks with filtering options
- Get task details
- Create new tasks
- Update existing tasks
- Mark tasks as completed
- Delete tasks
-
Project Management
- Get all projects
- Get project details
Installation
Prerequisites
- Go 1.21 or later
- Todoist API token
Setup
- Clone the repository:
git clone https://github.com/naotama2002/todoist-go-mcp-server.git
cd todoist-go-mcp-server
- Install dependencies:
go mod download
- Set up your Todoist API token:
Create a .envrc
file in the root directory with the following content:
export TODOIST_API_TOKEN=your_todoist_api_token
If you're using direnv, run:
direnv allow
Alternatively, you can set the environment variable directly:
export TODOIST_API_TOKEN=your_todoist_api_token
Usage
Running the Server
HTTP Mode
Run the server in HTTP mode:
go run cmd/todoist-mcp-server/main.go --mode http --addr :8080
Standard I/O Mode
Run the server in stdio mode for integration with MCP clients:
go run cmd/todoist-mcp-server/main.go --mode stdio
Command Line Options
The server supports the following command line options:
--mode <mode>
: Server mode, either 'http' or 'stdio' (default: "http")http
: Run as an HTTP serverstdio
: Run using standard input/output for MCP communication
--addr <address>
: Address to listen on in HTTP mode (default: ":8080")--token <token>
: Todoist API token (can also be set via TODOIST_API_TOKEN environment variable)
Examples:
# Run HTTP server on port 3000
go run cmd/todoist-mcp-server/main.go --mode http --addr :3000
# Run with a specific Todoist API token
go run cmd/todoist-mcp-server/main.go --mode http --token your_todoist_api_token
# Run in stdio mode
go run cmd/todoist-mcp-server/main.go --mode stdio
Testing with the MCP Client
You can test the server using the included test client:
go run cmd/test-mcp-client/main.go
Available Tools
Task Management
todoist_get_task_filter_rules
Get filter rules and examples for Todoist task filters. This tool helps translate natural language queries into Todoist filter syntax for the todoist_get_tasks
tool.
Parameters: None
Example response (Markdown format):
# Introduction to Filters
Filters in Todoist are custom views that display tasks based on specific criteria. You can filter tasks by name, date, project, label, priority, creation date, and more.
## Creating Filters
1. Select "Filters & Labels" in the sidebar
2. Click the add icon next to Filters
3. Enter a name for your filter and change its color (optional)
4. Enter your filter query
5. Click "Add" to save your filter
## Filter Symbols
| Symbol | Meaning | Example |
|--------|---------|--------|
| \| | OR | today \| overdue |
| & | AND | today & p1 |
| ! | NOT | !subtask |
| () | Priority processing | (today \| overdue) & #work |
## Advanced Queries
### Keyword-Based Filters
| Description | Query |
|-------------|-------|
| Tasks containing "meeting" | search: meeting |
| Tasks containing "meeting" scheduled for today | search: meeting & today |
### Date-Based Filters
| Description | Query |
|-------------|-------|
| Tasks for a specific date | date: jan 3 |
| Tasks before a specific date | before: may 5 |
| Tasks with no date | no date |
## Useful Filter Examples
| Description | Query |
|-------------|-------|
| Overdue or today's tasks in "Work" project | (today \| overdue) & #work |
| Tasks with no date | no date |
| Tasks with @waiting label in the next 7 days | 7 days & @waiting |
#### `todoist_get_tasks`
Get a list of tasks with filtering options.
Parameters:
- `projectId` (string, optional): Filter tasks by project ID
- `filter` (string, optional): Todoist filter query using the Todoist filter syntax
Example:
```json
{
"projectId": "2203306141",
"filter": "today"
}
todoist_get_task
Get details of a specific task.
Parameters:
id
(string, required): The unique identifier of the task
Example:
{
"id": "2995104339"
}
todoist_create_task
Create a new task.
Parameters:
content
(string, required): The content of the taskdescription
(string, optional): Detailed description or notes for the taskprojectId
(string, optional): Project ID to assign the task toparentId
(string, optional): Parent task ID for creating subtasksorder
(integer, optional): Order value for positioning the taskpriority
(integer, optional): Task priority: 4 (normal), 3 (medium), 2 (high), 1 (urgent)dueString
(string, optional): Due date in natural language, e.g., 'today', 'tomorrow'dueDate
(string, optional): Due date in YYYY-MM-DD formatdueDatetime
(string, optional): Due date and time in RFC3339 format
Example:
{
"content": "Buy groceries",
"description": "Need to buy milk, eggs, and bread",
"projectId": "2203306141",
"priority": 2,
"dueString": "tomorrow at 10am"
}
todoist_update_task
Update an existing task.
Parameters:
id
(string, required): The unique identifier of the task to updatecontent
(string, optional): The new content of the taskdescription
(string, optional): Detailed description or notes for the taskpriority
(integer, optional): Task priority: 4 (normal), 3 (medium), 2 (high), 1 (urgent)dueString
(string, optional): Due date in natural languagedueDate
(string, optional): Due date in YYYY-MM-DD formatdueDatetime
(string, optional): Due date and time in RFC3339 format
Example:
{
"id": "2995104339",
"content": "Buy groceries and household items",
"priority": 1
}
todoist_close_task
Mark a task as completed.
Parameters:
id
(string, required): The unique identifier of the task to mark as completed
Example:
{
"id": "2995104339"
}
todoist_delete_task
Delete a task.
Parameters:
id
(string, required): The unique identifier of the task to delete
Example:
{
"id": "2995104339"
}
Project Management
todoist_get_projects
Get a list of all projects.
Parameters: None
todoist_get_project
Get details of a specific project.
Parameters:
id
(string, required): The unique identifier of the project
Example:
{
"id": "2203306141"
}
Integration with Claude Desktop
To use the Todoist MCP Server with Claude Desktop, you need to add it to your Claude Desktop configuration.
Download from GitHub Releases
The easiest way to get started is to download a pre-built binary from the GitHub Releases page:
-
Go to the Releases page and download the latest release for your platform:
- Linux:
todoist-mcp-server_Linux_x86_64.tar.gz
ortodoist-mcp-server_Linux_arm64.tar.gz
- macOS:
todoist-mcp-server_Darwin_x86_64.tar.gz
ortodoist-mcp-server_Darwin_arm64.tar.gz
- Windows:
todoist-mcp-server_Windows_x86_64.zip
- Linux:
-
Extract the archive to get the
todoist-mcp-server
binary:# For Linux/macOS tar -xzf todoist-mcp-server_*_*.tar.gz # For Windows # Extract the zip file using Windows Explorer or a tool like 7-Zip
-
Make the binary executable (Linux/macOS only):
chmod +x todoist-mcp-server
-
Optionally, move the binary to a location in your PATH:
# Linux/macOS sudo mv todoist-mcp-server /usr/local/bin/ # Windows # Move the .exe file to a location in your PATH
Build from source
Alternatively, you can build the binary from source:
# Build the binary
make build
Configuration
Add the Todoist MCP Server to your Claude Desktop configuration:
HTTP Mode
- Run the Todoist MCP Server in HTTP mode:
todoist-mcp-server --mode http --addr :8080
- Add the following configuration to your Claude Desktop settings:
{
"name": "Todoist",
"description": "Manage Todoist tasks and projects",
"endpoint": "http://localhost:8080",
"tools": [
{
"name": "todoist_get_task_filter_rules",
"description": "Get filter rules and examples for Todoist task filters"
},
{
"name": "todoist_get_tasks",
"description": "Get a list of tasks with filtering options"
},
{
"name": "todoist_get_task",
"description": "Get details of a specific task"
},
{
"name": "todoist_create_task",
"description": "Create a new task"
},
{
"name": "todoist_update_task",
"description": "Update an existing task"
},
{
"name": "todoist_close_task",
"description": "Mark a task as completed"
},
{
"name": "todoist_delete_task",
"description": "Delete a task"
},
{
"name": "todoist_get_projects",
"description": "Get a list of all projects"
},
{
"name": "todoist_get_project",
"description": "Get details of a specific project"
}
]
}
Stdio Mode
Claude Desktop / Cline, Roo Cline / Windsurf
{
"mcpServers": {
"github": {
"todoist": {
"command": "/path/to/todoist-mcp-server",
"args": ["--mode", "stdio"],
"env": {
"TODOIST_API_TOKEN": "<YOUR_TODOIST_API_TOKEN>"
}
}
}
}
}
VSCode
{
"mcp": {
"servers": {
"todoist": {
"command": "/path/to/todoist-mcp-server",
"args": ["--mode", "stdio"],
"env": {
"TODOIST_API_TOKEN": "<YOUR_TODOIST_API_TOKEN>"
}
}
}
}
}
Replace /path/to/todoist-mcp-server
with the actual path to the binary and <YOUR_TODOIST_API_TOKEN>
with your Todoist API token.
-
In Claude Desktop, go to Settings > Tools > Add Tool, and paste the appropriate JSON configuration.
-
Save the configuration and restart Claude Desktop if necessary.
Now you can ask Claude to manage your Todoist tasks and projects using natural language.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the MIT License - see the file for details.
Acknowledgments
Development
Project Structure
todoist-go-mcp-server/
├── cmd/
│ ├── test-client/ # Test client for the Todoist API
│ ├── test-mcp-client/ # Test client for the MCP server
│ └── todoist-mcp-server/ # Main MCP server application
├── docs/ # Documentation
├── pkg/
│ ├── log/ # Logging utilities
│ ├── todoist/ # Todoist API client and tools
│ └── toolsets/ # MCP toolset definitions
└── todo/ # Implementation plans and notes
Running Tests
make test