mcp-tableau
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-tableaupublish the sales dashboard to Tableau Server"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Tableau
Servidor Model Context Protocol construído com FastMCP que expõe ferramentas para automatizar o ciclo de publicação e validação de conteúdo no Tableau Server / Tableau Cloud.
O objetivo é permitir que um agente de IA autônomo complete o fluxo descobrir → construir → validar → publicar sem intervenção humana, com retornos estruturados e auditáveis. As capacidades cobrem:
Deploy — publicar/sobrescrever workbooks (
.twb/.twbx) e datasources (.tds/.tdsx).Inspeção visual — renderizar PNG/PDF de views e sinalizar telas em branco.
QA estrutural — ler campos, filtros e conexões; auditar complexidade contra boas práticas.
Metadados — linhagem ascendente/descendente, dicionário de dados e busca de similaridade.
🚀 Começando agora? Veja o QUICKSTART para rodar o servidor via
uvxe configurar nos principais agentes (Claude, GitHub Copilot, Cursor, Kiro e outros).
Stack
Linguagem: Python
>= 3.13Framework MCP: FastMCP (
>= 3.4.2), transporte stdioIntegração Tableau:
tableauserverclient(REST API) + Metadata API (GraphQL)Parsing/validação:
tableaudocumentapi,Pillow,rapidfuzz,pydanticGerenciador de pacotes: uv
Related MCP server: powerbi-mcp-local
Instalação
Requer uv e Python >= 3.13.
uv syncConfiguração
As credenciais são lidas de variáveis de ambiente (autenticação via Personal Access Token). Copie o exemplo e preencha os valores:
cp .env.example .envVariável | Obrigatória | Default | Descrição |
| sim | — | URL do Tableau Server/Cloud. |
| sim | — | Nome do Personal Access Token. |
| sim | — | Segredo do PAT (nunca é logado nem retornado). |
| não |
| Content URL do site (vazio = site default no Server). |
| não |
| Tempo limite das requisições à API, em segundos. |
| não |
| Limiar de filtros para auditoria de complexidade. |
| não |
| Limiar de worksheets. |
| não |
| Limiar de fontes de dados. |
O arquivo
.envé ignorado pelo Git. Nunca commite credenciais.
Execução
Inicia o servidor MCP em transporte stdio:
uv run python main.pyEstrutura do projeto
mcp-tableau/
├── src/mcp_tableau/
│ ├── __init__.py # versão do pacote
│ ├── server.py # instância FastMCP + registro das tools (stdio)
│ ├── config.py # Settings (env) e carregamento validado
│ ├── models.py # contratos Pydantic de saída + envelope ToolError
│ ├── tableau/ # integração REST (client.py) e GraphQL (metadata.py)
│ ├── tools/ # ferramentas MCP por capacidade
│ └── validation/ # regras de validação puras (sem rede)
├── tests/ # testes espelhando src/ (pytest)
├── main.py # ponto de entrada (inicia o servidor)
└── pyproject.toml # dependências e configuração de ferramentasTestes
A suite rápida (unitários + integração MCP in-memory) mocka toda a rede/Tableau:
uv run pytest # suite rápida + cobertura
uv run pytest -m integration # integração com Tableau realA suite rápida exclui a integração real e aplica o gate de cobertura ≥ 80%
(--cov-fail-under=80) automaticamente — ambos configurados em addopts no
pyproject.toml. A integração com Tableau real (publish/download roundtrip, render PNG e
linhagem) é marcada com @pytest.mark.integration, fica fora da suite rápida e só roda
com TABLEAU_INTEGRATION=1 e as variáveis de sandbox definidas
(TABLEAU_IT_WORKBOOK_PATH, TABLEAU_IT_PROJECT, TABLEAU_IT_VIEW_ID,
TABLEAU_IT_DATASOURCE_ID); caso contrário, esses testes são pulados.
Lint e formatação com Ruff:
uv run ruff check .
uv run ruff format .Convenções
Padrões de código e de testes ficam nas skills do projeto
(code-standards e
testing-standards). Consulte também
o AGENTS.md para a visão geral e boas práticas adotadas.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/edudutra/mcp-tableau'
If you have feedback or need assistance with the MCP directory API, please join our Discord server