Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
4.5 KiB
F6.3 — Rollback da migração schema-per-tenant
Como voltar atrás. Lê isto ANTES de aplicar a F6.3 (o DROP). A regra de ouro: enquanto a F6.3 NÃO foi aplicada, o rollback é trivial e sem perda.
Princípio: a branch é a rede de segurança
A migração inteira (F3→F6.4) vive na branch feat/schema-per-tenant. A main
nunca mudou o modelo antigo — só recebeu F0/F1/F2, que são aditivas
(criam tenants.slug, o schema _tenant_template, helpers e o gatilho de
provisionamento; não removem nem alteram nada que o app antigo usa). Ou seja:
git checkout main te devolve o app funcionando no modelo public, desde que
o banco também volte (ver abaixo).
O único passo IRREVERSÍVEL por si só é o DROP (F6.3). Tudo antes dele é reversível porque os dados continuam espelhados em public (a F6.1 COPIA, não move). Por isso o checkpoint é parar ANTES do DROP.
Cenário 1 — ANTES de aplicar a F6.3 (estado atual) — rollback trivial
Nada destrutivo foi feito. Public tem todas as tabelas e dados originais. Para abandonar a migração:
# 1. código volta pro modelo antigo
git checkout main
# 2. banco: derruba os schemas tenant + artefatos da migração
docker exec -i -e PGPASSWORD=postgres supabase_db_agenciapsi-primesakai \
psql -U supabase_admin -h 127.0.0.1 -d postgres <<'SQL'
DO $$ DECLARE r record; BEGIN
FOR r IN SELECT nspname FROM pg_namespace WHERE nspname LIKE 'tenant\_%' OR nspname='_tenant_template' LOOP
EXECUTE format('DROP SCHEMA %I CASCADE', r.nspname);
END LOOP;
END $$;
-- limpa o registro + config do PostgREST
DELETE FROM public.tenant_schemas;
ALTER ROLE authenticator SET pgrst.db_schemas = 'public, graphql_public';
NOTIFY pgrst, 'reload config';
SQL
⚠️ As FUNÇÕES em public foram reescritas (F6.2) na branch, mas essas mudanças
não foram aplicadas via migration em main — elas vieram dos arquivos
manual/f6_2*.sql aplicados como supabase_admin no banco LOCAL. Se você quer o
banco local 100% igual ao main, restaure as funções originais do backup:
# restaura o estado public pré-migração (funções, triggers, tudo)
docker exec -i supabase_db_agenciapsi-primesakai psql -U postgres -d postgres \
< database-novo/backups/pre-F6/public.sql # ou o backup mais antigo (pré-F1)
Como na prática o banco é LOCAL e descartável, o caminho mais limpo do Cenário 1
é: git checkout main + node db.cjs reset (reinstala schema+seeds do zero).
Cenário 2 — DEPOIS de aplicar a F6.3 (DROP já feito) — recuperável, com cuidado
O DROP removeu as 78 tabelas tenant de public. Os dados VIVOS estão nos schemas
tenant_<slug>. Há duas situações:
2a) Rollback rápido (logo após o DROP, app quase não rodou nos schemas)
Os dados em public estavam atualizados até o backup pré-F6.3. Se quase nada foi escrito nos schemas depois do DROP, restaure public do backup e volte o código:
git checkout main
docker exec -i supabase_db_agenciapsi-primesakai psql -U postgres -d postgres \
< database-novo/backups/pre-F6.3/public.sql # backup TIRADO antes do DROP
# + derrubar schemas tenant (bloco SQL do Cenário 1)
PERDE: qualquer escrita feita NOS SCHEMAS entre o DROP e o rollback.
2b) Rollback com dados atualizados (app rodou e acumulou dados nos schemas)
Aí os schemas têm a verdade mais nova. Precisa de uma migração reversa
(schema → public, o inverso da F6.1), re-adicionando tenant_id. Roteiro:
- Restaure a ESTRUTURA das 78 tabelas em public (do backup pré-F6.3, sem os dados, ou recriando via o schema dump).
- Para cada tenant,
INSERT INTO public.<tab> (cols + tenant_id) SELECT cols, '<tenant_id>' FROM tenant_<slug>.<tab>— o inverso exato domanual/f6_1_migrate_data.supabase_admin.sql(trocar origem/destino e RE-ADICIONAR a coluna tenant_id com o id do tenant do schema). - Resetar sequences, recriar as 9 views + 2 FKs, voltar o código (
git checkout main).
Esse caminho é trabalhoso — por isso a recomendação forte: só aplique a F6.3 depois de validar o app, e mantenha o backup pré-F6.3. O DROP é a única coisa que transforma "trivial" em "trabalhoso".
Checklist antes de aplicar a F6.3 (resumo)
- App testado no browser (fluxos autenticados sem erro PGRST/4xx).
- Backup FRESCO:
pg_dump --schema=public > backups/pre-F6.3/public.sql. - Branch commitada (rollback de código =
git checkout main). - Ciente: pós-DROP, public some; a verdade passa a ser os schemas.