Skip to main content

A Model Context Protocol (MCP) server for PostgreSQL, acting as a super memory and task tracker for AI assistants.

Project description

Pg-Mnemosyne MCP

PyPI version License: MIT Python Version MCP Protocol Platform Support

Pg-Mnemosyne MCP Power Banner

A Model Context Protocol (MCP) server that provides AI assistants with a robust "super memory", task tracker, and dynamic PostgreSQL database management capabilities.

⚡ Quick Start

  1. Install the package globally (recommended):

    pipx install pg-mnemosyne-mcp
    

    Note: If you get an 'externally-managed-environment' error, either use pipx (recommended) or add --break-system-packages to your pip command.

  2. Auto-configure all your AI agents (Claude, Gemini, Qwen, Cursor, etc.) at once:

    pg-mnemosyne init --dsn "postgresql://user:password@localhost:5432/postgres"
    
  3. Restart your AI agents. You're done!


Features

  • High-Performance: Uses cached connection pooling (asyncpg.create_pool) for instant sub-millisecond database queries.
  • Dynamic Projects: The AI can create new databases for different projects on the fly.
  • Dynamic Schema: The AI can modify table schemas dynamically to adapt to changing memory needs.
  • Standard Memory Tracker: Built-in support for tracking, updating, and deleting memory items with tags.
  • Advanced Task Management: Dedicated tasks schema with fields for status transitions, priority, and deadlines.
  • Multi-Agent Coordination: Centralized session tracking preventing duplicate coding and file-editing conflicts.
  • Raw SQL Execution: Gives AI ultimate flexibility for complex queries and DDL operations.

Setup

Users will need to provide their PostgreSQL credentials using the PG_BASE_DSN environment variable. This is a standard connection string: postgresql://<USERNAME>:<PASSWORD>@<HOST>:<PORT>/<DEFAULT_DB>

Where to configure this (Client Setup)

The exact location depends on which AI client you are using. You need to add the server configuration to your client's MCP settings file.

For Claude Desktop:

  • Mac: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json

For Cursor:

  • Go to Settings > Features > MCP and add a new MCP server, or edit your project's .cursor/mcp.json.

For Roo Code / Cline (VS Code):

  • Edit the MCP settings file located at ~/Library/Application Support/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json (Mac) or the equivalent Windows path.

For Gemini CLI & Qwen CLI:

  • Open your global configuration file (usually located at ~/.gemini/settings.json or ~/.qwen/settings.json).
  • Alternatively, use the CLI:
    gemini mcp add pg-mnemosyne "/path/to/pg-mnemosyne" -e PG_BASE_DSN="postgresql://user:pass@localhost:5432/postgres" -s user
    # OR
    qwen mcp add pg-mnemosyne "/path/to/pg-mnemosyne" -e PG_BASE_DSN="postgresql://user:pass@localhost:5432/postgres" -s user
    

For Claude Code CLI:

  • The easiest way is to add it via the CLI:
    claude mcp add pg-mnemosyne "/path/to/pg-mnemosyne" -e PG_BASE_DSN="postgresql://user:pass@localhost:5432/postgres" -s user
    
  • Manually, it lives in your global config at ~/.claude.json.

For Codex CLI:

  • The easiest way is to add it via the CLI:
    codex mcp add pg-mnemosyne --env PG_BASE_DSN="postgresql://user:pass@localhost:5432/postgres" -- pg-mnemosyne
    
  • Manually, it lives in your global config at ~/.codex/config.toml (TOML format).

For Windsurf IDE:

  • Edit your global config at ~/.codeium/windsurf/mcp_config.json.
  • Alternatively, click the Hammer (MCP) icon in the Cascade panel and select Configure.

For Antigravity CLI (agy): Antigravity uses a plugin-based system. To add the server:

  1. Create a plugin directory: mkdir -p ~/.gemini/config/plugins/pg-mnemosyne
  2. Create ~/.gemini/config/plugins/pg-mnemosyne/mcp_config.json with the Standard Template below.
  3. Add an entry to your ~/.gemini/config/import_manifest.json under the "imports" array:
    {
      "name": "pg-mnemosyne",
      "source": "manual",
      "components": ["mcpServers"]
    }
    

Configuration Template (Claude Desktop, Cursor, Roo Code, Gemini CLI, Claude Code, Antigravity, Windsurf):

{
  "mcpServers": {
    "pg-mnemosyne": {
      "command": "pg-mnemosyne",
      "env": {
        "PG_BASE_DSN": "postgresql://postgres:my_password@localhost:5432/postgres"
      }
    }
  }
}

For OpenCode:

  • Edit your OpenCode configuration file located at ~/.config/opencode/opencode.jsonc.

