Allows to add new todo items, view all todos, view today's tasks, and check off tasks as complete in a Notion database through Claude
Notion MCP Integration
A simple Model Context Protocol (MCP) server that integrates with Notion's API to manage my personal todo list through Claude. This is a basic implementation tailored specifically for my minimalist todo list setup in Notion.
Important Note
This is a personal project designed for a very specific use case: my simple Notion todo list that has just three properties:
- Task (title) 
- When (select with only two options: "today" or "later") 
- Checkbox (marks if completed) 
While you can use this as a starting point for your own Notion integration, you'll likely need to modify the code to match your specific database structure and requirements.
Features
- Add new todo items 
- View all todos 
- View today's tasks 
- Check off a task as complete 
Prerequisites
- Python 3.10 or higher 
- A Notion account 
- A Notion integration (API key) 
- A Notion database that matches the exact structure described above (or willingness to modify the code for your structure) 
Setup
- Clone the repository: 
- Set up Python environment: 
- Create a Notion integration: - Create new integration 
- Copy the API key 
 
- Share your database with the integration: - Open your todo database in Notion 
- Click "..." menu → "Add connections" 
- Select your integration 
 
- Create a - .envfile:
- Configure Claude Desktop: 
Running the Server
The server can be run in two ways:
- Directly from the command line: 
- Automatically through Claude Desktop (recommended): 
- The server will start when Claude launches if configured correctly in - claude_desktop_config.json
- No manual server management needed 
- Server stops when Claude is closed 
Note: When running directly, the server won't show any output unless there's an error - this is normal as it's waiting for MCP commands.
Usage
Basic commands through Claude:
- "Show all my todos" 
- "What's on my list for today?" 
- "Add a todo for today: check emails" 
- "Add a task for later: review project" 
Limitations
- Only works with a specific Notion database structure 
- No support for complex database schemas 
- Limited to "today" or "later" task scheduling 
- No support for additional properties or custom fields 
- Basic error handling 
- No advanced features like recurring tasks, priorities, or tags 
Customization
If you want to use this with a different database structure, you'll need to modify the server.py file, particularly:
- The - create_todo()function to match your database properties
- The todo formatting in - call_tool()to handle your data structure
- The input schema in - list_tools()if you want different options
Project Structure
License
MIT License - Use at your own risk
Acknowledgments
- Built to work with Claude Desktop 
- Uses Notion's API 
This server cannot be installed
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
A simple Model Context Protocol (MCP) server that integrates with Notion's API to manage my personal todo list through Claude.
Related MCP Servers
- AsecurityAlicenseAqualityMCP Server for the Notion API, enabling Claude to interact with Notion workspaces.Last updated -18329825MIT License
- -securityAlicense-qualityA Model Context Protocol server that integrates with Notion's API to manage personal todo lists, allowing users to view, add, and update tasks directly from Claude.Last updated -26MIT License
- AsecurityAlicenseAqualityA Model Context Protocol (MCP) server that provides tools for managing todo items, including creation, updating, completion, deletion, searching, and summarizing tasks.Last updated -31MIT License
- AsecurityFlicenseAqualityA Model Context Protocol server that enables Claude and other LLMs to interact with Notion workspaces, providing capabilities like searching, retrieving, creating and updating pages, as well as managing databases.Last updated -103053