TunnelHub MCP

TunnelHub MCP

Connects MCP clients to TunnelHub to monitor automations, inspect executions, and analyze logs or traces. It enables users to manage environments and troubleshoot integration failures through natural language commands.

Category
Visit Server

README

TunnelHub MCP

Conecte clientes MCP ao TunnelHub para investigar automações, execuções, logs, traces, estatísticas de uso, API Gateway, sistemas e pacotes usando o mesmo fluxo de autenticação do frontend.

Este MCP é especialmente útil para:

  • Acompanhar automações do TunnelHub
  • Localizar e resumir execuções
  • Imprimir logs e traces
  • Analisar falhas parciais e dependências externas
  • Trabalhar com ambientes da empresa atual

✨ O que você pode fazer

  • Autenticar no TunnelHub pelo navegador
  • Listar ambientes disponíveis
  • Listar e inspecionar automações
  • Consultar sistemas do ambiente atual
  • Consultar pacotes do ambiente atual
  • Consultar tabelas de de/para do ambiente atual
  • Consultar APIs, clients, usage plans, API keys e logs do API Gateway
  • Consultar estatísticas de uso e consumo da empresa atual
  • Localizar execuções por intervalo de tempo
  • Resumir uma execução completa
  • Consultar logs e traces de uma execução
  • Ler informações básicas da empresa atual

✅ Pré-requisitos

Você vai precisar de:

  • Node.js 22+
  • Acesso a uma empresa do TunnelHub
  • Um cliente compatível com MCP via stdio

Clientes recomendados:

  • OpenCode
  • Claude Desktop
  • Cursor
  • Outros clientes MCP compatíveis com stdio

🚀 Comece em 2 minutos

A forma principal de uso é via npx com o bin explícito:

npx -y @tunnelhub/mcp@latest

Se você estiver desenvolvendo localmente:

pnpm install
pnpm build
node dist/index.js

Se esta for sua primeira vez usando o MCP do TunnelHub, siga este fluxo:

  1. Faça login no TunnelHub
    • se for o primeiro login, informe o accountName da empresa
  2. Qual sessão está ativa?
  3. Liste os ambientes disponíveis
  4. Liste as automações ativas

Você não precisa decorar o nome das tools. Pode pedir em linguagem natural, e o cliente MCP deve escolher a ferramenta certa.

🔌 Configuração oficial por cliente

OpenCode

A forma mais estável de configurar no OpenCode é via opencode.json.

Se preferir, você também pode usar opencode mcp add, que abre um fluxo interativo para adicionar o servidor MCP.

Exemplo usando opencode.json:

Exemplo completo:

{
  "mcp": {
    "tunnelhub": {
      "type": "local",
      "command": [
        "npx",
        "-y",
        "@tunnelhub/mcp@latest"
      ],
      "enabled": true,
      "environment": {
        "OAUTH_CALLBACK_PORT": "3333"
      }
    }
  }
}

Exemplo usando build local:

{
  "mcp": {
    "tunnelhub": {
      "type": "local",
      "command": [
        "node",
        "/caminho/para/mcp/dist/index.js"
      ],
      "enabled": true,
      "environment": {
        "OAUTH_CALLBACK_PORT": "3333"
      }
    }
  }
}

Claude Desktop

Exemplo de configuração no claude_desktop_config.json:

{
  "mcpServers": {
    "tunnelhub": {
      "command": "npx",
      "args": ["-y", "@tunnelhub/mcp@latest"],
      "env": {
        "OAUTH_CALLBACK_PORT": "3333"
      }
    }
  }
}

Exemplo usando build local:

{
  "mcpServers": {
    "tunnelhub": {
      "command": "node",
      "args": ["/caminho/para/mcp/dist/index.js"],
      "env": {
        "OAUTH_CALLBACK_PORT": "3333"
      }
    }
  }
}

Cursor

Use o mesmo comando stdio do cliente MCP:

