Provides a standardized interface for interacting with Notion's API, allowing users to list and query databases, create and update pages, and search across a Notion workspace.
Notion MCP Server
A Model Context Protocol (MCP) server implementation for Notion integration, providing a standardized interface for interacting with Notion's API. Compatible with Claude Desktop and other MCP clients.
Features
List and query Notion databases
Create and update pages
Search across Notion workspace
Get database details and block children
Full async/await support with httpx
Type-safe with Pydantic v2 models
Proper error handling with detailed logging
Compatibility with MCP 1.6.0
Related MCP server: Notion MCP Server
Installation
Clone the repository:
Create a virtual environment and install dependencies (using uv):
Alternatively, using standard venv:
Create a
.envfile in the project root:
Usage
Test the server (it should run without errors):
To use it with Claude Desktop, adjust your
claude_desktop_config.jsonfile (located at~/Library/Application Support/Claude/claude_desktop_config.jsonon macOS):
Be sure to replace /Users/username/ with your actual home directory path.
Development
Project Structure
Running Tests
Configuration
The server requires a Notion integration token. To set this up:
Go to https://www.notion.so/my-integrations
Create a new integration with appropriate capabilities (read/write as needed)
Copy the integration token
Add it to your
.envfile in the project root directory:
Share your Notion databases with the integration (from the database's "Share" menu)
Contributing
Fork the repository
Create your feature branch (
git checkout -b feature/amazing-feature)Commit your changes (
git commit -m 'Add some amazing feature')Push to the branch (
git push origin feature/amazing-feature)Open a Pull Request
License
MIT License - Use at your own risk
Troubleshooting
Common Issues
Connection Errors: Make sure your Notion API key is correct and you have internet access
Permission Errors: Ensure your integration has been given access to the databases you're trying to access
Claude Desktop Integration: If Claude Desktop isn't connecting, check that your config path is correct and that the server is running without logging to stdout
Acknowledgments
Built to work with Claude Desktop and other MCP clients
Uses Notion's API (latest compatible version 2022-02-22)
MCP 1.6.0 compatibility maintained
Special thanks to danhilse, I referenced his notion-mcp-server project