Server data from the Official MCP Registry
dbt MCP — manifest/run_results/sources/catalog parsing + DQ result tables (BigQuery/Postgres)
dbt MCP — manifest/run_results/sources/catalog parsing + DQ result tables (BigQuery/Postgres)
Valid MCP server (1 strong, 1 medium validity signals). No known CVEs in dependencies. Package registry verified. Imported from the Official MCP Registry. Trust signals: trusted author (10/10 approved).
4 files analyzed · 1 issue found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: DBT_PROJECT_DIR
Environment variable: DBT_TARGET_DIR
Environment variable: DBT_RUN_HISTORY_DIR
Environment variable: DQ_BACKEND
Environment variable: DQ_RESULTS_TABLE
Environment variable: DQ_SCORE_TABLE
Environment variable: GOOGLE_APPLICATION_CREDENTIALS
Environment variable: BQ_PROJECT_ID
Environment variable: PG_CONNECTION_STRING
Environment variable: DBT_ALLOW_WRITE
Environment variable: DQ_SCHEMA
Environment variable: DQ_COL_RUN_AT
Environment variable: DQ_COL_CHECK_TYPE
Environment variable: DQ_COL_STATUS
Environment variable: DQ_COL_DATASET
Environment variable: DQ_COL_TABLE_NAME
Environment variable: DQ_COL_SEVERITY
Environment variable: DQ_COL_FAILURE_COUNT
Environment variable: DQ_COL_MESSAGE
Environment variable: DQ_COL_CHECK_NAME
Environment variable: DQ_COL_SCORE_DATE
Environment variable: DQ_COL_SCOPE
Environment variable: DQ_COL_TIER
Environment variable: DQ_TIER1_TARGET_PCT
Environment variable: DBT_SLA_CONFIG_PATH
Environment variable: DBT_TOOLS
Environment variable: DBT_DISABLE
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-us-all-dbt": {
"env": {
"DBT_TOOLS": "your-dbt-tools-here",
"DQ_SCHEMA": "your-dq-schema-here",
"DQ_BACKEND": "your-dq-backend-here",
"DBT_DISABLE": "your-dbt-disable-here",
"DQ_COL_TIER": "your-dq-col-tier-here",
"DQ_COL_SCOPE": "your-dq-col-scope-here",
"BQ_PROJECT_ID": "your-bq-project-id-here",
"DQ_COL_RUN_AT": "your-dq-col-run-at-here",
"DQ_COL_STATUS": "your-dq-col-status-here",
"DBT_TARGET_DIR": "your-dbt-target-dir-here",
"DQ_COL_DATASET": "your-dq-col-dataset-here",
"DQ_COL_MESSAGE": "your-dq-col-message-here",
"DQ_SCORE_TABLE": "your-dq-score-table-here",
"DBT_ALLOW_WRITE": "your-dbt-allow-write-here",
"DBT_PROJECT_DIR": "your-dbt-project-dir-here",
"DQ_COL_SEVERITY": "your-dq-col-severity-here",
"DQ_RESULTS_TABLE": "your-dq-results-table-here",
"DQ_COL_CHECK_NAME": "your-dq-col-check-name-here",
"DQ_COL_CHECK_TYPE": "your-dq-col-check-type-here",
"DQ_COL_SCORE_DATE": "your-dq-col-score-date-here",
"DQ_COL_TABLE_NAME": "your-dq-col-table-name-here",
"DBT_RUN_HISTORY_DIR": "your-dbt-run-history-dir-here",
"DBT_SLA_CONFIG_PATH": "your-dbt-sla-config-path-here",
"DQ_TIER1_TARGET_PCT": "your-dq-tier1-target-pct-here",
"DQ_COL_FAILURE_COUNT": "your-dq-col-failure-count-here",
"PG_CONNECTION_STRING": "your-pg-connection-string-here",
"GOOGLE_APPLICATION_CREDENTIALS": "your-google-application-credentials-here"
},
"args": [
"-y",
"@us-all/dbt-mcp"
],
"command": "npx"
}
}
}From the project's GitHub README.
dbt MCP server —
manifest.json,run_results.json,sources.json,catalog.json, plus DQ result tables (BigQuery / Postgres) behind one stdio MCP. Built on@us-all/mcp-toolkit.
A read-only window into your dbt project for LLM clients. No dbt run triggering — just deep introspection, run-history analysis, source freshness, per-column test coverage, lineage walks, and (if you have a custom DQ result table) historical check trends and Tier SLA status.
For DAG triggering / run history / log tails, install the companion @us-all/airflow-mcp alongside.
dbt, quality, meta) — 21 primitive tools + 5 aggregations + 1 metaextractFields response projection on high-volume reads# 1. add the MCP server
pnpm add -D @us-all/dbt-mcp
# 2. add the DQ backend you actually use (only if you query custom DQ tables):
pnpm add -D @google-cloud/bigquery # OR
pnpm add -D pg
DBT_PROJECT_DIR=/path/to/dbt-project \
DQ_RESULTS_TABLE=my-project.data_ops.quality_checks \
npx @us-all/dbt-mcp
The server speaks MCP stdio; wire it into Claude Desktop / Cursor / any MCP client. Set MCP_TRANSPORT=http to opt in to Streamable HTTP transport (Bearer auth, /health endpoint).
| Category | Tools | Purpose |
|---|---|---|
dbt | 15 + 3 aggregations | Parse manifest.json / run_results.json / sources.json / catalog.json |
quality | 6 + 2 aggregations | Query quality_checks and quality_score_daily (BQ or PG); per-tier rollup via dq-tier-by-source |
meta | 1 (always on) | search-tools for natural-language tool discovery |
Toggle with DBT_TOOLS=dbt (allowlist) or DBT_DISABLE=quality (denylist).
dbt (15 + 3)dbt-list-models, dbt-get-model, dbt-list-tests, dbt-get-test, dbt-list-sources, dbt-get-source, dbt-list-exposures, dbt-list-macros, dbt-get-macro, dbt-list-runs, dbt-get-run-results, dbt-failed-tests, dbt-slow-models, dbt-coverage, dbt-graph, freshness-status, incident-context, dbt-sla-status
quality (6 + 2)dq-list-checks, dq-get-check-history, dq-failed-checks-by-dataset, dq-score-trend, dq-tier-status, dq-tier-by-source, failed-tests-summary, dq-score-snapshot
| Prompt | Use when |
|---|---|
investigate-failed-tests | "What's broken in the last 24h?" |
freshness-degradation-triage | "Are any sources stale?" (Tier 1 focus optional) |
dq-trend-report | "Give me a stakeholder-friendly DQ trend report" |
incident-triage | "Triage <model | source>" — bundles all signals |
| Env | Required | Notes |
|---|---|---|
DBT_PROJECT_DIR | yes | dbt project root (where dbt_project.yml lives) |
DBT_TARGET_DIR | no | Defaults to $DBT_PROJECT_DIR/target |
DBT_RUN_HISTORY_DIR | no | Optional dir for archived run_results.json history |
DQ_BACKEND | no | bigquery (default) or postgres |
DQ_RESULTS_TABLE | no | FQN of the checks table; required only for checks-based quality tools |
DQ_SCORE_TABLE | no | FQN of the score-daily table; required for score-only tools |
GOOGLE_APPLICATION_CREDENTIALS | no | For BigQuery backend (ADC fallback supported) |
BQ_PROJECT_ID | no | Explicit BQ project (otherwise inferred from ADC) |
PG_CONNECTION_STRING | no | When DQ_BACKEND=postgres (secret) |
DQ_SCHEMA | no | generic (default) or us-all — base schema preset for the quality category |
DQ_COL_* | no | Per-column overrides on top of DQ_SCHEMA (see below). Overrides must be simple SQL identifiers. |
DQ_TIER1_TARGET_PCT | no | Tier 1 SLA threshold for dq-tier-status when no tier column is configured (default 99.5). Superseded by DBT_SLA_CONFIG_PATH tier_sla.1 if both are set. |
DBT_SLA_CONFIG_PATH | no | Optional YAML path with tier_sla and dbt_sla blocks. Drives dq-tier-status thresholds and dq-tier-by-source per-tier targets. Mtime cached. |
DBT_ALLOW_WRITE | no | Reserved for future write tools (none currently) |
DBT_TOOLS / DBT_DISABLE | no | Category toggles |
The quality category supports two schema presets via DQ_SCHEMA:
DQ_SCHEMA=generic (default)Columns assumed on DQ_RESULTS_TABLE: run_at, check_name, check_type, dataset, table_name, status, severity, failure_count, message.
Columns assumed on DQ_SCORE_TABLE: score_date, scope, tier, completeness_pct, freshness_pct, validity_pct, anomaly_free_pct, overall_score.
dq-tier-status rolls up by Tier 1/2/3 against the per-scope rows.
DQ_SCHEMA=us-allReal schema used at us-all (Postgres data_ops database):
quality_checks: run_date, check_type, dimension, source, target_name, status, metric_value, threshold, details (JSONB).
quality_score_daily: run_date, completeness_pct, freshness_pct, validity_pct, anomaly_free_pct, overall_score, total_checks, failed_checks.
In this flavor quality_score_daily is one row per day (no per-scope rollup, no tier column). dq-tier-status falls back to comparing the day's overall_score against DQ_TIER1_TARGET_PCT (default 99.5).
dq-get-check-history requires checkName formatted as '<check_type>:<target_name>' since us-all has no native check_name column.
DQ_COL_*If your DQ tables don't match either preset, layer per-column overrides on top of DQ_SCHEMA. Any DQ_COL_* env var, when set, replaces the preset value for that single column. Unset vars keep the preset default.
Overrides are validated as simple SQL identifiers to avoid injecting raw SQL through environment variables. Table names in DQ_RESULTS_TABLE / DQ_SCORE_TABLE are also validated and quoted for the configured backend.
| Env var | Logical concept | Generic preset | us-all preset |
|---|---|---|---|
DQ_COL_RUN_AT | timestamp/date on the checks table | run_at | run_date |
DQ_COL_CHECK_TYPE | check type / dimension family | check_type | check_type |
DQ_COL_STATUS | pass/fail/warn/error | status | status |
DQ_COL_DATASET | dataset / source / schema | dataset | source |
DQ_COL_TABLE_NAME | table or target name | table_name | target_name |
DQ_COL_SEVERITY | severity / dimension | severity | dimension |
DQ_COL_FAILURE_COUNT | numeric failure count / metric | failure_count | metric_value |
DQ_COL_MESSAGE | free-text or JSON message | message | details::text |
DQ_COL_CHECK_NAME | natural identifier of the check | check_name | (none) |
DQ_COL_SCORE_DATE | date column on the score table | score_date | run_date |
DQ_COL_SCOPE | scope/tenant column on score table | scope | (none) |
DQ_COL_TIER | tier column on score table | tier | (none) |
For the three nullable columns (DQ_COL_CHECK_NAME, DQ_COL_SCOPE, DQ_COL_TIER), set the value to none / null / - to declare "no native column":
check_name → the tools synthesize one from check_type || ':' || table_name. dq-get-check-history then expects checkName formatted as '<check_type>:<table_name>'.scope → dq-score-trend's scope filter is ignored (with a caveat) and dq-tier-status switches to the single-overall_score path that compares against DQ_TIER1_TARGET_PCT.tier → same single-overall_score fallback.Example — generic preset against a Postgres schema where columns happen to be named differently:
DQ_SCHEMA=generic
DQ_COL_RUN_AT=checked_at
DQ_COL_DATASET=schema_name
DQ_COL_TABLE_NAME=tbl
DQ_COL_FAILURE_COUNT=fail_n
DQ_COL_CHECK_NAME=none # synthesize from check_type+tbl
DQ_COL_SCOPE=none # no per-team rollup
DQ_COL_TIER=none # use DQ_TIER1_TARGET_PCT instead
DBT_SLA_CONFIG_PATHSet DBT_SLA_CONFIG_PATH to a YAML file to surface project-defined tier targets and DBT SLAs to the quality tools. Schema (extra keys ignored):
dbt_sla:
test_pass_pct: 99.0 # consumed by dbt-sla-status (test pass rate threshold)
freshness_pass_pct: 99.5 # consumed by dbt-sla-status (source freshness pass rate threshold)
tier_sla:
1: 99.5 # tier-1 overall_score / per-source pass-rate target
2: 99.0
3: 95.0
When set, the tier_sla map drives:
dq-tier-status — per-tier rollup compares each row's overall_score against the matching target. Without this file, hardcoded {1: 99.5, 2: 99.0, 3: 95.0} is used.dq-tier-by-source — per-source pass-rate is compared to the target for that source's tier (resolved from dbt sources.yml meta.tier).dq-tier-status no-tier-column path (us-all preset / DQ_COL_TIER=none) — uses tier_sla.1 as the single target. DQ_TIER1_TARGET_PCT env still works as a fallback when no SLA file is set.The dbt_sla block drives:
dbt-sla-status — computes test pass rate from latest run_results.json and freshness pass rate from sources.json, then compares each axis against dbt_sla.test_pass_pct / dbt_sla.freshness_pass_pct. Returns passPct, target, meeting per axis plus caveats when fields or artifacts are missing.The file is mtime-cached; edits between tool calls are picked up automatically.
quality_checks — dq-tier-by-sourceFor schemas where quality_score_daily has only one row per day (no per-scope/tier breakdown), dq-tier-by-source reconstructs a per-tier picture from the raw quality_checks rows. Two modes:
mode: "source" (default) — group by source/dataset columnUse when each row of quality_checks represents a check on a source group and the dataset/source column carries the dbt source-group name directly.
source_name -> tier map from the dbt manifest's sources.<source>.<table>.meta.tier (first table's tier per source group).quality_checks rows by the dataset/source column and computes pass rate per source over a date or sinceHours window.mode: "table" — group by table_name columnUse when the dataset/source column is a category (bq / dbt / airflow) and the actual dbt source-table identifier lives in the table_name / target_name column as <source_group>.<table>. Common in checks tables that consolidate signals from heterogeneous backends.
<source_group>.<table> -> tier map from the manifest using each source entry's source_name + name + meta.tier — picks up table-level tier overrides naturally.quality_checks rows by the table_name column. Pre-filter via sourceFilter (e.g. sourceFilter: "bq") when only some categories produce parseable target names.<source_group>.<table>; rows without a . or whose key is not in the manifest land in caveats[].Untiered rows (no manifest meta.tier) and unparseable rows always appear in caveats[] so you can tier them or accept the gap.
caveats line will flag them.For Airflow DAG operations (list, runs, task instances, log tail, trigger, clear), install @us-all/airflow-mcp alongside this server.
pnpm install
pnpm run build # tsc → dist/
pnpm test # vitest
pnpm run smoke # spawns dist/index.js, calls initialize + tools/list (set env first)
MIT — see LICENSE.
Be the first to review this server!
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption