Metadata-Version: 2.4
Name: engram-notion-mcp
Version: 1.1.0
Summary: The permanent and semantic memory layer for AI agents
Project-URL: Repository, https://github.com/shubhamomar/engram-notion-mcp
Author-email: Shubham Omar <shubhamomar53@gmail.com>
License: MIT
Requires-Python: >=3.10
Requires-Dist: fastmcp
Requires-Dist: mcp
Requires-Dist: notion-client
Requires-Dist: python-dotenv
Description-Content-Type: text/markdown

# Engram Notion MCP - Semantic Memory for AI Agents

**Engram Notion MCP** is a powerful Model Context Protocol (MCP) server that gives your AI agents a **permanent, semantic memory**. It seamlessly integrates with [Notion](https://notion.so) to store, retrieve, and organize information, turning your workspace into an intelligent knowledge base.

> 🧠 **Why Engram?**
> AI Agents often suffer from amnesia. Engram solves this by providing a persistent memory layer backed by Notion's robust database structure.

---

## 📦 Features

### Notion Integration
| Feature | Tool Name | Description |
| :--- | :--- | :--- |
| **Page Creation** | `create_page` | Create new pages with content. Auto-chunks large text to avoid limits. |
| **Page Updates** | `update_page` | Append content to existing pages. Auto-chunks large text. |
| **Logging** | `log_to_notion` | Fast logging wrapper for appending notes/logs. |
| **Reading** | `read_page_content` | Read and parse page content into Agent-friendly text. |
| **Databases** | `list_databases` | detailed list of accessible databases. |
| **Querying** | `query_database` | Query databases with filters to find specific items. |
| **Organization** | `list_sub_pages` | List pages within a parent page. |
| **Cleanup** | `delete_block` | Archive/Delete blocks or pages. |

### Semantic Memory (SQLite)
| Feature | Tool Name | Description |
| :--- | :--- | :--- |
| **Store Facts** | `remember_fact` | Saves key info to internal vector-like storage. |
| **Search** | `search_memory` | Full-text search over stored memories. |
| **Recall** | `get_recent_memories`| Retrieve the latest context/facts. |

### Operations
| Feature | Tool Name | Description |
| :--- | :--- | :--- |
| **Alerts** | `send_alert` | Send push notifications via Telegram. |

---

## 🛠 Configuration

To use Engram Notion MCP, you need to set up your environment variables.

| Variable | Required | Description |
| :--- | :--- | :--- |
| `NOTION_API_KEY` | **Yes** | Your Notion Internal Integration Token (`secret_...`). |
| `NOTION_PAGE_ID` | No | Default Page ID for creating pages if no parent is specified. |
| `TELEGRAM_BOT_TOKEN`| No | For `send_alert` tool. |
| `TELEGRAM_CHAT_ID` | No | For `send_alert` tool. |
| `AGENT_MEMORY_PATH` | No | Custom path for the SQLite memory database. |

---

> ### 💡 Quick Setup Tips
> <details>
> <summary>
> <strong>🔑 How to get Notion API Key</strong>
> </summary>
>
> 1.  Go to [Notion My Integrations](https://www.notion.so/my-integrations).
> 2.  Click **New integration**.
> 3.  Name it (e.g., "Engram Notion MCP") and submit.
> 4.  Copy the **Internal Integration Secret**. this is your `NOTION_API_KEY`.
> </details>
>
> <details>
> <summary>
> <strong>🤖 How to get Telegram Bot Token & Chat ID</strong>
> </summary>
>
> 1.  **Bot Token**:
>     - Open Telegram and search for **@BotFather**.
>     - Send the command `/newbot`.
>     - Follow the prompts to name your bot.
>     - Copy the **HTTP API Token**.
>
> 2.  **Chat ID**:
>     - Search for **@userinfobot** in Telegram.
>     - Click Start or send `/start`.
>     - It will reply with your **Id**. Copy this number.
> </details>
>

---

### Configuration Patterns

#### 1. Minimal Setup (Flexible / Unbound)
You can omit `NOTION_PAGE_ID` to keep the agent "unbound". It will force the agent to ask for a destination or search for one.

```json
"env": {
  "NOTION_API_KEY": "secret_your_key_here"
}
```

#### 2. Multi-Page Support
You don't need to configure an array of IDs. **Engram relies on Notion's native permissions.**
To give the agent access to multiple specific pages:
1.  Open any page in Notion.
2.  Click the **... (three dots)** menu (top-right) -> **Connections**.
3.  Look for the name you gave your integration (e.g., "Engram Notion MCP").
4.  Once connected, the agent can automatically see this page using the `list_accessible_pages` tool.
5.  **Repeat this** for any other page you want the agent to see.

---

## 🔌 Installation & Client Setup Instructions

<details open>
<summary>
<h3 style="display: inline-block;"> ⚡ Recommended (Fastest) - Bun</h3>
</summary>

Use `bunx` to run the server with native performance (`bun:sqlite`).

Add this to your `claude_desktop_config.json` or `mcp.json`.

**Config using `bunx` (Recommended):**
```json
{
  "mcpServers": {
    "engram-notion-mcp": {
      "command": "bunx",
      "args": ["engram-notion-mcp"],
      "env": {
        "NOTION_API_KEY": "secret_your_key_here"
      }
    }
  }
}
```
</details>

---

<details>
<summary>
<h3 style="display: inline-block;"> 🐢 Standard - Node.js (NPX)</h3>
</summary>

Works with any standard Node.js environment (`better-sqlite3`).

Add this to your `claude_desktop_config.json` or `mcp.json`.

**Config using `npx` (Standard):**
```json
{
  "mcpServers": {
    "engram-notion-mcp": {
      "command": "npx",
      "args": ["-y", "engram-notion-mcp"],
      "env": {
        "NOTION_API_KEY": "secret_your_key_here"
      }
    }
  }
}
```
</details>

---

<details>
<summary>
<h3 style="display: inline-block;"> 🐍 Alternative - Python (UVX / PIPX)</h3>
</summary>

If you prefer `uvx` or `pipx` or have strict Python environments:

Add this to your `claude_desktop_config.json` or `mcp.json`.

**Config using `uvx` (Alternative):**
```json
{
  "mcpServers": {
    "engram-notion-mcp": {
      "command": "uvx",
      "args": ["engram-notion-mcp"],
      "env": {
        "NOTION_API_KEY": "secret_your_key_here"
      }
    }
  }
}
```

---

**Config using `pipx` (Alternative):**

```json
{
  "mcpServers": {
    "engram-notion-mcp": {
      "command": "pipx",
      "args": ["run", "engram-notion-mcp"],
      "env": { ... }
    }
  }
}
```
</details>

---

**Where to put it:**
- **🖥️ Desktop Apps (Claude Desktop): `claude_desktop_config.json`**
- **🆚 VS Code / Cursor / Windsurf**: User Settings (`settings.json`).
- **Cline / Roo Code**: Extension Settings -> MCP Servers.
- **Kilo Code**: `.kilo/config.json`.
- **⌨️ Gemini CLI:**
    <details>
    <summary>
    <strong>Bun (Recommended)</strong>
    </summary>

    ```bash
    gemini mcp add engram-notion-mcp bunx "engram-notion-mcp" -e NOTION_API_KEY=<your_secret_key>
    ```
    </details>

    <details>
    <summary>
    <strong>Node.js - NPX (Standard)</strong>
    </summary>

    ```bash
    gemini mcp add engram node "npx engram-notion-mcp" -e NOTION_API_KEY=<your_secret_key>
    ```
    </details>

---

## 💬 Support & Feedback
If you face any issues or have suggestions, please feel free to:
- Open an issue on this [GitHub Repository](https://github.com/shubhamomar/engram-notion-mcp/issues).
- Reach out to me directly via my GitHub profile.

---

## Quick Links

This MCP tool is published as a package on NPM and PyPI.

- [Bun / Node.js Package on NPM](https://www.npmjs.com/package/engram-notion-mcp)
- [Python Package on PyPI](https://pypi.org/project/engram-notion-mcp/)
