4.5 KiB
Substituição Daniela -> Camila Reservas (Migração e Arquitetura)
Data: 18/01/2026 Autor: Antigravity (Assistant) Contexto: Teste A/B e Evolução da Arquitetura de Reservas
1. Objetivo
Migrar a lógica de reservas que estava hardcoded na agente "Daniela Reservas" para uma nova arquitetura mais flexível baseada na agente "Camila Reservas", gerenciada via UI (Agent Manager) e com suporte a roteamento dinâmico.
O objetivo principal é permitir que o prompt e as configurações da agente de reservas sejam alterados por usuários não-técnicos (ou sem deploy), facilitando testes A/B e ajustes finos.
2. Mudanças Arquiteturais
A. De Hardcoded para Database-Driven
- Antes (Daniela): A lógica de seleção e o prompt da Daniela eram muitas vezes dependentes de código ou arquivos estáticos difíceis de alterar em tempo de execução.
- Depois (Camila): A Camila é um registro completo na tabela
Captain::Scenario(Agent Manager). Seu prompt ("Instruction") e ferramentas habilitadas vivem no banco de dados.
B. Roteamento Dinâmico (Dynamic Routing)
Implementamos uma nova camada de decisão na JasmineBrain para substituir o roteamento estático.
- Trigger Keywords: Adicionamos o campo
trigger_keywordsno modeloCaptain::Scenario. - Lógica: A Jasmine agora consulta o banco para ver se a mensagem do usuário contém palavras-chave de algum cenário ativo. Se sim, roteia diretamente, sem passar por lógicas condicionais complexas no código Ruby.
- Sugestão Mágica ✨: Criamos um endpoint
/suggest_triggersque usa LLM (configurável via envCAPTAIN_LLM_MODEL) para sugerir palavras-chave com base na descrição do agente.
C. Message Debouncer (WhatsApp)
Para resolver problemas de fragmentação de mensagens (onde "Oi", "quero", "reservar" eram processadas como 3 intenções separadas), implementamos um Debouncer.
- Funcionamento: O sistema aguarda um buffer de tempo (ex: 15s) após a última mensagem do usuário.
- Agregação: Todas as mensagens recebidas nesse intervalo são concatenadas (com
\n) e enviadas como um único bloco de texto para a IA. - Benefício: A Camila recebe o contexto completo ("Oi\nquero\nreservar") e responde de forma muito mais assertiva.
3. Passos da Migração
- Clonagem: Criamos um script
restore_camila_prompt.rbque clona a "Daniela Reservas" para criar a "Camila Reservas", copiando instruções e ferramentas. - Ajuste na Brain: Alteramos
enterprise/app/services/captain/llm/jasmine_brain.rbpara priorizar o roteamento dinâmico ou apontar explicitamente para a Camila em intenções de reserva. - UI Updates: Atualizamos o
ScenariosCard.vuepara suportar a edição de palavras-chave e a funcionalidade de sugestão mágica. - Backend Fixes: Corrigimos o
ScenariosControllerpara respeitar a variável de ambienteCAPTAIN_LLM_MODEL(Gemini) em vez de hardcoar OpenAI.
4. Arquivos Relevantes Alterados
enterprise/app/services/captain/llm/jasmine_brain.rb: Lógica de roteamento.enterprise/app/controllers/api/v1/accounts/captain/scenarios_controller.rb: Endpoint de sugestão e CRUD de cenários.app/javascript/dashboard/components-next/captain/assistant/ScenariosCard.vue: UI do Card de Cenário.app/javascript/dashboard/i18n/locale/pt_BR/integrations.json: Traduções (Trigger Keywords).enterprise/app/jobs/captain/conversation/debounce_response_job.rb: Job de Debounce.enterprise/app/jobs/captain/conversation/response_builder_job.rb: Lógica de agregação de mensagens no V2.
5. Como Validar
- Verificar Agente: Vá em "Capitão" > "Cenários" e confirme se "Camila Reservas" existe e está ativa.
- Testar Roteamento:
- Adicione palavras-chave na Camila (ex: "reservar", "vaga").
- Envie "Quero reservar" no Chat.
- Verifique se a resposta vem da Camila (pode ter personalidade diferente ou logar
agent_name: Camila Reservas).
- Testar Debounce:
- Envie 3 mensagens rápidas.
- Aguarde a resposta única.
6. Como Reverter (Rollback)
Caso a Camila apresente instabilidade:
- Via UI: Desative o cenário "Camila Reservas" no Agent Manager.
- Via Código (Emergência): Edite
jasmine_brain.rbe reverta o apontamento manual deconsultar_camila_reservasparaconsultar_daniela_reservas(se houver override manual). - Restaurar Prompt: Se a Camila for corrompida, rode
bundle exec rails runner restore_camila_prompt.rbpara resetá-la ao estado original da Daniela.