Skip to main content

MCP server that lets AI agents run read/write queries against PostgreSQL, MySQL, MongoDB and Oracle through alias-based connections, without exposing credentials.

Project description

Custom MCP Database

An MCP server that lets AI agents run alias-based queries against PostgreSQL, MySQL, MongoDB and Oracle — without ever exposing credentials to the model. Connections are configured once and stored locally; the agent only ever references them by alias.

Works with Claude Code, Claude Desktop, Cursor, VS Code, Windsurf, Gemini CLI, and any other MCP client (all use the same stdio launch command).


Install

The server runs over stdio. The universal launch command is uvx custom-mcp-database run (requires uv; the package is fetched from PyPI on first run).

Claude Code

# Direct (published package)
claude mcp add custom-mcp-database -- uvx custom-mcp-database run

# Or install the full plugin from this repo's marketplace
/plugin marketplace add renanlido/custom-mcp-database
/plugin install custom-mcp-database@renanlido-mcp

Claude Desktop

Two options:

  1. One-click bundle — build the .mcpb (mcpb pack) and open it in Claude Desktop. See Distribution.
  2. Manual config — add the snippet from examples/mcp-clients/claude-desktop.json to claude_desktop_config.json.

Other clients

Copy the matching snippet — all use the same command/args, only the file and key differ:

Client Config file Key Snippet
Cursor ~/.cursor/mcp.json mcpServers cursor.json
VS Code .vscode/mcp.json servers vscode.json
Windsurf ~/.codeium/windsurf/mcp_config.json mcpServers windsurf.json
Gemini CLI ~/.gemini/settings.json mcpServers gemini-cli.json

Full client matrix and a local-checkout variant: examples/mcp-clients/README.md.


Configure connections

The server starts empty. Add connections via the CLI (or the db_add_database tool). Credentials are written to local SQLite and never re-sent to the model.

# PostgreSQL
uvx custom-mcp-database add-db --alias pg --type postgres \
  --host localhost --port 5432 --user me --password secret --dbname app

# MySQL
uvx custom-mcp-database add-db --alias my --type mysql \
  --host localhost --port 3306 --user root --password secret --dbname app

# Oracle
uvx custom-mcp-database add-db --alias ora --type oracle \
  --host db.example.com --port 1521 --user system --password pw --dbname ORCLPDB1

# MongoDB
uvx custom-mcp-database add-db --alias mongo --type mongo \
  --uri "mongodb+srv://user:pw@cluster.mongodb.net/" --dbname app

uvx custom-mcp-database list-aliases
uvx custom-mcp-database remove-db --alias pg

Config location (override with MCP_DB_CONFIG): $XDG_CONFIG_HOME/custom-mcp-database/mcp_config.sqlite3 (default ~/.config/custom-mcp-database/mcp_config.sqlite3).

Credentials are stored as plaintext JSON in that SQLite file. Keep it secret; it is not committed and not encrypted.


MCP tools

Tool Purpose
db_list_aliases List configured aliases and types
db_add_database Add/replace a connection
db_remove_database Remove a connection
db_execute_query Run SQL or a MongoDB JSON filter
db_list_collections List MongoDB collections

db_execute_query notes: SQL runs as given with parameterized binds (add your own LIMIT); MongoDB takes a JSON filter + collection, caps results at 10 (--limit), rejects empty filters, and coerces 24-char hex strings to ObjectId.


Develop

uv sync                 # create .venv and install deps
make run                # run the server (stdio)
make lint               # ruff
make build              # sdist + wheel into dist/

Inspect tools interactively:

uv run mcp dev src/custom_mcp_database/server.py

Distribution

This repo ships ready-to-publish metadata for every major channel. All of it is published automatically on push to main (see below):

Channel File Published by
PyPI pyproject.toml release.yml (push to main)
MCP Registry server.json release.yml (push to main)
Claude Code plugin .claude-plugin/plugin.json, .mcp.json available on GitHub push
Claude Code marketplace .claude-plugin/marketplace.json available on GitHub push
Claude Desktop bundle manifest.json release.yml attaches .mcpb to the Release

Automated release — just push to main

Releases are fully automated. On every push to main, .github/workflows/release.yml:

  1. Picks the next semantic version from your commits since the last tag (feat: → minor, BREAKING CHANGE/type!: → major, anything else → patch; add [skip release] to a commit message to skip).
  2. Writes that version into pyproject.toml and syncs it into every artifact (server.json, manifest.json, plugin + marketplace) via scripts/sync_version.py — version lives in one place, no hand-bumping.
  3. Builds, commits chore(release): vX [skip ci], tags vX, pushes.
  4. Publishes to PyPI (Trusted Publishing/OIDC), then the MCP Registry (GitHub OIDC).
  5. Packs the .mcpb and cuts a GitHub Release with the wheel + bundle attached.

The release commit carries [skip ci], so it does not re-trigger the workflow.

One-time setup (can't be automated — needs your accounts):

  • Create a PyPI Trusted Publisher for renanlido/custom-mcp-database, workflow release.yml.
  • Allow GitHub Actions to push to main (repo → Settings → Actions → Read and write permissions; if main is a protected branch, allow the actions bot to bypass or use a PAT).

The MCP Registry namespace is io.github.renanlido/custom-mcp-database (GitHub-validated).

Local manual escape hatch: make build (syncs version + builds) then uv publish.


License

MIT

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

custom_mcp_database-0.3.1.tar.gz (17.7 kB view details)

Uploaded Source

Built Distribution

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

custom_mcp_database-0.3.1-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file custom_mcp_database-0.3.1.tar.gz.

File metadata

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

File hashes

Hashes for custom_mcp_database-0.3.1.tar.gz
Algorithm Hash digest
SHA256 2839a74626fa898be53832f9001649a09af1d16bbe87dcfbbb4607eb81936ce9
MD5 8e2995e10653bda74902458b394a9f6f
BLAKE2b-256 f5ea5908c8fbe0de5f8957db47a6853dff3637b89cd5822c7b5ccee8e4b9b781

See more details on using hashes here.

Provenance

The following attestation bundles were made for custom_mcp_database-0.3.1.tar.gz:

Publisher: release.yml on renanlido/custom-mcp-database

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

File details

Details for the file custom_mcp_database-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for custom_mcp_database-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2f6db7f47c0f2de879cdc01b5adc806d9e3407e96a755949a36a648a859adcb9
MD5 6f08464147198dd716f11f040f5dde3e
BLAKE2b-256 3dbc5967934f9753d9734fde7ca488381fe71be6a4fdd7dff86394fd3ff42f11

See more details on using hashes here.

Provenance

The following attestation bundles were made for custom_mcp_database-0.3.1-py3-none-any.whl:

Publisher: release.yml on renanlido/custom-mcp-database

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