@shck-dev/notion-mcp
v0.1.7
Published
MCP server for Notion using internal API — search, export, and import pages as markdown. No workspace admin or OAuth needed, just your browser cookie.
Maintainers
Readme
@shck-dev/notion-mcp
Notion MCP Server — search, export, and import pages as markdown
No workspace admin. No OAuth. No page sharing.
Just paste 3 values from your browser and go.
Features
- Search — full-text search across your entire workspace
- Export — download any page as clean markdown (headings, lists, code blocks, tables, links)
- Import — write markdown back to Notion pages, from a string or local file
- Zero setup friction — uses the same internal API as the Notion web app; if you can see it in your browser, this server can access it
Tools
| Tool | Description |
|------|-------------|
| notion_search | Full-text search across all pages in your workspace |
| notion_export_page | Export any Notion page as markdown |
| notion_import_page | Write markdown content to a Notion page |
| notion_import_page_from_file | Write a local .md file to a Notion page |
Why not the official Notion API?
| | This MCP server | Official Notion API |
|---|----------|-------------------|
| Setup | Paste 3 values from DevTools | Create integration, get admin approval, share pages |
| Page access | Everything you can see | Only explicitly shared pages |
| Markdown | Bidirectional (export + import) | Read-only blocks API |
| Auth | Cookie (token_v2) | OAuth / integration token |
Trade-off: The internal API is undocumented and may change. Token expires periodically (re-grab from browser).
Quick start
1. Get credentials from your browser
- Open notion.so in Chrome
- Press F12 → Application → Cookies →
www.notion.so - Copy the
token_v2cookie value →NOTION_TOKEN - Press F12 → Network tab, do any action in Notion
- Find a POST request to
api/v3/*, click it - From Request Headers: copy
x-notion-active-user-header→NOTION_USER_ID - From Request Body (Payload): find
spaceId→NOTION_SPACE_ID
2. Configure your MCP client
Claude Code
claude mcp add notion -- env NOTION_TOKEN=your_token NOTION_USER_ID=your_user_id NOTION_SPACE_ID=your_space_id bunx @shck-dev/notion-mcpClaude Desktop / Cursor / any MCP client
Add to your MCP config (claude_desktop_config.json, .cursor/mcp.json, etc.):
{
"mcpServers": {
"notion": {
"command": "bunx",
"args": ["@shck-dev/notion-mcp"],
"env": {
"NOTION_TOKEN": "your_token_v2_value",
"NOTION_USER_ID": "your_user_id",
"NOTION_SPACE_ID": "your_space_id"
}
}
}
}Requirements
- Bun runtime —
curl -fsSL https://bun.sh/install | bash
Limitations
- Internal API — undocumented, may break with Notion updates
- Token expiry —
token_v2expires periodically; re-grab from browser when auth fails - Pages only — no database queries (search, export, import work on pages)
- Replace-only import — import replaces all page content (no append/merge)
- Lossy markdown — some complex formatting may simplify during conversion
License
MIT
