todoist-v1-mcp-server
Provides tools for interacting with Todoist's API v1, enabling AI agents to manage tasks, projects, sections, and labels programmatically through the Todoist platform.
todoist-v1-mcp-server
A clean, reliable MCP (Model Context Protocol) server for Todoist — built on the Todoist unified API v1.
Why this exists
The official Todoist web MCP (todoist-ai) has a known persistent disconnection bug on the Anthropic side that requires reconnecting daily. Community alternatives are either built on the deprecated REST API v2 or have schema validation bugs that cause failures when Todoist returns additional fields as their API evolves.
This server:
Targets the current Todoist API v1 (not deprecated v2)
Uses stdio transport — no cloud dependency, no daily reconnections
Uses the modern MCP SDK
registerTool()API (not the deprecatedsetRequestHandlerpattern)Never enforces strict output schemas on API responses — Todoist can add new fields freely without breaking anything
Zero SDK wrapper dependency — direct HTTP calls via axios, so there's no intermediary library drifting from the API
Tools (20 total)
Tasks
Tool | Description |
| List/filter tasks — supports Todoist filter strings like |
| Get a single task by ID |
| Create a task with natural language due dates ( |
| Update any field; pass |
| Mark a task as done |
| Reopen a completed task |
| Permanently delete a task |
Projects
Tool | Description |
| List all projects |
| Get a single project by ID |
| Create a project (with color, view style, parent) |
| Update a project |
| Permanently delete a project and all its tasks |
Sections
Tool | Description |
| List sections within a project |
| Create a section |
| Rename a section |
| Delete a section |
Labels
Tool | Description |
| List all personal labels |
| Create a label |
| Update a label |
| Delete a label |
Setup
1. Get your Todoist API token
Go to Todoist → Settings → Integrations → Developer and copy your API token.
2. Install and build
git clone https://github.com/christulino/todoist-v1-mcp-server
cd todoist-v1-mcp-server
npm install
npm run build3. Configure Claude Desktop
Edit ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"todoist": {
"command": "node",
"args": ["/absolute/path/to/todoist-v1-mcp-server/dist/index.js"],
"env": {
"TODOIST_API_TOKEN": "your_api_token_here"
}
}
}
}Restart Claude Desktop. You should see "todoist" in the connected MCP servers.
4. Configure Claude Code (optional)
claude mcp add todoist -- node /absolute/path/to/todoist-v1-mcp-server/dist/index.jsThen set the env var:
export TODOIST_API_TOKEN=your_api_token_hereOr add it to your shell profile.
Usage examples
Once connected, Claude can handle natural language like:
"What's on my plate today?" → uses
todoist_get_taskswithfilter: "today""Add a task to call the dentist next Tuesday" → uses
todoist_create_task"Mark the dentist task as done" → uses
todoist_complete_task"Show me everything overdue" → uses
todoist_get_taskswithfilter: "overdue""Create a project called Home Renovation" → uses
todoist_create_project"What projects do I have?" → uses
todoist_get_projects
Todoist filter syntax
The filter parameter in todoist_get_tasks supports Todoist's full natural language filter syntax:
Filter | Meaning |
| Due today |
| Past due |
| Due in the next 7 days |
| Priority urgent |
| Tasks in a specific project |
| Tasks with a specific label |
| Tasks without a due date |
| Today or overdue (combine with |
| Today AND labeled 'waiting' |
Full filter documentation: https://todoist.com/help/articles/introduction-to-filters
Requirements
Node.js 18+
A Todoist account (free tier works)
Development
npm run dev # tsx watch mode with auto-reload
npm run build # compile TypeScript
npm start # run compiled serverTesting
The test suite hits the live Todoist API and runs a full CRUD cycle across tasks, projects, sections, and labels. All test data is prefixed with [mcp-test] and cleaned up automatically.
TODOIST_API_TOKEN=your_token npm testYour API token is at Todoist → Settings → Integrations → Developer — same token you put in claude_desktop_config.json.
Contributing
PRs welcome. The goal is a minimal, correct implementation that stays current with the Todoist API v1. Priorities:
Correctness over cleverness
Permissive output handling (never reject unknown API fields)
Helpful error messages that tell you what went wrong and how to fix it
License
MIT
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/christulino/todoist-v1-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server