Cover image
Try Now
2025-04-13

** Intion MCP服务器**是一个模型上下文协议(MCP)服务器实现,使AI助手可以与Intion的API进行交互。这款可生产的服务器提供了一套完整的工具。

3 years

Works with Finder

2

Github Watches

10

Github Forks

88

Github Stars

Notion MCP Server

License TypeScript Model Context Protocol smithery badge NPM Downloads Stars

Notion MCP Server is a Model Context Protocol (MCP) server implementation that enables AI assistants to interact with Notion's API. This production-ready server provides a complete set of tools and endpoints for reading, creating, and modifying Notion content through natural language interactions.

🚧 Active Development: Database support is now available! Comments and user management tools have been added. If you find this project useful, please consider giving it a star - it helps me know that this work is valuable to the community and motivates further development.

📑 Table of Contents

🚀 Getting Started & Integration

Setup Process

  1. Obtain a Notion API Key

  2. Enable Integration for Your Pages

    • Select an existing page or create a new one in Notion
    • Click the "..." menu in the top right corner
    • Go to "Connections"
    • Find and enable your integration from the list

    Notion Page Connection

  3. Choose Your Integration Method

    • Follow one of the integration options below based on your preferred MCP client
  4. Ask Your AI Assistant to Interact with Notion

    • "Create a new page with today's tasks"
    • "Update my meeting notes in Notion"
    • "Add bullet points to my meeting notes page"
    • "Create a new database for tracking projects"
    • "Add new entries to my task database"
    • "Add a comment to my project page"
    • "Show me all comments on this document"
    • "List all users in my workspace"
    • "Get information about a specific user"

Cursor Integration

Method 1: Using mcp.json

  1. Create or edit the .cursor/mcp.json file in your project directory:
{
  "mcpServers": {
    "notion-mcp-server": {
      "command": "env NOTION_TOKEN=YOUR_KEY NOTION_PAGE_ID=YOUR_PAGE_ID npx",
      "args": ["-y", "notion-mcp-server"]
    }
  }
}
  1. Replace YOUR_KEY and YOUR_PAGE_ID with your actual Notion API key and page ID
  2. Restart Cursor to apply the changes

Method 2: Manual Mode

  1. Open Cursor and go to Settings
  2. Navigate to the "MCP" or "Model Context Protocol" section
  3. Click "Add Server" or equivalent
  4. Enter the following command in the appropriate field:
env NOTION_TOKEN=YOUR_KEY NOTION_PAGE_ID=YOUR_PAGE_ID npx -y notion-mcp-server
  1. Replace YOUR_KEY and YOUR_PAGE_ID with your actual Notion API key and page ID
  2. Save the settings and restart Cursor if necessary

Claude Desktop Integration

  1. Create or edit the mcp.json file in your configuration directory:
{
  "mcpServers": {
    "notion-mcp-server": {
      "command": "npx",
      "args": ["-y", "notion-mcp-server"],
      "env": {
        "NOTION_TOKEN": "YOUR_KEY",
        "NOTION_PAGE_ID": "YOUR_PAGE_ID"
      }
    }
  }
}
  1. Replace YOUR_KEY and YOUR_PAGE_ID with your actual Notion API key and page ID
  2. Restart Claude Desktop to apply the changes

🌟 Features

  • 📝 Notion Integration - Interact with Notion databases, pages, and blocks
  • 🔌 Universal MCP Compatibility - Works with all MCP clients including Cursor, Claude Desktop, Cline, and Zed
  • 🔍 Data Retrieval - Fetch information from Notion pages, blocks, and databases
  • ✏️ Content Creation - Create and update Notion pages and blocks
  • 📊 Block Management - Append, update, and delete blocks within Notion pages
  • 💾 Database Operations - Create, query, and update databases
  • 🔄 Batch Operations - Perform multiple operations in a single request
  • 🗑️ Archive & Restore - Archive and restore Notion pages
  • 🔎 Search Functionality - Search Notion pages and databases by title
  • 💬 Comments Management - Get, create, and reply to comments on pages and discussions
  • 👥 User Management - Retrieve workspace users and user information

📚 Documentation

Available Tools

The server provides the following consolidated tools for interacting with Notion:

notion_pages

A comprehensive tool for page operations including:

  • Creating new pages with specified content
  • Updating page properties
  • Archiving pages (moving to trash)
  • Restoring previously archived pages
  • Searching for pages by title

Example operations:

{
  "payload": {
    "action": "create_page", // One of: "create_page", "archive_page", "restore_page", "search_pages", "update_page_properties"
    "params": {
      // Parameters specific to the chosen action
    }
  }
}

notion_blocks

A complete toolkit for block operations including:

  • Retrieving block content
  • Fetching child blocks
  • Appending new blocks to a parent
  • Updating existing blocks
  • Deleting blocks
  • Performing batch operations (append, update, delete, mixed)

Example operations:

{
  "payload": {
    "action": "append_block_children", // One of: "append_block_children", "retrieve_block", "retrieve_block_children", "update_block", "delete_block", "batch_append_block_children", "batch_update_blocks", "batch_delete_blocks", "batch_mixed_operations"
    "params": {
      // Parameters specific to the chosen action
    }
  }
}

