Skip to main content

A Model-Context Protocol server for Amazon Redshift.

Project description

redshift-comment-mcp

English · 日本語 · 繁體中文

A read-only Model Context Protocol server for Amazon Redshift, plus a Claude Code plugin with 7 slash-command skills built on top. Designed around one assertion: column names lie, comments don't — so the server exposes comments aggressively and the skills compose those tools into the discovery workflows you actually do every day.

"What values does dbt_marts.fct_orders.status really hold?"
   → /redshift-profile dbt_marts.fct_orders status
   → cardinality, top-N, null rate, min/max, existing comment — one round.

Why this exists

If you've ever opened an unfamiliar Redshift table and squinted at column names like f3, legacy_id_v2, or status (which status?), you already know the pain. dbt manifests are too narrow. Web GUIs are too slow. Hand-written SQL is too repetitive.

This plugin's charter is Guided Data Discovery:

  • Comments first. Every list / search tool returns the column, table, or schema comment when asked — names are advisory, comments are authoritative.
  • Read-only by construction. execute_sql rejects DDL / DML at the parse layer; no skill in this repo can mutate Redshift.
  • MCP-composed skills. New workflows are built by stringing together existing tools, not by adding new database connections.
  • No persistence. No synthesis layer, no .redshift-wiki/ markdown, no stale tracking. (Cache is rebuildable; that's different.) Persistence belongs in a separate plugin.

See implementation_guide.md §1.2 for the full charter.

What you get

MCP tools (11, defined in src/redshift_comment_mcp/)

Group Tools
List list_schemas · list_tables · list_columns
Search (hit-count ranked) search_schemas · search_tables · search_columns
Comment retrieval get_schema_comment · get_table_comment · get_column_comment · get_all_column_comments
Query execute_sql (SELECT / WITH only)

Pagination on every list / search; explicit WARNING strings nudging the LLM to read comments before trusting names.

Slash-command skills (7, defined in skills/)

Skill One-liner Since
/redshift-setup Conversational walk-through to configure a connection profile. v0.2.0
/redshift-profile Profile a column: cardinality / top-N / null rate / min-max / existing comment, one round. v0.3.0
/redshift-suggest-schema-yml Draft a paste-ready dbt v2 models: block with conservative test suggestions. v0.3.0
/redshift-cache-schema Dump cluster structure as markdown to ~/.cache/... for offline browsing. v0.3.0
/redshift-erd Mermaid erDiagram with three-tier FK inference (pg_constraint → dbt manifest → naming heuristic), confidence-labeled. v0.3.0
/redshift-explore Three-step interactive wizard (schema → table → column) — pick by reading comments. v0.3.0
/redshift-lineage-from-stl Mine STL_QUERY + sqlglot to reconstruct actual table-to-table lineage from query history. v0.3.0

Each skill has its own tri-lingual README inside its folder.

Quick start

The fastest path is the Claude Code plugin.

# 1. Register the marketplace (one-time)
claude plugin marketplace add kouko/redshift-comment-mcp

# 2. Install the plugin
claude plugin install redshift-comment-mcp

# 3. Configure a connection profile (in a Claude Code chat)
/redshift-setup

/redshift-setup walks you through host / port / user / dbname / password. The password is collected in a system dialog (macOS) or a zenity prompt (Linux desktop) or your own terminal (headless) — never in chat. It lands directly in your OS keychain.

After setup, just type any of the slash commands above. Multi-cluster? Run /redshift-setup again with a different profile name.

For Claude Desktop / other MCP clients / local development, see docs/install.md (or scroll down to Other install paths).

Other install paths

Scenario How
Claude Code (recommended) claude plugin install redshift-comment-mcp (above)
Claude Desktop / generic MCP client pip install redshift-comment-mcp then point your client at uvx redshift-comment-mcp --profile default
Local development git clone … && pip install -e ".[dev]" then python -m redshift_comment_mcp.server --profile default
Multi-cluster One profile per cluster: redshift-comment-mcp setup --profile prod

The plugin runs from the cloned repo source via uv run --project ${CLAUDE_PLUGIN_ROOT} — PyPI release is NOT a prerequisite for plugin updates.

Where things live

.
├── README.md / README.ja.md / README.zh-TW.md     (this file, tri-lingual)
├── implementation_guide.md                         design rationale + charter
├── src/redshift_comment_mcp/                       MCP server source — see its own README
├── skills/                                         7 slash-command skills — see its own README
├── commands/                                       plugin slash command stubs
├── tests/                                          pytest suite
├── pyproject.toml                                  packaging metadata
└── .claude-plugin/                                 plugin manifest + marketplace

The two READMEs to read next:

Data layout at runtime

Path Contents Permissions
~/.config/redshift-comment-mcp/config.toml Non-secret profile fields 0600
OS keychain (redshift-comment-mcp / <profile>) Passwords OS-managed
~/.cache/redshift-comment-mcp/<profile>/ Optional offline structure cache (written by /redshift-cache-schema) 0700

Recommended DB GRANTs (defense-in-depth)

execute_sql blocks DDL / DML / admin keywords at the parser layer (DROP / DELETE / UPDATE / INSERT / ALTER / CREATE / TRUNCATE / MERGE / GRANT / REVOKE / COPY / UNLOAD), but that's a layer-1 defense. The defense-in-depth move is to give the plugin's connecting Redshift user read-only privileges only, so even if a parser bypass is found, the database itself rejects writes:

-- Create a dedicated read-only user for the plugin
CREATE USER redshift_mcp_reader WITH PASSWORD '...';

-- Grant only what the plugin actually needs
GRANT USAGE ON SCHEMA public, dbt_marts, dbt_staging TO redshift_mcp_reader;
GRANT SELECT ON ALL TABLES IN SCHEMA public, dbt_marts, dbt_staging TO redshift_mcp_reader;
ALTER DEFAULT PRIVILEGES IN SCHEMA public, dbt_marts, dbt_staging
  GRANT SELECT ON TABLES TO redshift_mcp_reader;

-- Do NOT grant: INSERT / UPDATE / DELETE / TRUNCATE / DROP / CREATE / GRANT / superuser

For /redshift-lineage-from-stl, the user additionally needs SYSLOG ACCESS UNRESTRICTED (or admin) to read STL_QUERY / SYS_QUERY_HISTORY. If you're not running that skill, skip this grant.

Comment-writing tips for your DB

The plugin shines brightest on tables whose owners invest in comments. Concrete tips (Chinese examples — adapt to your team's language):

COMMENT ON SCHEMA   sales        IS '[用途] 線上零售銷售數據 [主要實體] 訂單, 客戶, 產品';
COMMENT ON TABLE    sales.orders IS '[實體] 訂單 [PK] order_id [FK] customer_id → customers.customer_id';
COMMENT ON COLUMN   sales.orders.revenue IS '[定義] 訂單總銷售額 [語意類型] Metric [單位] 新台幣 [計算] 未稅商品總價 + 稅 − 折扣';

A more thorough Semantic Layer guide is in implementation_guide.md Appendix A.

Development

pytest tests/                    # run tests
python -m build                  # build sdist + wheel

CI / release flow lives in .github/.

License

MIT

Contributing

Issues and pull requests welcome. New skills should follow the patterns documented in skills/README.md: read-only, MCP-composed, no direct DB connections, no synthesis layer. SKILL.md ≤ 130 lines, tri-lingual README, audited via dev-workflow:skill-judge before commit.

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

redshift_comment_mcp-0.2.2.tar.gz (111.7 kB view details)

Uploaded Source

Built Distribution

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

redshift_comment_mcp-0.2.2-py3-none-any.whl (30.2 kB view details)

Uploaded Python 3

File details

Details for the file redshift_comment_mcp-0.2.2.tar.gz.

File metadata

  • Download URL: redshift_comment_mcp-0.2.2.tar.gz
  • Upload date:
  • Size: 111.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for redshift_comment_mcp-0.2.2.tar.gz
Algorithm Hash digest
SHA256 67389df21d400fafeebda0d62102d312b53196a0c7da5dc3420e1d39f12c442e
MD5 9b7e3fc99b18c6690144295300741870
BLAKE2b-256 0a35d8929950a99378b257ab426bc6a3fada05b96a42f7d3707622815403dc46

See more details on using hashes here.

File details

Details for the file redshift_comment_mcp-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for redshift_comment_mcp-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9c5b67bd5f31bac47bf517ca5a4b280741303a0c06a5c6c2804415d826e2b52a
MD5 e7b17ca283d5d361739fcbca89b9accd
BLAKE2b-256 5eb9bd1b14d9b1f3ceec27af55b2d287f61f35f16e2129f816ca65821f3b1009

See more details on using hashes here.

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