4.8 KiB
Manifesto de Desenvolvimento: Jasmine & Daniela (Reservas com Pix)
Data: 17/01/2026 Responsável: Arquiteto de Software (AI)
1. Visão Geral e Objetivo
Este documento define o padrão de desenvolvimento e comportamento para a funcionalidade de Reservas via Chat no Chatwoot (projeto Chatwoot-Develop). O objetivo final é uma experiência fluida onde a agente principal (Jasmine) orquestra o atendimento, delegando a lógica de negócio complexa para a especialista (Daniela), sem que o cliente perceba fricção ou "troca de robôs".
2. Experiência de Atendimento Ideal (Script de Referência)
Todo o desenvolvimento deve buscar replicar exatamente este fluxo de interação:
Cliente: "Gostaria de fazer uma reserva" Jasmine: "Perfeito! Vou te ajudar com isso 😊. Para darmos continuidade à sua reserva, poderia me informar, por favor, seu nome completo e CPF?"
Cliente: "João Pedro da Silva, CPF 123.456.789-00" Jasmine: "Obrigada, João 😊. Agora me diga, por favor: qual suíte você deseja reservar?"
Cliente: "Suíte Luxo" Jasmine: "Ótima escolha! ✨. Para qual data e horário/período você gostaria da reserva?"
Cliente: "Dia 20/02, das 22h às 10h" (Internamente: Daniela consulta disponibilidade e preço) Jasmine: "Prontinho! 😊 Sua reserva ficou assim: • Suíte: Luxo • Data: 20/02 • Horário: das 22h às 10h • Valor total: R$ 300,00
Para confirmar a reserva, é necessário o pagamento de 50% antecipado (R$ 150,00). Posso gerar o Pix para você agora?"
Cliente: "Pode sim" (Internamente: Daniela gera intenção e Pix) Jasmine: "Perfeito 😊 Segue abaixo o Pix para pagamento da entrada: 💰 Valor: R$ 150,00 📌 Chave Pix: [Copia e Cola] 👉 Basta copiar a chave Pix, colar no aplicativo do seu banco e realizar o pagamento. Assim que pagar, me avise por aqui para que eu confirme sua reserva, tudo bem?"
Cliente: "Pronto, acabei de pagar" (Internamente: Daniela confirma pagamento) Jasmine: "Pagamento confirmado com sucesso! ✅ Sua reserva está confirmada 🎉 Resumo final: • Suíte: Luxo • Data: 20/02 • Horário: das 22h às 10h • Entrada paga: R$ 150,00
Qualquer dúvida ou se precisar de algo mais, é só me chamar. Será um prazer te receber! 😊✨"
3. Protocolo de Debugging (Baseado em Tempo)
Para garantir a análise correta dos erros e a correção assertiva:
- Input do Usuário: O Rodrigo fornecerá o Horário de Início da Conversa (Horário de Brasília).
- Conversão e Análise: O Arquiteto converterá esse horário para o fuso do servidor (UTC/Local) e analisará os logs (
log/tool_debug.log,log/brain_debug.log,log/development.log) a partir desse ponto exato. - Reconstrução: O Arquiteto reconstruirá o fluxo passo-a-passo (Intenção -> Ferramenta -> Resposta -> Erro).
- Ação de Correção: O ajuste será feito para corrigir a raiz do problema, garantindo que o fluxo futuro respeite o item 2 (Script de Referência).
4. Princípios de Arquitetura (CTO Mode)
A. Jasmine é a Interface, Daniela é o Cérebro da Reserva
- O cliente NUNCA fala diretamente com a Daniela. A Jasmine é a "persona" que fala.
- A Daniela opera como uma Tool ou Scenario avançado que mantém estado.
- A Jasmine repassa a entrada do usuário para a Daniela, que processa a lógica de negócio e devolve instruções ou fatos.
- Jasmine: Responsável pela polidez, emojis e formatação final.
- Daniela: Responsável pelo fluxo lógico, cálculo de preços (50%) e validação de dados.
B. O Estado é Sagrado (Stateful)
- Não podemos depender da memória de curto prazo do LLM para dados críticos (CPF, Valor).
- O estado da reserva (etapa atual, dados coletados) deve ser persistido em
conversation.custom_attributes['jasmine_state']. - O fluxo é sequencial: Coleta Nome/CPF -> Coleta Suíte/Data -> Check Disponibilidade -> Acordo de Valor -> Pix -> Confirmação.
C. Postura "Fix It All"
- Não faremos correções pontuais (ex: "arruma esse erro de sintaxe").
- Ao encontrar um erro, analisaremos o fluxo completo.
- Se o Pix falhou, verificaremos desde a coleta do CPF até a chamada da API.
5. Estrutura Técnica
- JasmineBrain (
jasmine_brain.rb): Detecta intenção de reserva e delega paraDaniela Reservas. - Daniela (
seed_jasmine_hotel_v3.rb): Scenario configurado com instruções rigorosas para seguir o script ideal. - Tools:
update_contact: Salva Nome/CPF.check_availability: Calcula preço total.create_reservation_intent: Salva 50% do valor como depósito.generate_pix: Gera o Pix Cobrança (Inter/Simulado) para o valor do depósito.
Este documento deve ser lido no início de cada sessão de manutenção desta feature para garantir alinhamento.