Skip to content

mcpslim/notion-slim

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

notion-slim

Notion MCP server optimized for AI assistants — Reduce context window tokens by 73.0% while keeping full functionality. Compatible with Claude, ChatGPT, Gemini, Cursor, and all MCP clients.

npm version Test Status MCP Compatible

What is notion-slim?

A token-optimized version of the Notion Model Context Protocol (MCP) server.

The Problem

MCP tool schemas consume significant context window tokens. When AI assistants like Claude or ChatGPT load MCP tools, each tool definition takes up valuable context space.

The original @notionhq/notion-mcp-server loads 21 tools consuming approximately ~26,073 tokens — that's space you could use for actual conversation.

The Solution

notion-slim intelligently groups 21 tools into 10 semantic operations, reducing token usage by 73.0% — with zero functionality loss.

Your AI assistant sees fewer, smarter tools. Every original capability remains available.

Performance

Metric Original Slim Reduction
Tools 21 10 -52%
Schema Tokens 14,103 1,352 90.4%
Claude Code (est.) ~26,073 ~7,052 ~73.0%

Benchmark Info

  • Original: @notionhq/notion-mcp-server@2.0.0
  • Schema tokens measured with tiktoken (cl100k_base)
  • Claude Code estimate includes ~570 tokens/tool overhead

Quick Start

One-Command Setup (Recommended)

# Claude Desktop - auto-configure
npx notion-slim --setup claude

# Cursor - auto-configure
npx notion-slim --setup cursor

# Interactive mode (choose your client)
npx notion-slim --setup

Done! Restart your app to use notion.

⚠️ This MCP requires environment variables. The setup will add placeholders - update them with your actual values. See Configuration.

CLI Tools (already have CLI?)

# Claude Code (creates .mcp.json in project root)
claude mcp add notion -s project --env NOTION_API_KEY=<YOUR_KEY> -- npx -y notion-slim@latest

# Windows: use cmd /c wrapper
claude mcp add notion -s project --env NOTION_API_KEY=<YOUR_KEY> -- cmd /c npx -y notion-slim@latest

# VS Code (Copilot, Cline, Roo Code)
code --add-mcp '{"name":"notion","command":"npx","args":["-y","notion-slim@latest"],"env":{"NOTION_API_KEY":"<YOUR_KEY>"}}'

Configuration

Required Environment Variables

Variable Description Required
NOTION_API_KEY Notion Integration Token (from notion.so/my-integrations) Yes

Manual Setup

Click to expand manual configuration options

Claude Desktop

Add to your claude_desktop_config.json:

OS Path
Windows %APPDATA%\Claude\claude_desktop_config.json
macOS ~/Library/Application Support/Claude/claude_desktop_config.json
{
  "mcpServers": {
    "notion": {
      "command": "npx",
      "args": ["-y", "notion-slim@latest"],
      "env": {
        "NOTION_API_KEY": "<YOUR_KEY>"
      }
    }
  }
}

Cursor

Add to .cursor/mcp.json (global) or <project>/.cursor/mcp.json (project):

{
  "mcpServers": {
    "notion": {
      "command": "npx",
      "args": ["-y", "notion-slim@latest"],
      "env": {
        "NOTION_API_KEY": "<YOUR_KEY>"
      }
    }
  }
}

How It Works

MCPSlim acts as a transparent bridge between AI models and the original MCP server:

┌─────────────────────────────────────────────────────────────────┐
│  Without MCPSlim                                                │
│                                                                 │
│  [AI Model] ──── reads 21 tool schemas ────→ [Original MCP]    │
│             (~26,073 tokens loaded into context)                 │
├─────────────────────────────────────────────────────────────────┤
│  With MCPSlim                                                   │
│                                                                 │
│  [AI Model] ───→ [MCPSlim Bridge] ───→ [Original MCP]           │
│       │                │                      │                 │
│   Sees 10 grouped      Translates to        Executes actual   │
│   tools only         original call       tool & returns    │
│   (~7,052 tokens)                                              │
└─────────────────────────────────────────────────────────────────┘

How Translation Works

  1. AI reads slim schema — Only 10 grouped tools instead of 21
  2. AI calls grouped tool — e.g., interaction({ action: "click", ... })
  3. MCPSlim translates — Converts to original: browser_click({ ... })
  4. Original MCP executes — Real server processes the request
  5. Response returned — Result passes back unchanged

Zero functionality loss. 73.0% token savings.

Available Tool Groups

Group Actions
get 4
post 2
patch 2
retrieve 5
update 2
create 2

Plus 4 passthrough tools — tools that don't group well are kept as-is with optimized descriptions.

Compatibility

  • Full functionality — All original @notionhq/notion-mcp-server features preserved
  • All AI assistants — Works with Claude, ChatGPT, Gemini, Copilot, and any MCP client
  • Drop-in replacement — Same capabilities, just use grouped action names
  • Tested — Schema compatibility verified via automated tests

FAQ

Does this reduce functionality?

No. Every original tool is accessible. Tools are grouped semantically (e.g., click, hover, draginteraction), but all actions remain available via the action parameter.

Why do AI assistants need token optimization?

AI models have limited context windows. MCP tool schemas consume tokens that could be used for conversation, code, or documents. Reducing tool schema size means more room for actual work.

Is this officially supported?

MCPSlim is a community project. It wraps official MCP servers transparently — the original server does all the real work.

License

MIT


Powered by MCPSlim — MCP Token Optimizer
Reduce AI context usage. Keep full functionality.

About

notion MCP (52% less tokens). Quick setup: npx notion-slim --setup

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors