Skip to main content

TOMPo — Power BI & Fabric Lineage Intelligence. MCP Server + Streamlit Web App. Trace lineage from columns to visuals, cross-workspace. Governance health scores.

Project description

TOMPo MCP — Power BI & Fabric Lineage Intelligence

Trace lineage from semantic models → tables → reports → pages → visuals → columns/measures.

An MCP (Model Context Protocol) server that brings Power BI lineage intelligence directly into your AI assistant — GitHub Copilot, Claude Desktop, Cursor, or any MCP-compatible client.

What it does

  • Full Lineage: See exactly which columns and measures appear in which visuals, across all reports bound to a semantic model
  • Impact Analysis: "What breaks if I rename Employee.StartDate?" — instantly shows every affected visual
  • Interactive Visualization: Export a self-contained D3 tree (HTML file) with expand/collapse, zoom, and search
  • Zero Infrastructure: Runs locally on your machine using your own Azure identity. No App Service, no Docker, no backend.

Quick Start

1. Install

pip install git+https://github.com/microsoft/tompo-mcp.git

Or clone and install locally:

git clone https://github.com/microsoft/tompo-mcp.git
cd tompo-mcp
pip install -e .

2. Login to Azure

az login

3. Add to VS Code

Add to your VS Code settings.json (Ctrl+Shift+P → "Preferences: Open User Settings (JSON)"):

{
  "mcp": {
    "servers": {
      "tompo": {
        "command": "python",
        "args": ["-m", "tompo_mcp"]
      }
    }
  }
}

4. Use in Copilot Chat

Open GitHub Copilot Chat and start asking:

> List my Fabric workspaces
> Generate lineage for dataset abc-123 in workspace xyz-456
> What visuals use the Employee.Department column?
> Export the lineage as an interactive HTML file

MCP Tools

Tool Description
list_workspaces List all Fabric/Power BI workspaces you have access to
generate_lineage Full lineage: Model → Tables → Reports → Pages → Visuals → Fields
impact_analysis Find all visuals where a specific column or measure is used
describe_semantic_model Detailed metadata: tables, columns, measures, relationships, roles
export_lineage_html Generate interactive D3 visualization as a self-contained HTML file

How It Works

You type in Copilot Chat
        │
        ▼
Copilot calls TOMPo MCP tools
        │
        ▼
TOMPo runs locally on your machine:
  → Uses your az login identity
  → Calls Fabric REST APIs (getDefinition, Scanner, DAX)
  → Parses model + report definitions
  → Builds lineage tree
  → Returns data to Copilot
        │
        ▼
Copilot shows the lineage tree / impact table
(or opens interactive HTML in your browser)

Authentication

TOMPo uses DefaultAzureCredential which automatically picks up:

  1. Azure CLI (az login) — most common for developers
  2. VS Code Azure Account — if you're signed into the Azure extension
  3. Environment variables — for CI/CD pipelines
  4. Managed Identity — for Azure-hosted scenarios

You need access to the Fabric workspaces you want to analyze. No extra app registrations or service principals required.

Metadata Extraction (3-tier fallback)

  1. Fabric getDefinition API — returns full model.bim / TMDL / PBIR definitions
  2. Admin Scanner API — fallback if getDefinition fails (requires admin permissions)
  3. DAX executeQueries — last resort using INFO.TABLES(), INFO.COLUMNS(), etc.

If a sensitivity label blocks access, TOMPo temporarily downgrades to "General", extracts metadata, then restores the original label.

Interactive Visualization

The export_lineage_html tool generates a single HTML file with:

  • D3 horizontal tree with expand/collapse nodes
  • Color-coded by type (model, table, report, page, visual, column, measure)
  • Impact Analysis tab with searchable data grid
  • Semantic Model tab with tables, columns, measures, relationships
  • Zoom, pan, fullscreen — all interactive
  • Works offline — all JavaScript and CSS inlined, no server needed

Claude Desktop

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "tompo": {
      "command": "python",
      "args": ["-m", "tompo_mcp"]
    }
  }
}

Development

git clone https://github.com/microsoft/tompo-mcp.git
cd tompo-mcp
pip install -e ".[dev]"
python -m pytest tests/

Requirements

  • Python 3.10+
  • Azure CLI (az login) or any Azure credential
  • Access to Fabric/Power BI workspaces

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

tompo_mcp-0.3.14.tar.gz (112.5 kB view details)

Uploaded Source

Built Distribution

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

tompo_mcp-0.3.14-py3-none-any.whl (73.7 kB view details)

Uploaded Python 3

File details

Details for the file tompo_mcp-0.3.14.tar.gz.

File metadata

  • Download URL: tompo_mcp-0.3.14.tar.gz
  • Upload date:
  • Size: 112.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for tompo_mcp-0.3.14.tar.gz
Algorithm Hash digest
SHA256 57600dcf286f465102c0f776c1f7327faac1c7d5cbc0a310f55db69152e16cd4
MD5 db7ed641b14248152bba394e45d7cd43
BLAKE2b-256 f38b9d3086f714117e99c6d5da00d2a8d4f04cc21b873fc99e626a937bb42604

See more details on using hashes here.

File details

Details for the file tompo_mcp-0.3.14-py3-none-any.whl.

File metadata

  • Download URL: tompo_mcp-0.3.14-py3-none-any.whl
  • Upload date:
  • Size: 73.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for tompo_mcp-0.3.14-py3-none-any.whl
Algorithm Hash digest
SHA256 6bf8aede455974788453d5a4c7c113ce09f6c9e3a3716f5d88096a2b948dd68c
MD5 6dcff961c05bd0dd21923fe77aa207f1
BLAKE2b-256 4bee81a568f603ca685bb4827bc87bf8b76e95595a62085524690934e17b5399

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