Sends HTTP requests to Slack webhooks for notifications and integrations, supporting custom parameters and headers
Webhooks MCP
Um servidor MCP (Model Context Protocol) para enviar requisições HTTP para webhooks com parâmetros dinâmicos.
Funcionalidades
✅ Suporte a todos os métodos HTTP: GET, POST, PUT, PATCH, DELETE
✅ Parâmetros dinâmicos de qualquer tipo (nome, email, telefone, etc.)
✅ Headers HTTP personalizados
✅ Timeout configurável
✅ Validação de entrada com Zod
✅ Tratamento de erros detalhado
✅ Logs de requisição e resposta
Instalação
As dependências já estão instaladas. Para reinstalar se necessário:
Compile o TypeScript:
Configuração no Claude Desktop
Adicione a seguinte configuração no arquivo claude_desktop_config.json:
Localização do arquivo de configuração:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
Uso
Ferramenta Disponível
send_webhook
Envia uma requisição HTTP para um webhook com parâmetros personalizados.
Parâmetros:
url(obrigatório): URL do webhook (ex: https://meuwebhook.com.br)method(obrigatório): Método HTTP (GET, POST, PUT, PATCH, DELETE)parameters(opcional): Objeto com parâmetros de qualquer tipoheaders(opcional): Headers HTTP adicionaistimeout(opcional): Timeout em milissegundos (padrão: 30000)
Exemplos de Uso
1. POST com dados de usuário
2. GET com query parameters
3. PUT com headers personalizados
4. DELETE simples
Comportamento por Método HTTP
GET/DELETE: Parâmetros são enviados como query parameters na URL
POST/PUT/PATCH: Parâmetros são enviados no body da requisição como JSON
Tratamento de Erros
O MCP trata diferentes tipos de erro:
Erros de validação: Quando os parâmetros não estão no formato correto
Erros HTTP: Quando o webhook retorna status de erro (4xx, 5xx)
Erros de rede: Timeout, conexão recusada, etc.
Desenvolvimento
Scripts disponíveis
npm run build: Compila o TypeScriptnpm run dev: Compila em modo watchnpm start: Executa o servidor compilado
Estrutura do projeto
Testando o Servidor
Para testar se o servidor está funcionando:
Logs
O servidor gera logs detalhados:
Requisições enviadas (método, URL, parâmetros)
Respostas recebidas (status, tempo de resposta)
Erros detalhados com contexto
Segurança
Validação rigorosa de entrada com Zod
Headers de User-Agent identificando o MCP
Timeout configurável para evitar requisições infinitas
Tratamento seguro de erros sem exposição de dados sensíveis
Whitelist de URLs/domínios: configure a variável de ambiente
WHITELIST_URLS(separada por vírgula) para restringir os destinos permitidos. Exemplo:
Se não configurada, qualquer URL será permitida.
Níveis de log configuráveis: defina a variável de ambiente
LOG_LEVELpara controlar a verbosidade dos logs (debug,info,warn,error). Exemplo:
Retentativas automáticas: defina as variáveis de ambiente
RETRY_ATTEMPTS(número de tentativas, padrão 1) eRETRY_BASE_DELAY_MS(delay inicial em ms, padrão 500) para habilitar retentativas automáticas com backoff exponencial em falhas temporárias.
Internacionalização (i18n): defina a variável de ambiente
LANGcomopt(padrão) ouenpara receber mensagens em português ou inglês.
Exemplos de Respostas de Erro
Erro de validação de parâmetros:
Erro HTTP (exemplo 500):
URL não permitida (whitelist):
Validação de Headers HTTP
Alguns headers são validados automaticamente:
Authorization: deve ser no formatoBearer <token>Content-Type: deve serapplication/json,application/x-www-form-urlencodedouapplication/xml
Exemplo de header válido:
Exemplo de header inválido:
FAQ
Como configuro domínios permitidos?
Defina a variável de ambiente WHITELIST_URLS com uma lista separada por vírgula dos domínios ou URLs permitidos.
Como habilito logs mais detalhados?
Defina LOG_LEVEL=debug para ver logs detalhados.
Como habilito retentativas automáticas?
Defina RETRY_ATTEMPTS e RETRY_BASE_DELAY_MS conforme desejado.
Como executo os testes automatizados?
Basta rodar npm test na raiz do projeto.
Como reportar um bug ou sugerir melhoria?
Abra uma issue no repositório do GitHub.
Próximos Passos
Configure o Claude Desktop: Adicione a configuração no arquivo
claude_desktop_config.jsonReinicie o Claude Desktop: Para carregar a nova configuração
Teste o MCP: Use o Claude para enviar webhooks com diferentes parâmetros
Exemplos Práticos
Veja o arquivo examples.json para exemplos detalhados de como usar o MCP em diferentes cenários:
Cadastro de usuários
Integrações com CRM
Notificações Slack
Processamento de pagamentos
E muito mais!
Deploy com Docker
Você pode rodar o MCP facilmente usando Docker:
Adapte as variáveis de ambiente conforme necessário.
CLI Interativa
Você pode testar webhooks manualmente pelo terminal:
Siga os prompts para informar URL, método, parâmetros e headers.