metabase-server

metabase-server

Enables AI assistants to interact with Metabase by providing access to dashboards, questions, and databases through the Metabase API. It allows users to list resources, execute existing cards, and run custom SQL queries to retrieve data through natural language.

Category
访问服务器

README

metabase-mcp-mbql

Serveur MCP (Model Context Protocol) pour l'intégration avec Metabase, avec support complet de MBQL pour l'édition visuelle des requêtes.

Installation

npm install metabase-mcp-mbql

Configuration MCP

Ajoutez cette configuration à votre client MCP (Claude Desktop, etc.) :

{
  "mcpServers": {
    "metabase": {
      "command": "npx",
      "args": ["metabase-mcp-mbql"],
      "env": {
        "METABASE_URL": "https://metabase.example.com",
        "METABASE_API_KEY": "mb_votre_cle_api"
      }
    }
  }
}

Authentification

Deux méthodes sont supportées :

1. Clé API (recommandé) :

{
  "METABASE_URL": "https://metabase.example.com",
  "METABASE_API_KEY": "mb_votre_cle_api"
}

2. Identifiants utilisateur :

{
  "METABASE_URL": "https://metabase.example.com",
  "METABASE_USERNAME": "votre_email",
  "METABASE_PASSWORD": "votre_mot_de_passe"
}

Outils disponibles

Dashboards

Outil Description
list_dashboards Liste tous les dashboards
get_dashboard Récupère les détails complets d'un dashboard (cartes, paramètres)
create_dashboard Crée un nouveau dashboard
update_dashboard Met à jour un dashboard existant
delete_dashboard Archive ou supprime un dashboard
get_dashboard_cards Liste toutes les cartes d'un dashboard
add_card_to_dashboard Ajoute une carte à un dashboard
remove_card_from_dashboard Retire une carte d'un dashboard
update_dashboard_cards Met à jour les cartes avec leurs mappings de paramètres
add_dashboard_filter Ajoute ou met à jour un filtre sur un dashboard

Cards (Questions)

Outil Description
list_cards Liste toutes les questions/cartes (filtres: archived, table, database, using_model, bookmarked, using_segment, all, mine)
get_card Récupère une carte avec sa configuration complète (dataset_query, template-tags)
create_card Crée une nouvelle question
update_card Met à jour une question existante
delete_card Archive ou supprime une question
execute_card Exécute une question et retourne les résultats

Requêtes MBQL

Outil Description
create_card_mbql Crée une question en MBQL (éditable dans le query builder visuel)
execute_mbql_query Exécute une requête MBQL sans créer de carte

Requêtes SQL

Outil Description
execute_query Exécute une requête SQL native sur une base de données

Bases de données

Outil Description
list_databases Liste toutes les bases de données
get_database_metadata Récupère les métadonnées complètes (tables, champs, IDs)
get_table_metadata Récupère les métadonnées détaillées d'une table

Collections

Outil Description
list_collections Liste toutes les collections
create_collection Crée une nouvelle collection
update_collection Met à jour une collection

Utilisateurs

Outil Description
list_users Liste tous les utilisateurs
get_user Récupère les détails d'un utilisateur
create_user Crée un nouvel utilisateur
update_user Met à jour un utilisateur
disable_user Désactive un utilisateur

Permissions

Outil Description
list_permission_groups Liste les groupes de permissions
create_permission_group Crée un groupe de permissions
delete_permission_group Supprime un groupe de permissions
get_collection_permissions Récupère le graphe des permissions par collection
update_collection_permissions Met à jour les permissions d'un groupe sur une collection
add_user_to_group Ajoute un utilisateur à un groupe
remove_user_from_group Retire un utilisateur d'un groupe

Exemples d'utilisation

Créer une question MBQL

{
  "name": "Ventes par mois",
  "database_id": 1,
  "query": {
    "source-table": 123,
    "aggregation": [["sum", ["field", 456, null]]],
    "breakout": [["field", 789, {"temporal-unit": "month"}]]
  },
  "display": "line"
}

Configurer un filtre avec template-tag

{
  "card_id": 42,
  "dataset_query": {
    "type": "native",
    "database": 1,
    "native": {
      "query": "SELECT * FROM orders WHERE status = {{status}}",
      "template-tags": {
        "status": {
          "id": "abc-123",
          "name": "status",
          "display-name": "Statut",
          "type": "dimension",
          "dimension": ["field", 456, null],
          "widget-type": "category"
        }
      }
    }
  }
}

Connecter un filtre dashboard à une carte

{
  "dashboard_id": 10,
  "cards": [{
    "id": 100,
    "card_id": 42,
    "row": 0,
    "col": 0,
    "size_x": 6,
    "size_y": 4,
    "parameter_mappings": [{
      "parameter_id": "filter-1",
      "card_id": 42,
      "target": ["variable", ["template-tag", "status"]]
    }]
  }]
}

Développement

# Installation des dépendances
npm install

# Build
npm run build

# Watch mode
npm run watch

# Inspector MCP (debug)
npm run inspector

Licence

MIT

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选