Configuration Template (OpenCode):

{
  "mcp": {
    "pg-mnemosyne": {
      "type": "local",
      "command": ["pg-mnemosyne"],
      "environment": {
        "PG_BASE_DSN": "postgresql://postgres:my_password@localhost:5432/postgres"
      }
    }
  }
}

Running the Server (Standalone)

pg-mnemosyne run

This starts the MCP server using standard input/output.

CLI Usage

The pg-mnemosyne command also acts as a standalone CLI for managing your data and configuring agents.

Auto-Initialization

You can automatically configure all supported AI agents (Claude, Gemini, Qwen, Cursor, etc.) with a single command:

pg-mnemosyne init --dsn "postgresql://user:pass@localhost:5432/postgres"

Manual Record Management

You can add and list records directly from your terminal:

# Add a record
pg-mnemosyne add my_project_db todo "Finish the documentation"

# List records
pg-mnemosyne list my_project_db --type todo

🤝 Multi-Agent Coordination & Advanced Tasks

Pg-Mnemosyne includes specialized schemas to help complex multi-agent setups (e.g. Gemini CLI, Codex CLI, Roo Code, Claude Desktop) coordinate on the same project:

📋 Professional Tasks Schema

Spin up a dedicated tasks table with fields for statuses (backlog, todo, in_progress, blocked, done), priority levels (low, medium, high, critical), tags, and deadlines:

pg-mnemosyne init-todo my_project_db

🛰️ Agent Coordination Hub

Avoid merge conflicts, double-coding, and redundant compiler troubleshooting by initializing the shared agent_sessions coordination table:

pg-mnemosyne init-coordination my_project_db

When active, agents use the update_agent_session and get_active_sessions MCP tools to register their current editing files and active subtasks, creating a real-time bulletin board for mutual visibility!

Available MCP Tools

  • create_project_db(db_name: str): Creates a new isolated PostgreSQL database.
  • init_schema(db_name: str): Initializes the base records table.
  • init_todo_schema(db_name: str): Initializes a professional tasks table.
  • init_coordination_schema(db_name: str): Initializes the multi-agent agent_sessions table.
  • add_column(db_name: str, table: str, column_name: str, data_type: str): Dynamically adds a column to any table.
  • add_record(db_name: str, type: str, content: str, tags: list[str]): Adds a memory/todo record.
  • get_records(db_name: str, type: str = None, limit: int = 50): Retrieves recent records.
  • update_record(db_name: str, record_id: int, content: str = None, tags: list[str] = None, status: str = None): Partially updates a record.
  • delete_record(db_name: str, record_id: int): Deletes a record by ID.
  • update_agent_session(db_name: str, agent_name: str, active_task: str, active_file: str = None, status: str = "active"): Registers/updates active agent state.
  • get_active_sessions(db_name: str): Lists active agent coordination sessions.
  • run_sql(db_name: str, query: str): Runs arbitrary SQL (SELECT, INSERT, DDL, etc.).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pg_mnemosyne_mcp-0.1.2.tar.gz (886.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pg_mnemosyne_mcp-0.1.2-py3-none-any.whl (12.1 kB view details)

Uploaded Python 3

File details

Details for the file pg_mnemosyne_mcp-0.1.2.tar.gz.

File metadata

  • Download URL: pg_mnemosyne_mcp-0.1.2.tar.gz
  • Upload date:
  • Size: 886.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pg_mnemosyne_mcp-0.1.2.tar.gz
Algorithm Hash digest
SHA256 c4c4ed09d902af6842042be4e152fe85c804606286c05521f338c6c32c4fdb4c
MD5 fa8416b7afba8ecdddfdeee87f7335bc
BLAKE2b-256 a73ed438c4f82061bcae0e8d73dda489eb49d48e52cd39b24680e1c2051f00c2

See more details on using hashes here.

Provenance

The following attestation bundles were made for pg_mnemosyne_mcp-0.1.2.tar.gz:

Publisher: publish.yml on Janadasroor/pg-mnemosyne-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pg_mnemosyne_mcp-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pg_mnemosyne_mcp-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6e433ed7ec915d762d02b9e1fe03ee71a1e0c791fe1df7d520c755580fa1acb6
MD5 bf09053c28dc2f3e4099d621f78ff297
BLAKE2b-256 3bbe7715d94c3c4d40004095cb8e199f886f60b0094b82ead895d65f6cef1d3f

See more details on using hashes here.

Provenance

The following attestation bundles were made for pg_mnemosyne_mcp-0.1.2-py3-none-any.whl:

Publisher: publish.yml on Janadasroor/pg-mnemosyne-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page