Skip to main content

MCP server for getMe (HTTP over Unix domain socket).

Project description

getMe MCP Server

An MCP server that exposes getMe key-value operations as Model Context Protocol (MCP) tools, enabling LLMs to talk to the getMe core database over HTTP via a Unix Domain Socket (UDS).

🔗 Quick Links

Using the MCP Server

The getme-mcp-server package is published on PyPI. For integration with MCP-compatible clients like Claude Desktop, Cursor, or the MCP Inspector, you can seamlessly run it using uvx or pipx.

Claude Desktop Configuration

Add the following to your claude_desktop_config.json:

{
  "mcpServers": {
    "getme": {
      "command": "uvx",
      "args": ["getme-mcp-server"],
      "env": {
        "GETME_SOCKET_PATH": "/tmp/getMeStore/sockDir/getMe.sock",
        "GETME_KEY_PREFIX": "agent-context:",
        "GETME_READ_ONLY": "false"
      }
    }
  }
}

Features & Safety

  • Read-Only Mode: Ensure LLMs don't mutate data via GETME_READ_ONLY=true.
  • Destructive Operation Guards: The clear tool is disabled by default, ensuring agents can't accidentally drop the store.
  • Payload & Connection Limits: Defends against massive payloads/batches and re-uses HTTP connections for performance.
  • Prefix Isolation: Restrict the LLM to a specific namespace in the DB with GETME_KEY_PREFIX.
  • Masked Logging: Tool execution metadata is logged, but payloads are masked to prevent leaking secrets.

Configuration (Environment Variables)

Control safety rules and performance via environment variables.

  • GETME_SOCKET_PATH (default: /tmp/getMeStore/sockDir/getMe.sock): Path to the UNIX socket used by the core getMe daemon.
  • GETME_READ_ONLY (default: false): If true, only get and get_json tools are registered.
  • GETME_ALLOW_CLEAR (default: false): If true, enables the dangerous clear tool.
  • GETME_KEY_PREFIX (default: ""): String prefix prepended to all keys. Sandboxes the LLM (e.g., agent1:).
  • GETME_MAX_VALUE_SIZE_BYTES (default: 5242880 / 5MB): Limit on single value payload sizes.
  • GETME_MAX_BATCH_ITEMS (default: 100): Maximum keys processed in one batch_put.

Best Practices

  1. Sandbox with Prefixes: Always use GETME_KEY_PREFIX when handing the database over to an LLM. For instance, using GETME_KEY_PREFIX="claude:" ensures the model can't overwrite core application data.
  2. Restrict Privileges: If the agent only needs context (e.g., fetching RAG documents or reading app state), enforce GETME_READ_ONLY=true.
  3. Never Allow Clear: Keep GETME_ALLOW_CLEAR=false (the default) in production environments to prevent catastrophic drops caused by hallucinated commands.
  4. Volume Mounts: Make sure the environment running the MCP server has adequate read/write permissions to the GETME_SOCKET_PATH.

Tools

Once connected, the LLM has access to the following operations:

  • get(key) -> str
  • get_json(key) -> object
  • put(key, value) -> str
  • put_json(key, json_value) -> str
  • delete(key) -> str
  • clear() -> str (Requires GETME_ALLOW_CLEAR=true)
  • batch_put(pairs: object) -> object
  • batch_get(keys: list) -> object
  • batch_delete(keys: list) -> object

Development & Installation

Prereqs

  • uv installed
  • getMe core server running and listening on the Unix socket

Install from Source

cd mcp-server
uv sync

Fixing VS Code "package not installed" warnings

If Pylance shows warnings like Package "httpx" is not installed in the selected environment, VS Code is using a different Python interpreter than the uv virtualenv.

  • Open Command Palette → Python: Select Interpreter
  • Select: getMe/mcp-server/.venv/bin/python

This repo also includes a workspace setting that points the interpreter at mcp-server/.venv.

Run Locally

cd mcp-server
# optional override
export GETME_SOCKET_PATH=/tmp/getMeStore/sockDir/getMe.sock
uv run getme-mcp-server

Docker deployment

This MCP server speaks stdio (JSON-RPC), so when running in Docker you must avoid allocating a TTY.

Build the image:

cd mcp-server
docker compose build

Run it over stdio (recommended for MCP clients):

cd mcp-server
docker compose run --rm -T getme-mcp-server

The compose file bind-mounts the host UDS directory:

  • host: /tmp/getMeStore/sockDir
  • container: /tmp/getMeStore/sockDir

So the MCP server can reach the core getMe server via GETME_SOCKET_PATH=/tmp/getMeStore/sockDir/getMe.sock.

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

getme_mcp_server-1.0.3.tar.gz (68.1 kB view details)

Uploaded Source

Built Distribution

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

getme_mcp_server-1.0.3-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file getme_mcp_server-1.0.3.tar.gz.

File metadata

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

File hashes

Hashes for getme_mcp_server-1.0.3.tar.gz
Algorithm Hash digest
SHA256 9781c1e2177fb9445c9311c09aaf9ddd2c5988b531171f9089c2906befbe7297
MD5 a64b1d426e96272822d22b78b7ac8c09
BLAKE2b-256 d9172e5eeff39e8a893f3569aae51f590aefb09d52a0034907567aba24817d2c

See more details on using hashes here.

Provenance

The following attestation bundles were made for getme_mcp_server-1.0.3.tar.gz:

Publisher: mcp-server-ci.yml on AatirNadim/getMe

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

File details

Details for the file getme_mcp_server-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for getme_mcp_server-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2c0f0ac569f08f80305627109a2d26e35a002a3f279117672e8c1f64ee01f12d
MD5 c0a74893c05613fe32b047e53e8cfead
BLAKE2b-256 21d3861daf3677370520428b1f0f736ad87a750cc9a6d223ce2aa1510e763756

See more details on using hashes here.

Provenance

The following attestation bundles were made for getme_mcp_server-1.0.3-py3-none-any.whl:

Publisher: mcp-server-ci.yml on AatirNadim/getMe

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