notion_database

A powerful tool for database interactions including:

  • Creating new databases with custom properties
  • Querying databases with filters and sorting
  • Updating database structure and properties

Example operations:

{
  "payload": {
    "action": "create_database", // One of: "create_database", "query_database", "update_database"
    "params": {
      // Parameters specific to the chosen action
    }
  }
}

notion_comments

A tool for managing comments on Notion content:

  • Retrieving comments from pages and blocks
  • Adding new comments to pages
  • Replying to existing discussions

Example operations:

{
  "payload": {
    "action": "get_comments", // One of: "get_comments", "add_page_comment", "add_discussion_comment"
    "params": {
      // Parameters specific to the chosen action
    }
  }
}

notion_users

A tool for accessing user information:

  • Listing all workspace users
  • Getting details about specific users
  • Retrieving information about the current bot user

Example operations:

{
  "payload": {
    "action": "list_users", // One of: "list_users", "get_user", "get_bot_user"
    "params": {
      // Parameters specific to the chosen action
    }
  }
}

Available Resources

The server currently does not expose any resources, focusing instead on tool-based operations.

🛠 Development

  1. Clone the Repository

    git clone https://github.com/awkoy/notion-mcp-server.git
    cd notion-mcp-server
    
  2. Install Dependencies

    npm install
    
  3. Set Up Environment Variables

    • Create a .env file with:
      NOTION_TOKEN=your_notion_api_key
      NOTION_PAGE_ID=your_notion_page_id
      
  4. Build the Project

    npm run build
    
  5. Run the Inspector

    npm run inspector
    

🔧 Technical Details

  • Built using TypeScript and the MCP SDK (version 1.7.0+)
  • Uses the official Notion API client (@notionhq/client v2.3.0+)
  • Follows the Model Context Protocol specification
  • Implements tools for CRUD operations on Notion pages, blocks, and databases
  • Supports efficient batch operations for performance optimization
  • Validates input/output with Zod schemas

❓ Troubleshooting

  • Common Issues

    • Authentication Errors: Ensure your Notion token has the correct permissions and integration is enabled for your pages/databases
    • Page Access Issues: Make sure your integration has been added to the pages you're attempting to access
    • Rate Limiting: Notion API has rate limits - use batch operations to optimize requests
  • Getting Help

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

相关推荐

  • Joshua Armstrong
  • Confidential guide on numerology and astrology, based of GG33 Public information

  • https://suefel.com
  • Latest advice and best practices for custom GPT development.

  • Emmet Halm
  • Converts Figma frames into front-end code for various mobile frameworks.

  • Elijah Ng Shi Yi
  • Advanced software engineer GPT that excels through nailing the basics.

  • Alexandru Strujac
  • Efficient thumbnail creator for YouTube videos

  • https://maiplestudio.com
  • Find Exhibitors, Speakers and more

  • Yusuf Emre Yeşilyurt
  • I find academic articles and books for research and literature reviews.

  • Carlos Ferrin
  • Encuentra películas y series en plataformas de streaming.

  • https://zenepic.net
  • Embark on a thrilling diplomatic quest across a galaxy on the brink of war. Navigate complex politics and alien cultures to forge peace and avert catastrophe in this immersive interstellar adventure.

  • https://reddgr.com
  • Delivers concise Python code and interprets non-English comments

  • apappascs
  • 发现市场上最全面,最新的MCP服务器集合。该存储库充当集中式枢纽,提供了广泛的开源和专有MCP服务器目录,并提供功能,文档链接和贡献者。

  • ShrimpingIt
  • MCP系列GPIO Expander的基于Micropython I2C的操作,源自ADAFRUIT_MCP230XX

  • pontusab
  • 光标与风浪冲浪社区,查找规则和MCP

  • av
  • 毫不费力地使用一个命令运行LLM后端,API,前端和服务。

  • 1Panel-dev
  • 🔥1Panel提供了直观的Web接口和MCP服务器,用于在Linux服务器上管理网站,文件,容器,数据库和LLMS。

  • Mintplex-Labs
  • 带有内置抹布,AI代理,无代理构建器,MCP兼容性等的多合一桌面和Docker AI应用程序。

  • GeyserMC
  • 与Minecraft客户端/服务器通信的库。

  • awslabs
  • AWS MCP服务器 - 将AWS最佳实践直接带入您的开发工作流程的专门MCP服务器

  • WangRongsheng
  • 🧑‍🚀 llm 资料总结(数据处理、模型训练、模型部署、 o1 模型、mcp 、小语言模型、视觉语言模型)|摘要世界上最好的LLM资源。

  • appcypher
  • 很棒的MCP服务器 - 模型上下文协议服务器的策划列表

    Reviews

    3 (1)
    Avatar
    user_WqKkWeAH
    2025-04-17

    I've been using notion-mcp-server for a while and it has significantly streamlined my workflows. The integration with Notion is seamless, and it provides robust server capabilities that enhance productivity. Kudos to awkoy for developing such a reliable tool. Highly recommend it to anyone looking to optimize their Notion experience. Check it out on GitHub!