0006_resource_objects.sql 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. BEGIN;
  2. CREATE TABLE maps (
  3. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  4. map_public_id TEXT NOT NULL UNIQUE,
  5. code TEXT NOT NULL UNIQUE,
  6. name TEXT NOT NULL,
  7. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'disabled', 'archived')),
  8. description TEXT,
  9. current_version_id UUID,
  10. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  11. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
  12. );
  13. CREATE INDEX maps_status_idx ON maps(status);
  14. CREATE TRIGGER maps_set_updated_at
  15. BEFORE UPDATE ON maps
  16. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  17. CREATE TABLE map_versions (
  18. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  19. version_public_id TEXT NOT NULL UNIQUE,
  20. map_id UUID NOT NULL REFERENCES maps(id) ON DELETE CASCADE,
  21. version_code TEXT NOT NULL,
  22. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'archived')),
  23. mapmeta_url TEXT NOT NULL,
  24. tiles_root_url TEXT NOT NULL,
  25. published_asset_root TEXT,
  26. bounds_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  27. metadata_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  28. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  29. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  30. UNIQUE (map_id, version_code)
  31. );
  32. CREATE INDEX map_versions_map_id_idx ON map_versions(map_id);
  33. CREATE INDEX map_versions_status_idx ON map_versions(status);
  34. CREATE TRIGGER map_versions_set_updated_at
  35. BEFORE UPDATE ON map_versions
  36. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  37. ALTER TABLE maps
  38. ADD CONSTRAINT maps_current_version_fk
  39. FOREIGN KEY (current_version_id) REFERENCES map_versions(id) ON DELETE SET NULL;
  40. CREATE TABLE playfields (
  41. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  42. playfield_public_id TEXT NOT NULL UNIQUE,
  43. code TEXT NOT NULL UNIQUE,
  44. name TEXT NOT NULL,
  45. kind TEXT NOT NULL DEFAULT 'course',
  46. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'disabled', 'archived')),
  47. description TEXT,
  48. current_version_id UUID,
  49. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  50. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
  51. );
  52. CREATE INDEX playfields_status_idx ON playfields(status);
  53. CREATE TRIGGER playfields_set_updated_at
  54. BEFORE UPDATE ON playfields
  55. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  56. CREATE TABLE playfield_versions (
  57. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  58. version_public_id TEXT NOT NULL UNIQUE,
  59. playfield_id UUID NOT NULL REFERENCES playfields(id) ON DELETE CASCADE,
  60. version_code TEXT NOT NULL,
  61. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'archived')),
  62. source_type TEXT NOT NULL CHECK (source_type IN ('kml', 'geojson', 'control_set', 'json')),
  63. source_url TEXT NOT NULL,
  64. published_asset_root TEXT,
  65. control_count INTEGER,
  66. bounds_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  67. metadata_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  68. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  69. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  70. UNIQUE (playfield_id, version_code)
  71. );
  72. CREATE INDEX playfield_versions_playfield_id_idx ON playfield_versions(playfield_id);
  73. CREATE INDEX playfield_versions_status_idx ON playfield_versions(status);
  74. CREATE TRIGGER playfield_versions_set_updated_at
  75. BEFORE UPDATE ON playfield_versions
  76. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  77. ALTER TABLE playfields
  78. ADD CONSTRAINT playfields_current_version_fk
  79. FOREIGN KEY (current_version_id) REFERENCES playfield_versions(id) ON DELETE SET NULL;
  80. CREATE TABLE resource_packs (
  81. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  82. resource_pack_public_id TEXT NOT NULL UNIQUE,
  83. code TEXT NOT NULL UNIQUE,
  84. name TEXT NOT NULL,
  85. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'disabled', 'archived')),
  86. description TEXT,
  87. current_version_id UUID,
  88. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  89. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
  90. );
  91. CREATE INDEX resource_packs_status_idx ON resource_packs(status);
  92. CREATE TRIGGER resource_packs_set_updated_at
  93. BEFORE UPDATE ON resource_packs
  94. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  95. CREATE TABLE resource_pack_versions (
  96. id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
  97. version_public_id TEXT NOT NULL UNIQUE,
  98. resource_pack_id UUID NOT NULL REFERENCES resource_packs(id) ON DELETE CASCADE,
  99. version_code TEXT NOT NULL,
  100. status TEXT NOT NULL DEFAULT 'draft' CHECK (status IN ('draft', 'active', 'archived')),
  101. content_entry_url TEXT,
  102. audio_root_url TEXT,
  103. theme_profile_code TEXT,
  104. published_asset_root TEXT,
  105. metadata_jsonb JSONB NOT NULL DEFAULT '{}'::jsonb,
  106. created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  107. updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
  108. UNIQUE (resource_pack_id, version_code)
  109. );
  110. CREATE INDEX resource_pack_versions_pack_id_idx ON resource_pack_versions(resource_pack_id);
  111. CREATE INDEX resource_pack_versions_status_idx ON resource_pack_versions(status);
  112. CREATE TRIGGER resource_pack_versions_set_updated_at
  113. BEFORE UPDATE ON resource_pack_versions
  114. FOR EACH ROW EXECUTE FUNCTION set_updated_at();
  115. ALTER TABLE resource_packs
  116. ADD CONSTRAINT resource_packs_current_version_fk
  117. FOREIGN KEY (current_version_id) REFERENCES resource_pack_versions(id) ON DELETE SET NULL;
  118. COMMIT;