0009_event_ops_phase2.sql 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. BEGIN;
  2. CREATE TABLE event_presentations (
  3. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  4. presentation_public_id TEXT NOT NULL UNIQUE,
  5. event_id UUID NOT NULL REFERENCES events(id) ON DELETE CASCADE,
  6. code TEXT NOT NULL,
  7. name TEXT NOT NULL,
  8. presentation_type TEXT NOT NULL CHECK (presentation_type IN ('card', 'detail', 'h5', 'result', 'generic')),
  9. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'disabled', 'archived')),
  10. is_default BOOLEAN NOT NULL DEFAULT FALSE,
  11. schema_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  12. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  13. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  14. UNIQUE (event_id, code)
  15. );
  16. CREATE INDEX event_presentations_event_id_idx ON event_presentations(event_id);
  17. CREATE INDEX event_presentations_status_idx ON event_presentations(status);
  18. CREATE TRIGGER event_presentations_set_updated_at
  19. BEFORE UPDATE ON event_presentations
  20. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  21. CREATE TABLE content_bundles (
  22. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  23. content_bundle_public_id TEXT NOT NULL UNIQUE,
  24. event_id UUID NOT NULL REFERENCES events(id) ON DELETE CASCADE,
  25. code TEXT NOT NULL,
  26. name TEXT NOT NULL,
  27. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'disabled', 'archived')),
  28. is_default BOOLEAN NOT NULL DEFAULT FALSE,
  29. entry_url TEXT,
  30. asset_root_url TEXT,
  31. metadata_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  32. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  33. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  34. UNIQUE (event_id, code)
  35. );
  36. CREATE INDEX content_bundles_event_id_idx ON content_bundles(event_id);
  37. CREATE INDEX content_bundles_status_idx ON content_bundles(status);
  38. CREATE TRIGGER content_bundles_set_updated_at
  39. BEFORE UPDATE ON content_bundles
  40. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  41. ALTER TABLE event_releases
  42. ADD COLUMN presentation_id UUID REFERENCES event_presentations(id) ON DELETE SET NULL,
  43. ADD COLUMN content_bundle_id UUID REFERENCES content_bundles(id) ON DELETE SET NULL;
  44. CREATE INDEX event_releases_presentation_id_idx ON event_releases(presentation_id);
  45. CREATE INDEX event_releases_content_bundle_id_idx ON event_releases(content_bundle_id);
  46. COMMIT;