| 1 |
|
| 2 |
|
| 3 |
|
| 4 |
|
| 5 |
|
| 6 |
|
| 7 |
|
| 8 |
|
| 9 |
|
| 10 |
|
| 11 |
|
| 12 |
|
| 13 |
|
| 14 |
|
| 15 |
|
| 16 |
|
| 17 |
|
| 18 |
CREATE TABLE item_images ( |
| 19 |
id UUID PRIMARY KEY DEFAULT gen_random_uuid(), |
| 20 |
item_id UUID NOT NULL REFERENCES items(id) ON DELETE CASCADE, |
| 21 |
s3_key TEXT NOT NULL, |
| 22 |
image_url TEXT NOT NULL, |
| 23 |
alt TEXT NOT NULL DEFAULT '', |
| 24 |
position INT NOT NULL DEFAULT 0, |
| 25 |
file_size_bytes BIGINT NOT NULL DEFAULT 0, |
| 26 |
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW() |
| 27 |
); |
| 28 |
|
| 29 |
CREATE INDEX idx_item_images_item ON item_images (item_id, position); |
| 30 |
|
| 31 |
CREATE TABLE project_images ( |
| 32 |
id UUID PRIMARY KEY DEFAULT gen_random_uuid(), |
| 33 |
project_id UUID NOT NULL REFERENCES projects(id) ON DELETE CASCADE, |
| 34 |
s3_key TEXT NOT NULL, |
| 35 |
image_url TEXT NOT NULL, |
| 36 |
alt TEXT NOT NULL DEFAULT '', |
| 37 |
position INT NOT NULL DEFAULT 0, |
| 38 |
file_size_bytes BIGINT NOT NULL DEFAULT 0, |
| 39 |
created_at TIMESTAMPTZ NOT NULL DEFAULT NOW() |
| 40 |
); |
| 41 |
|
| 42 |
CREATE INDEX idx_project_images_project ON project_images (project_id, position); |
| 43 |
|
| 44 |
|
| 45 |
|
| 46 |
ALTER TABLE scan_jobs DROP CONSTRAINT IF EXISTS scan_jobs_target_kind_check; |
| 47 |
ALTER TABLE scan_jobs ADD CONSTRAINT scan_jobs_target_kind_check |
| 48 |
CHECK (target_kind IN ( |
| 49 |
'version', 'item', 'project_image', 'item_image', 'media', |
| 50 |
'content_insertion', 'gallery_image' |
| 51 |
)); |
| 52 |
|