-- Migration: Ajout de colonnes UUID aux tables manquantes -- Création: 2025-01-27 -- Version: 1.0.0 -- Description: Ajoute des colonnes UUID aux tables conversation_members, audit_logs et security_events -- pour permettre la migration du code Rust de i64 vers Uuid -- ================================================================ -- TABLE conversation_members -- ================================================================ -- Ajouter la colonne uuid (cette table n'a pas de colonne id, seulement une PK composite) ALTER TABLE conversation_members ADD COLUMN IF NOT EXISTS uuid UUID DEFAULT gen_random_uuid(); -- Ajouter la contrainte UNIQUE ALTER TABLE conversation_members ADD CONSTRAINT conversation_members_uuid_unique UNIQUE (uuid); -- Ajouter la contrainte NOT NULL (après le backfill par default) -- Note: Les valeurs existantes ont déjà été remplies par DEFAULT, donc on peut ajouter NOT NULL ALTER TABLE conversation_members ALTER COLUMN uuid SET NOT NULL; -- Index pour performance CREATE INDEX IF NOT EXISTS idx_conversation_members_uuid ON conversation_members(uuid); -- ================================================================ -- TABLE audit_logs -- ================================================================ -- Ajouter la colonne uuid (cette table a déjà un id SERIAL) ALTER TABLE audit_logs ADD COLUMN IF NOT EXISTS uuid UUID DEFAULT gen_random_uuid(); -- Ajouter la contrainte UNIQUE ALTER TABLE audit_logs ADD CONSTRAINT audit_logs_uuid_unique UNIQUE (uuid); -- Ajouter la contrainte NOT NULL (après le backfill par default) ALTER TABLE audit_logs ALTER COLUMN uuid SET NOT NULL; -- Index pour performance CREATE INDEX IF NOT EXISTS idx_audit_logs_uuid ON audit_logs(uuid); -- ================================================================ -- TABLE security_events (block suppressed) -- ================================================================ -- Table externe non gérée dans ce schéma isolé. -- ================================================================ -- COMMENTAIRES -- ================================================================ COMMENT ON COLUMN conversation_members.uuid IS 'UUID unique pour chaque membre de conversation (pour migration i64 -> UUID)'; COMMENT ON COLUMN audit_logs.uuid IS 'UUID unique pour chaque log d''audit (pour migration i64 -> UUID)';