{
  "mcpServers": {
    "tunnelhub": {
      "command": "npx",
      "args": ["-y", "@tunnelhub/mcp@latest"],
      "env": {
        "OAUTH_CALLBACK_PORT": "3333"
      }
    }
  }
}

Exemplo usando build local:

{
  "mcpServers": {
    "tunnelhub": {
      "command": "node",
      "args": ["/caminho/para/mcp/dist/index.js"],
      "env": {
        "OAUTH_CALLBACK_PORT": "3333"
      }
    }
  }
}

Outros clientes MCP compatíveis com stdio

Se o cliente aceitar um comando local, use:

npx -y @tunnelhub/mcp@latest

Ou, em desenvolvimento:

node /caminho/para/mcp/dist/index.js

🔐 Como funciona o login

No primeiro uso, chame a ferramenta de login do MCP.

Fluxo esperado:

  1. O cliente chama login_tunnelhub
  2. O MCP abre o navegador local
  3. Você faz login no TunnelHub
  4. A sessão fica salva localmente
  5. As próximas ferramentas passam a usar a empresa e o ambiente ativos

Ferramentas básicas de sessão:

  • login_tunnelhub
  • current_session_tunnelhub
  • list_sessions_tunnelhub
  • list_environments_tunnelhub
  • switch_environment_tunnelhub
  • logout_tunnelhub

💬 Exemplos de perguntas

Você pode pedir coisas como:

  • Faça login no TunnelHub
  • Faça login no TunnelHub para a empresa 4success
  • Qual sessão está ativa?
  • Liste os ambientes disponíveis
  • Liste as automações ativas
  • Liste os sistemas HTTP do ambiente atual
  • Mostre o system 1234
  • Liste os pacotes do ambiente atual
  • Mostre o package abc
  • Liste as APIs do API Gateway
  • Mostre a API 123abc
  • Liste os clients de autenticacao
  • Mostre o client xyz
  • Liste os usage plans
  • Liste as API keys
  • Liste os logs da API 123abc
  • Mostre o log 9988 da API 123abc no timestamp 1710345600
  • Liste os logs globais do API Gateway no dia 2026-03-13
  • Mostre as estatísticas da home deste mês
  • Mostre as estatísticas da home de 2026-03-01 até 2026-03-31
  • Mostre o consumo de execuções do tenant neste mês
  • Mostre recargas e consumo do tenant para 2026-03-01
  • Liste as tabelas de de/para do ambiente atual
  • Busque a tabela de de/para CFOP
  • Liste os itens da tabela de de/para 1234
  • Me mostre o item abc da tabela de de/para 1234
  • Ache a execução 9b696080439f no dia 2026-03-13
  • Resuma a execução 019ce7f3-2707-740c-8692-9b696080439f
  • Me mostre os traces com ERROR dessa execução
  • Me mostre os logs dessa execução
  • Essa execução teve sucesso degradado?
  • Quais dependências externas falharam nessa execução?
  • Só usando o MCP, me diga o que precisa ser corrigido nessa automação

🧰 Principais ferramentas disponíveis

Sessão

  • login_tunnelhub
  • current_session_tunnelhub
  • list_sessions_tunnelhub
  • list_environments_tunnelhub
  • switch_environment_tunnelhub
  • logout_tunnelhub

Empresas

  • list_tenants_tunnelhub
  • get_tenant_tunnelhub

Tabelas de de/para

  • list_data_stores_tunnelhub
  • get_data_store_tunnelhub
  • list_data_store_items_tunnelhub
  • get_data_store_item_tunnelhub

API Gateway

  • list_api_gateways_tunnelhub
  • get_api_gateway_tunnelhub
  • list_api_keys_tunnelhub
  • list_usage_plans_tunnelhub
  • list_auth_clients_tunnelhub
  • get_auth_client_tunnelhub
  • list_auth_resource_servers_tunnelhub
  • list_api_gateway_logs_tunnelhub
  • get_api_gateway_log_tunnelhub
  • list_all_api_gateway_logs_tunnelhub

Sistemas

  • list_systems_tunnelhub
  • get_system_tunnelhub

