ProdLaunch

This commit is contained in:
2026-06-18 15:14:10 +02:00
parent d8f58640e5
commit 4c90a7c1a3
12 changed files with 1412 additions and 5 deletions
@@ -0,0 +1,44 @@
"""
Migrazione 0022: indice parziale su mailboxes(tenant_id, email_address).
Sostituisce l'indice UNIQUE completo con un indice parziale che esclude
le caselle soft-deleted (status = 'deleted'), permettendo la ri-creazione
di una casella con lo stesso indirizzo email dopo averla eliminata.
Revision ID: 0022_partial_unique_mailbox_email
Revises: 0021_add_rem_support
"""
from alembic import op
# ── Identificatori migrazione ─────────────────────────────────────────────────
revision = "0022"
down_revision = "0021"
branch_labels = None
depends_on = None
def upgrade() -> None:
# Rimuove il vecchio indice univoco completo (include anche i deleted)
op.drop_index("uq_mailbox_email_tenant", table_name="mailboxes")
# Crea un indice univoco parziale: solo caselle non-deleted
# Questo permette di avere piu' record soft-deleted con la stessa email
# e di ri-creare una casella dopo averla eliminata.
op.execute(
"CREATE UNIQUE INDEX uq_mailbox_email_tenant_active "
"ON mailboxes (tenant_id, email_address) "
"WHERE status != 'deleted'"
)
def downgrade() -> None:
op.drop_index("uq_mailbox_email_tenant_active", table_name="mailboxes")
# Ricrea l'indice completo originale
op.create_index(
"uq_mailbox_email_tenant",
"mailboxes",
["tenant_id", "email_address"],
unique=True,
)