Power BI MCP for Claude
MCP server for Microsoft Power BI and Fabric, enabling Claude to discover workspaces, semantic models, generate and execute DAX queries, and retrieve report metadata via device-code authentication.
README
Power BI MCP for Claude
Claude Desktop and Claude Code MCP server for Microsoft Power BI and Fabric. It supports Microsoft device-code sign-in, Power BI workspace and semantic model discovery, active semantic model context, DAX query generation/execution, schema metadata, report metadata, and redacted diagnostics.
Local Node/TypeScript MCP proxy for Claude. It forwards JSON-RPC messages to Microsoft's remote Power BI MCP endpoint, exposes stable local wrapper tools for Claude discovery, and acquires delegated Microsoft Entra ID tokens with MSAL device-code authentication.
The key difference from a terminal-only proxy is that first-time sign-in can happen from Claude chat. If Claude advertises MCP URL-mode elicitation, the server uses it. Claude Desktop currently starts this extension with MCP Apps UI capabilities instead, so the server also exposes local auth tools that return the Microsoft URL and device code directly in chat.
Remote endpoint:
https://api.fabric.microsoft.com/v1/mcp/powerbi
Power BI data access goes through this Fabric MCP endpoint. The local tools only handle sign-in and provide stable wrapper names for Claude Desktop to call.
Features
- Claude Desktop MCPB extension and Claude Code plugin support.
- Microsoft Entra ID device-code authentication through MSAL.
- Power BI workspace and semantic model discovery wrappers.
- Default and chat-scoped workspace/semantic model context.
- Fabric MCP wrappers for semantic model schema, DAX query generation, DAX execution, and report metadata.
- Redacted diagnostics for auth, context, local wrapper tools, and upstream Fabric MCP tool discovery.
- Fabric-only routing through
https://api.fabric.microsoft.com/v1/mcp/powerbi.
Install
npm install
npm run build
Commands
npm run start # run stdio MCP proxy
npm run login # authenticate in a terminal and populate the cache
npm run status # show non-sensitive cache/account info
npm run logout # delete the local MSAL token cache
npm test # run focused transport tests
Claude Desktop
Package as an MCPB desktop extension after building:
npm run build
npm run pack:mcpb
The root manifest.json describes the Claude Desktop extension. It passes POWERBI_MCP_CACHE_DIR, POWERBI_MCP_TENANT_ID, POWERBI_MCP_CLIENT_ID, and optional default workspace/semantic-model settings into the server.
Claude Code Plugin
The .claude-plugin/plugin.json, .mcp.json, and skills/powerbi/SKILL.md files let the same server run as a Claude Code plugin:
npm run build
claude --plugin-dir /path/to/Power-BI-MCP-Node
Authentication UX
The server first tries silent token acquisition from the local MSAL cache. It always exposes these local tools so Claude can discover them at connector startup:
powerbi_auth_startpowerbi_auth_statuspowerbi_auth_logoutpowerbi_diagnosticspowerbi_get_default_contextpowerbi_set_contextpowerbi_clear_contextpowerbi_list_workspacespowerbi_list_semantic_modelspowerbi_get_semantic_model_schemapowerbi_generate_dax_querypowerbi_execute_dax_querypowerbi_get_report_metadata
If no cached token is available:
- Claude calls
powerbi_auth_start. powerbi_auth_startreturns Microsoft's verification URL and a device code in chat.- The user completes Microsoft sign-in in the browser.
- MSAL stores refreshable tokens in the configured cache directory.
- Later requests, including workspace and semantic-model listing, refresh silently when possible and are sent to the Fabric MCP endpoint.
If chat-based sign-in is not convenient, run npm run login once from a normal terminal, then reconnect the MCP server.
Diagnostics
Use powerbi_diagnostics when Claude needs to verify whether the extension is healthy. It returns redacted status for the server version, authentication state, active/default context presence, local wrapper tools, and upstream Fabric MCP query tool discovery.
Diagnostics output intentionally omits tokens, auth headers, account email, cache paths, and raw workspace or semantic model IDs.
Default Power BI Context
Some Fabric MCP tools require a workspace ID or semantic model ID even when the endpoint does not advertise a tool that can list every available ID. In Claude Desktop settings, optionally configure one default workspace and one default semantic model:
- Default workspace ID
- Default workspace name
- Default semantic model ID
- Default semantic model name
The extension uses these defaults only when a Fabric MCP tool requires a missing ID. Explicit IDs supplied in chat are preserved.
You can also switch the active context inside a chat without changing Claude Desktop settings:
powerbi_set_contextsets a chat-session workspace ID, semantic model ID, or display names.powerbi_clear_contextclears the chat-session override and returns to Claude Desktop settings.powerbi_get_default_contextshows the active context, chat override, and configured defaults.
Context precedence is: explicit IDs in the current tool call, then chat-session context, then Claude Desktop settings.
The query tools are local wrappers around Fabric MCP tools so Claude can discover them before sign-in:
powerbi_get_semantic_model_schemaforwards to Fabric MCPGetSemanticModelSchema.powerbi_generate_dax_queryforwards to Fabric MCPGenerateQuery.powerbi_execute_dax_queryforwards to Fabric MCPExecuteQuery.powerbi_get_report_metadataforwards to Fabric MCPGetReportMetadata.
The wrappers still require Microsoft sign-in and still route all Power BI operations through https://api.fabric.microsoft.com/v1/mcp/powerbi.
Environment Variables
| Variable | Default |
|---|---|
POWERBI_MCP_URL |
https://api.fabric.microsoft.com/v1/mcp/powerbi |
POWERBI_MCP_CLIENT_ID |
built-in public Power BI client ID |
POWERBI_MCP_TENANT_ID |
organizations |
POWERBI_MCP_SCOPES |
https://analysis.windows.net/powerbi/api/.default |
POWERBI_MCP_DEFAULT_WORKSPACE_ID |
empty |
POWERBI_MCP_DEFAULT_WORKSPACE_NAME |
empty |
POWERBI_MCP_DEFAULT_SEMANTIC_MODEL_ID |
empty |
POWERBI_MCP_DEFAULT_SEMANTIC_MODEL_NAME |
empty |
POWERBI_MCP_CACHE_DIR |
~/.powerbi-mcp-claude, or ${CLAUDE_PLUGIN_DATA}/cache in Claude Code plugin mode |
POWERBI_MCP_TIMEOUT_SECONDS |
60 |
POWERBI_MCP_DEVICE_CODE_TIMEOUT_SECONDS |
900 |
POWERBI_MCP_ALLOW_INTERACTIVE_AUTH |
true |
Do not paste Microsoft access tokens or refresh tokens into Claude. Use device-code sign-in or a tenant-approved public-client app registration.
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.