Pacotes

  • list_packages_tunnelhub
  • get_package_tunnelhub

Automações

  • list_automations_tunnelhub
  • get_automation_tunnelhub
  • list_automation_deploys_tunnelhub
  • get_automation_action_logs_tunnelhub
  • execute_automation_tunnelhub

Monitoramento

  • list_automation_executions_tunnelhub
  • find_execution_tunnelhub
  • get_execution_tunnelhub
  • summarize_execution_tunnelhub
  • get_execution_traces_tunnelhub
  • get_execution_logs_tunnelhub

Estatísticas

  • get_home_statistics_tunnelhub
  • get_tenant_execution_statistics_tunnelhub

⚙️ Variáveis de ambiente

Variáveis suportadas:

  • OAUTH_CALLBACK_PORT padrão 3333
  • TUNNELHUB_FRONTEND_URL opcional
  • TUNNELHUB_API_HOST opcional; padrão https://api.tunnelhub.io

Observações:

  • O login usa o fluxo do frontend do TunnelHub
  • Quando possível, o MCP reutiliza o domínio personalizado da empresa
  • A porta do callback OAuth prefere 3333 e procura outra livre se necessário

🧭 Dicas de uso

  • Ao procurar uma execução, informe sempre a data ou um intervalo de tempo
  • Quando já souber automationId, executionId e executionPeriod, use direto as ferramentas de detalhe
  • Para diagnóstico rápido, prefira summarize_execution_tunnelhub
  • Para investigação detalhada, consulte traces e logs em seguida

⚠️ Limitações atuais

  • O foco atual está em automações e monitoramento
  • API Gateway está disponível em modo somente leitura
  • Sistemas e pacotes estão disponíveis em modo somente leitura
  • Tabelas de de/para estão disponíveis em modo somente leitura
  • API keys e logs podem incluir dados sensíveis retornados pelo backend
  • Algumas APIs do backend têm comportamentos específicos de filtro e paginação
  • A listagem de execuções depende de intervalo de tempo obrigatório
  • Estatísticas de consumo do tenant são somente leitura
  • Em get_tenant_execution_statistics_tunnelhub, o backend resolve o período principalmente por startDate

🛠️ Desenvolvimento local

Comandos úteis:

pnpm install
pnpm typecheck
pnpm build
pnpm dev

🤝 Contribuições

Feedback, sugestões e contribuições são bem-vindos.

Se você estiver evoluindo o MCP internamente, vale sempre validar:

  • Experiência de uso no cliente MCP
  • Clareza das respostas textuais
  • Consistência dos filtros
  • Qualidade dos exemplos do README

📦 Releases

O repositório publica GitHub Releases e o pacote no npm a partir de tags no formato vX.Y.Z.

Fluxo recomendado:

  1. Garanta que a branch principal esteja pronta para release
  2. Atualize a versão com um dos comandos abaixo:
    • pnpm release:patch para correções e ajustes compatíveis
    • pnpm release:minor para novas funcionalidades compatíveis
    • pnpm release:major para mudanças incompatíveis
  3. Envie o commit e a tag:
git push origin main --follow-tags

Quando a tag chegar no GitHub, o workflow de release:

  • valida se a tag bate com a versão do package.json
  • roda pnpm check
  • gera o tarball com npm pack
  • publica no npm via Trusted Publishing (OIDC)
  • cria ou atualiza a GitHub Release com notas automáticas

Para o publish no npm funcionar, configure o pacote no npm com Trusted Publisher apontando para tunnelhub/mcp e o workflow release.yml.

Comandos prontos:

# patch
pnpm release:patch
git push origin main --follow-tags

# minor
pnpm release:minor
git push origin main --follow-tags

# major
pnpm release:major
git push origin main --follow-tags

O histórico manual das releases fica em CHANGELOG.md.

📚 Documentação técnica

Detalhes técnicos, arquitetura e comportamento interno estão documentados em inglês:

  • docs/technical-overview.md

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