Skip to main content

FastMCP server for Todoist API integration

Project description

Todoist MCP Server

MCP server for Todoist API integration. Published to PyPI

Status

Full Functionality - Now using Todoist unified API v1 with proper pagination support

v0.3.0 - Added Comment CRUD operations and Task Move functionality

Features

  • Full cursor-based pagination for tasks, projects, and comments
  • Configurable limit parameter for all list endpoints
  • Multi-auth support (environment, config file, runtime)
  • Complete task and project management capabilities
  • Comment CRUD operations for tasks and projects
  • Move tasks between projects, sections, and parents
  • Error handling with detailed error messages

Installation

pip install todoist-mcp

Claude Desktop Configuration

Add to your claude_desktop_config.json:

{
  "mcpServers": {
    "todoist": {
      "command": "uvx",
      "args": ["todoist-mcp"],
      "env": {
        "TODOIST_API_TOKEN": "your_token_here"
      }
    }
  }
}

AmazonQ Developer CLI Configuration

Add to your .amazonq/mcp.json:

{
  "mcpServers": {
    "todoist": {
      "command": "uvx",
      "args": ["todoist-mcp"],
      "env": {
        "TODOIST_API_TOKEN": "your_token_here"
      }
    }
  }
}

Alternative: Using mcp-gen

For complex MCP configuration management such as in providing configurations for different contexts ot teams, use mcp-gen with YAML:

See https://github.com/OAuthBringer/mcp-gen/examples for more full examples

# mcp-config.yaml

servers:
    todoist:
      command: uvx
      args: [todoist-mcp]
      env:
        TODOIST_API_TOKEN: {{ secrets.TODOIST_API_TOKEN }}
    ```
Then generate your configuration:
```bash
`mcp-gen generate -c mcp-config.yaml -s secrets-file.yaml`

Configuration

Authentication options (in order of precedence):

  1. Runtime: Pass token when creating client
  2. Config file: ~/.config/todoist/config.json with {"api_token": "your_token"}
  3. Environment: Set TODOIST_API_TOKEN

Available Tools

Projects

  • get_projects - List projects with pagination (limit, cursor)
  • get_project - Get single project by ID
  • add_project - Create new project

Tasks

  • get_tasks - List tasks with pagination and filters
  • get_task - Get single task by ID
  • add_task - Create new task
  • update_task - Update existing task
  • move_task - Move task to different project, section, or parent

Comments

  • get_comments - List comments for task/project with pagination
  • get_comment - Get single comment by ID
  • add_comment - Add comment to task or project
  • update_comment - Update existing comment
  • delete_comment - Delete a comment

Technical Details

  • Built with FastMCP v2.3.3+
  • Python 3.11+
  • Direct API v1 integration using httpx
  • No dependency on todoist-api-python SDK

Development

# Clone repository
git clone https://github.com/OAuthBringer/todoist-mcp
cd todoist-mcp

# Create virtual environment
uv venv
source .venv/bin/activate  # or .venv\Scripts\activate on Windows

# Install dependencies
uv pip install -e .
uv pip install -e ".[dev]"

# Run tests
pytest

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

todoist_mcp-0.3.0.tar.gz (15.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

todoist_mcp-0.3.0-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file todoist_mcp-0.3.0.tar.gz.

File metadata

  • Download URL: todoist_mcp-0.3.0.tar.gz
  • Upload date:
  • Size: 15.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for todoist_mcp-0.3.0.tar.gz
Algorithm Hash digest
SHA256 352c6194680161f09b4a5e46f9f06b9b67328b2f6fa242b15ec72a74b5856969
MD5 9d48ad8f63af05f40a27704c1134becf
BLAKE2b-256 93c9ded2b00a9a35c20eae05190b7e6951460e04266ece31a5ec6a2f10b6cd33

See more details on using hashes here.

File details

Details for the file todoist_mcp-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: todoist_mcp-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for todoist_mcp-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 27a1d25a28aac5e3cf35e8123ca192ae33339a00f92ecddbaf1a4c0d070f2d9a
MD5 a0a366951733bf61c42a9905089cb042
BLAKE2b-256 443aadeb86299a18019b4013ba6216621bab1b25c924ab3bcebd8b83bb78ea52

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page