iachat/db/seed_prompts
Rodribm10 8fab08ba57 fix(captain): regra de pessoa extra do Dolce Amore — taxa a partir da 3ª
Bug reportado por cliente real: "valor extra não é a partir da 3ª pessoa?
Porque aí é para casal, ou seja sempre vai ter duas pessoas".

Cliente está certo. A base do quarto pra casal JÁ INCLUI 2 pessoas; taxa
extra começa na 3ª pessoa, não na 2ª. A documentação anterior (modelo +
skill Hermes + scenario 21 em prod) tinha "a partir da 2ª pessoa", o que
fazia Valentina cobrar extra pra ambos do casal — erro.

Mudanças:
- Texto da regra: "a partir da 3ª pessoa" pra Apartamento/Suítes/Mini
  Chalé 45, com nota explícita "base do quarto já inclui 2 pessoas".
- Exemplo de cálculo refeito: 4 pessoas Suíte Master pernoite sex/sáb =
  180 + (2 × 45) = R$ 270 (era 180 + 3×45 = 315, errado).

Categorias maiores (Chalé 2 Suítes, Suíte Ouro, Chalé Master 4 Suítes)
mantidas como antes (4ª e 8ª pessoa) — Rodrigo precisa revisar essas
separadamente já que cada uma tem capacidade diferente.

Aplicado em 3 lugares:
- db/seed_prompts/_modelos/scenarios/jasmine_dolce_amore__daniela_reservas.md
- /root/.hermes/profiles/valentina/skills/dolce-amore-reservas/SKILL.md
- DB do Captain prod scenario 21 (via update_columns, +363 chars)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-01 15:52:09 -03:00
..
_modelos fix(captain): regra de pessoa extra do Dolce Amore — taxa a partir da 3ª 2026-05-01 15:52:09 -03:00
_producao_atual chore(prompts): reorganiza pastas (_prod_snapshot→_producao_atual, _staging_current→_modelos) e prefixa arquivos por unidade 2026-04-23 09:17:33 -03:00
target chore(prompts): split prod snapshot from staging from target 2026-04-22 11:31:42 -03:00
jasmine_orchestrator.md fix(captain): route embeddings to legacy OpenAI + retry transient errors 2026-04-22 17:42:31 -03:00
README.md chore(captain): ajustes de unit + migration + schema + seed README 2026-05-01 11:21:38 -03:00

Captain — prompts versionados

Todo prompt da Jasmine (orchestrator) e dos cenários (Daniela, Maria, Disponibilidade, etc) vive em arquivos .md aqui. O DB é só espelho.

Estrutura

db/seed_prompts/
├── README.md                  ← você está aqui
│
├── _producao_atual/           ← prompts rodando em produção HOJE (com defeitos)
│   │                            extraído de iachat_production em 2026-04-22
│   ├── assistants/  (4 Jasmines: qnn01, primeal, primevl, express)
│   └── scenarios/   (12 cenários, 3 por assistente)
│
├── _modelos/                  ← versões REVISADAS que vão virar a nova produção
│   │                            (o que Rodrigo e Claude testaram no staging,
│   │                             SEMPRE prefixado por unidade: jasmine_<slug>__)
│   ├── assistants/  (ex: jasmine_primeal.md — só PrimeAL validado até agora)
│   └── scenarios/   (ex: jasmine_primeal__daniela_reservas.md)
│
└── target/                    ← APLICADO no DB pela migration de seed
    ├── assistants/
    └── scenarios/

Regra simples

  • _producao_atual/ = só referência do que tá em prod hoje. Não é aplicado.
  • _modelos/ = só referência dos modelos revisados. Não é aplicado.
  • target/ = source of truth. A migration sincroniza isso no DB.

Arquivos vazios em target/ = a migration não toca aquele prompt. Útil pra deployar mudanças seletivas (ex: subir só Daniela melhorada sem mexer na Jasmine de cada unidade).

Workflow de revisão (o que estamos fazendo agora)

Pra cada prompt:

  1. Olhar _producao_atual/X.md (o que tá em prod hoje)
  2. Olhar _modelos/X.md (se existir — versão revisada)
  3. Decidir o conteúdo final: pode ser igual ao modelo, igual ao prod ou novo. Salvar em target/X.md.
  4. Quando todos os prompts revisados estiverem em target/, mergear pra main e deployar — a migration aplica em prod.

Convenção de nomes

Os nomes batem com name/title no banco:

Slug do arquivo Captain::Assistant#name
jasmine_qnn01 Jasmine( Qnn01)
jasmine_primeal Jasmine(PrimeAL)
jasmine_primevl Jasmine(PrimeVL)
jasmine_express Jasmine (Express)
jasmine_dolce_amore Jasmine(DolceAmore)
Slug do cenário Captain::Scenario#title
daniela_reservas Daniela_Reservas
disponibilidade_suites Disponibilidade de suites
maria_fotos maria_fotos
outras_unidades outras_unidades
reclamacoes_ouvidoria Reclamacoes_Ouvidoria

Convenção em _modelos/ — SEMPRE prefixado por unidade

Cada arquivo em _modelos/ representa UMA unidade específica, nunca genérico:

  • _modelos/assistants/jasmine_primeal.md → Jasmine do PrimeAL
  • _modelos/assistants/jasmine_qnn01.md → Jasmine do Qnn01 (quando criado)
  • _modelos/scenarios/jasmine_primeal__daniela_reservas.md → Daniela do PrimeAL
  • _modelos/scenarios/jasmine_qnn01__daniela_reservas.md → Daniela do Qnn01

A migration aplica qualquer arquivo sem prefixo em target/scenarios/ como genérico (todas as unidades); com prefixo <assistant_slug>__ aplica só naquela unidade, sobrescrevendo o genérico se os dois existirem.

Estado atual da revisão

Em revisão. target/ está vazio. Nada será aplicado em prod até preenchermos os arquivos lá.

Unidades com modelo validado:

  • PrimeAL (testado em staging 2026-04-23)
  • Qnn01
  • PrimeVL
  • Express
  • Dolce Amore (criado 2026-04-27 — primeira unidade fora do 1001 Noites; marca distinta, motel-first em Natal/RN; não testado em staging ainda)