Como Integrar o Amazon Bedrock AgentCore com Slack: Guia Prático com AWS CDK

Visão geral da integração entre Amazon Bedrock AgentCore e Slack
Integrar o Amazon Bedrock AgentCore ao Slack permite que equipes acessem agentes de IA diretamente em seu ambiente de trabalho, sem a necessidade de alternar entre aplicativos, perder o histórico de conversas ou se reautenticar. Essa integração aborda três desafios técnicos principais: validação segura dos eventos do Slack, manutenção do contexto das conversas em threads e gerenciamento de respostas que ultrapassam o limite de timeout do Slack.
O uso do AWS Cloud Development Kit (AWS CDK) simplifica a implantação da infraestrutura necessária, composta por funções AWS Lambda especializadas, Amazon API Gateway, Amazon Simple Queue Service (SQS) e AWS Secrets Manager, garantindo uma arquitetura serverless escalável e segura.
Componentes da solução e arquitetura
A solução é dividida em três seções principais:
- Construção da imagem do agente: Utiliza AWS CodeBuild para criar imagens containerizadas otimizadas para AWS Graviton (ARM64), armazenadas no Amazon Elastic Container Registry (ECR).
- Componentes do AgentCore: Implementa o AgentCore Runtime, Gateway e Memory, utilizando o Strands Agents SDK para orquestrar invocações de modelos, chamadas a ferramentas e gerenciamento do histórico de conversas.
- Infraestrutura de integração com Slack: Composta por API Gateway, Secrets Manager, três funções Lambda e SQS para validação, enfileiramento e processamento assíncrono das mensagens do Slack.
O fluxo de requisição funciona da seguinte forma: o usuário envia uma mensagem no Slack; o Slack encaminha um webhook ao API Gateway; a função Lambda de verificação valida a requisição usando segredos armazenados no Secrets Manager; após a verificação, a mensagem é colocada na fila SQS e processada pela função Lambda de integração com o AgentCore, que consulta o histórico da conversa, invoca o modelo Amazon Bedrock Nova Pro e retorna a resposta atualizada ao Slack.
Pré-requisitos para implantação
- Conta AWS com permissões para Amazon Bedrock AgentCore, Lambda, API Gateway, SQS, ECR, CodeBuild, IAM e Secrets Manager.
- AWS CLI v2 configurado com credenciais.
- Node.js v18 ou superior e npm instalados.
- AWS CDK instalado e configurado (comando
npm install -g aws-cdkecdk bootstrap). - Conta Slack com permissões para criar apps ou acesso a workspace sandbox para testes.
Passo a passo para criar a integração
1. Criar um app no Slack
- Acesse Slack API e clique em "Create New App".
- Escolha "From scratch", defina o nome "agent-core-weather-agent" e selecione o workspace.
- Em "OAuth & Permissions", adicione as seguintes permissões ao Bot Token Scopes:
app_mentions:read,chat:write,im:history,im:read,im:write. - Instale o app no workspace e copie o "Bot User OAuth Token" e o "Signing Secret" para uso posterior.
- Em "App Home", habilite o envio de comandos Slash e mensagens na aba de mensagens.
2. Implantar a infraestrutura com AWS CDK
Clone o repositório oficial do GitHub:
git clone https://github.com/aws-samples/sample-Integrating-Amazon-Bedrock-AgentCore-with-Slack
cd sample-Integrating-Amazon-Bedrock-AgentCore-with-Slack
Configure as variáveis de ambiente com as credenciais do Slack:
export SLACK_BOT_TOKEN="xoxb-seu-token-aqui"
export SLACK_SIGNING_SECRET="seu-signing-secret-aqui"
Execute o script de deploy:
./deploy.sh
Essa etapa cria três stacks CDK e pode levar de 10 a 15 minutos. Ao final, será exibida a URL do webhook necessária para a configuração no Slack.
3. Configurar assinaturas de eventos no Slack
- Retorne ao app no Slack API e acesse "Event Subscriptions".
- Ative "Enable Events" e cole a URL do webhook fornecida pela implantação no campo "Request URL". Aguarde a verificação com o ícone verde.
- Em "Subscribe to bot events", adicione os eventos
app_mentioneim. - Salve as alterações e reinstale o app no workspace para ativar as permissões.
4. Testar a integração no Slack
Localize o app "agent-core-weather-agent" na seção de Apps do Slack. Você pode convidar o app para um canal com o comando /invite @agent-core-weather-agent ou interagir via mensagem direta.
Exemplo de comando: "What’s the weather in Dallas today". O app responde inicialmente com "Processing your request..." e, após o processamento pelo AgentCore, atualiza a mensagem com a resposta do agente.
O histórico da conversa é mantido graças ao AgentCore Memory, permitindo continuidade sem repetição de contexto.
Detalhes técnicos da integração
Gerenciamento de sessões e contexto
O AgentCore utiliza o timestamp da thread do Slack como session ID e o ID do usuário como actor ID para identificar e manter o histórico da conversa. Essa abordagem elimina a necessidade de gerenciamento externo de estado e isola conversas em threads distintas.
Processamento assíncrono para respeitar timeout do Slack
Como as respostas do agente podem ultrapassar o limite de 3 segundos do Slack para webhooks, a arquitetura usa três funções Lambda:
- Verification Lambda: valida a assinatura do Slack e responde imediatamente.
- SQS Integration Lambda: filtra eventos e coloca as mensagens na fila SQS.
- Agent Integration Lambda: processa a fila, invoca o AgentCore e atualiza as mensagens no Slack.
Comunicação segura e acesso a ferramentas
O AgentCore Gateway utiliza autenticação AWS Signature Version 4 (SigV4) para comunicação segura e o protocolo Model Context Protocol (MCP) para invocar ferramentas, como o agente de clima usado no exemplo.
É possível estender o modelo para permitir autenticação individual de usuários via Identity Provider (IdP), embora essa funcionalidade não seja abordada neste tutorial.
Personalização e reutilização da solução
A camada de integração Slack pode ser reaproveitada para diferentes agentes construídos com AgentCore. Basta substituir as ferramentas do agente no stack AgentCore para adaptá-lo a outras necessidades de negócio, mantendo o gerenciamento de memória e padrões de comunicação.
Limpeza e remoção dos recursos
Para remover todos os recursos criados, execute o script:
./cleanup.sh