Skip to main content
Glama
AyanoT1

tiny-notion-mcp

by AyanoT1

tiny-notion-mcp

A lightweight Notion MCP server that minimises token usage compared to the official Notion MCP.

Instead of returning raw Notion API JSON, every tool returns the smallest useful representation: pages come back as plain Markdown, search results as a single line per hit. In practice this cuts token consumption significantly on read-heavy workflows.

Tools

Tool

Description

notion_search

Search pages by title. Returns one line per result in TOON format.

notion_read

Read a page as Markdown.

notion_write

Append Markdown to an existing page.

notion_create_page

Create a sub-page under a parent, optionally with content.

TOON format

Search results and page creation responses use the compact TOON (Title | Object | Optional Notes) format:

Page title | page-id | https://notion.so/... | parent:<parent-id>

This keeps search responses to a single line per result instead of hundreds of tokens of JSON.

Supported block types

Read (notion_read)

Block type

Markdown output

Paragraph

Plain text

Heading 1 / 2 / 3

# / ## / ###

Bulleted list item

- item

Numbered list item

1. item, 2. item, …

Code block

```lang … ```

Table

Pipe-delimited rows

Child page

[Subpage: title](id)

Inline formatting (bold, italic, bold-italic, strikethrough, underline, inline code, links) is preserved as Markdown.

Write (notion_write)

The same block types are supported on write. Markdown is parsed and appended to the target page as native Notion blocks.

Not yet implemented (v2)

The following block types are recognised by Notion but not yet handled. They are silently skipped on read and cannot be written:

  • Dividers (---)

  • Block quotes

  • To-do / checkbox lists

  • Callout blocks

  • Toggle lists

  • Table of contents

  • Files, images, and videos

Known limitations

  • Empty paragraph blocks between different list types are not round-tripped. When a page has an explicit empty paragraph separating, say, a bulleted list from a numbered list, that separator is lost on a read → write cycle. The "\n\n" that Markdown already places between blocks is visually equivalent but does not produce a Notion empty-paragraph block on write. This is an inherent limitation of a flat Markdown representation and will stay until a v2 format is designed.

  • Table header flag is not round-tripped. Notion tables can be created without a column-header row (has_column_header: false). The current writer always sets has_column_header: true because standard Markdown tables imply a header. Tables written back will look identical but have the header flag set.

Requirements

  • Python 3.12+

  • A Notion integration token with read/write access to the pages you want to use

Installation

# From source
git clone https://github.com/your-username/tiny-notion-mcp
cd tiny-notion-mcp
pip install .

Or install directly with uv:

uv tool install .

Configuration

Set your Notion integration token as an environment variable:

export NOTION_TOKEN=secret_...

NOTION_API_KEY is accepted as an alias.

Claude Desktop / Claude Code

Add the server to your MCP configuration:

{
  "mcpServers": {
    "tiny-notion-mcp": {
      "command": "tiny-notion-mcp",
      "env": {
        "NOTION_TOKEN": "secret_..."
      }
    }
  }
}

If you installed with uv into an isolated environment, use the full path:

{
  "mcpServers": {
    "tiny-notion-mcp": {
      "command": "uv",
      "args": ["run", "--", "tiny-notion-mcp"],
      "env": {
        "NOTION_TOKEN": "secret_..."
      }
    }
  }
}

Development

# Install with dev dependencies
pip install -e ".[dev]"

# Run tests
pytest

Tests use a stub NotionClient and make no real API calls.

Design goals

  • Token efficiency first. Every response is as small as it can be while still being actionable.

  • No intermediate files. All content is returned inline as strings — no temp files, no file-path references.

  • Testable without a Notion account. The NotionClient interface is injected so the core logic can be tested in isolation.

F
license - not found
-
quality - not tested
B
maintenance

Maintenance

Maintainers
Response time
0dRelease cycle
2Releases (12mo)

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/AyanoT1/tiny-notion-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server