aimm-mcp

aimm-mcp

Local MCP server for AI Model Manager that captures SQL data-model metadata and exposes it to MCP clients over stdio.

Category
Visit Server

README

aimm-mcp

Local Model Context Protocol server for the AI Model Manager. Captures SQL data-model metadata as one JSON file per project (<slug>.aimm.json) and exposes it to Claude Code (or any MCP client) over stdio.

Fork of the AIMM VS Code extension, rebuilt in Python with no UI: just tools the agent calls. Both the VS Code extension and this server read/write the same project-file format — share a project by committing one .aimm.json to your repo.

Why this exists

The VS Code extension lives inside an editor. This fork lets you skip the editor entirely — install once with claude mcp add, and any Claude session on the machine sees the same models.

Install

One line. Claude Code spawns the server via uvx (uv's npx) — no prior install, no setup.

claude mcp add aimm --scope user -- uvx aimm-mcp

First connection downloads the package (a few seconds). Subsequent connections are cache-served.

For testing from a local checkout before PyPI, see LOCAL_INSTALL.md.

Where state lives

Two concepts: machine-local sidecars (always at ~/Documents/AIMM/) and project files (anywhere you point them, default the same folder).

~/Documents/AIMM/                    machine-local, never moves
├── state.json                       which folder + which active project
├── discovered_joins.json            scan output (not project state)
└── diagnostics.log                  ODBC query append-log

<projects_folder>/                   defaults to ~/Documents/AIMM/
├── customer_warehouse.aimm.json     one project
├── reporting_model.aimm.json        another project
└── …

A team checks <projects_folder> into a git repo. The agent runs aimm_set_projects_folder to point at the local clone, then aimm_list_projects + aimm_set_active_project to pick one. The "active project" pointer survives across Claude Code sessions.

No derived snapshots on disk. Renderings (XML / markdown / raw JSON) happen in-memory when aimm_read_project_context is called.

Engines

Three engines via ODBC: trino, sql_server, databricks. Connection descriptors carry a DSN name (system DSN registered at the OS level) plus the catalog / database qualifier.

Tools

Session / context

The agent must select an active project before any project-touching tool runs — these tools handle that bootstrap.

  • aimm_set_projects_folder — point the server at a folder of .aimm.json files (defaults to ~/Documents/AIMM/). Use to switch to a team repo of shared projects. Clears the active pointer.
  • aimm_list_projects — enumerate .aimm.json files in the current folder with their internal project name + updated_at.
  • aimm_set_active_project — pick one as active. Subsequent tool calls read and write that file.
  • aimm_show_active_project — report the current pointer state (folder + active file + on-disk status).

Project + context

  • aimm_init_project — create a new <slug>.aimm.json (slug derived from name) in the current folder, set it as active.
  • aimm_read_project_context — return the entire active project. Formats: xml (default), markdown, json (raw bytes of the active file).

Connections + live catalog

  • aimm_upsert_connection — create / update a connection descriptor. Validates Trino catalog requirement.
  • aimm_list_system_dsns — pyodbc.dataSources() wrapper for discovery before upsert.
  • aimm_browse_connection — drill into schemas / tables / columns on a live connection. Optional case-insensitive search filter.
  • aimm_refresh_columns — re-fetch column shapes from information_schema and merge back into the active project (preserves user-edited PK / FK / description flags).

Table mutations

  • aimm_update_table — patch any non-identity field on a tracked table. Creates on first patch.
  • aimm_set_primary_key — atomically set primary_keys + flip is_primary_key on matching columns.
  • aimm_add_relationship — append an FK edge (idempotent on duplicates, composite keys supported).
  • aimm_add_upstream — append a lineage edge.

Semantic context (the "what it means" layer)

The structural fields above tell the agent what's there. These tell it what those things mean — captured once, surfaced on every subsequent aimm_read_project_context call.

  • aimm_set_table_grain — one-line "what is a row?" per table.
  • aimm_add_pitfall — append-with-dedupe to a table's "don't do this" list.
  • aimm_set_column_classification — flag a column as pii / phi / restricted / internal / public.
  • aimm_add_glossary_term — upsert a domain-vocabulary entry.
  • aimm_add_measure — upsert a KPI / metric with definition + formula.
  • aimm_update_project_config — patch the project header (description, conventions, dialect, default_connection, modeling_paradigm, tags).

Folder scan for joins

  • aimm_scan_folder_for_joins — walk a local folder of .sql files, extract JOIN clauses via sqlglot (multi-dialect fallback: tsql → spark → none), persist canonical edges to ~/Documents/AIMM/discovered_joins.json. Works without an active project.

Diagnostics

  • aimm_show_diagnostics_log — tail of diagnostics.log where every ODBC query is recorded.

Pending changes

  • aimm_get_pending_changes — per-tracked-table diff between authored columns and the live information_schema shape.

Why ODBC?

Every warehouse this targets exposes an ODBC driver. We never run user SQL — only information_schema reads for column / table / schema metadata. Drivers stay read-only at the credential level.

Development

uv sync --dev
uv run python -m aimm_mcp        # starts the MCP stdio server
uv run pytest -q                 # tests

License

MIT.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured