apply-media-production-migration.ts 992 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. import 'dotenv/config';
  2. import { Pool } from 'pg';
  3. async function main() {
  4. const pool = new Pool({ connectionString: process.env.DATABASE_URL });
  5. try {
  6. await pool.query(`
  7. ALTER TABLE media
  8. ADD COLUMN IF NOT EXISTS resource_id uuid
  9. `);
  10. await pool.query(`
  11. ALTER TABLE media
  12. ADD COLUMN IF NOT EXISTS error_message text
  13. `);
  14. await pool.query(`
  15. DO $$
  16. BEGIN
  17. IF NOT EXISTS (
  18. SELECT 1
  19. FROM pg_constraint
  20. WHERE conname = 'media_resource_id_resources_id_fk'
  21. ) THEN
  22. ALTER TABLE media
  23. ADD CONSTRAINT media_resource_id_resources_id_fk
  24. FOREIGN KEY (resource_id)
  25. REFERENCES resources(id)
  26. ON DELETE SET NULL;
  27. END IF;
  28. END $$;
  29. `);
  30. console.log('✅ Media production migration applied.');
  31. } finally {
  32. await pool.end();
  33. }
  34. }
  35. main().catch((error) => {
  36. console.error('❌ Migration failed:', error);
  37. process.exit(1);
  38. });