mirror of
https://github.com/penpot/penpot.git
synced 2025-01-10 00:40:30 -05:00
222 lines
5.8 KiB
PL/PgSQL
222 lines
5.8 KiB
PL/PgSQL
CREATE TABLE project (
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
team_id uuid NOT NULL REFERENCES team(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
deleted_at timestamptz DEFAULT NULL,
|
|
|
|
is_default boolean NOT NULL DEFAULT false,
|
|
|
|
name text NOT NULL
|
|
);
|
|
|
|
CREATE INDEX project__team_id__idx
|
|
ON project(team_id);
|
|
|
|
CREATE TABLE project_profile_rel (
|
|
profile_id uuid NOT NULL REFERENCES profile(id) ON DELETE CASCADE,
|
|
project_id uuid NOT NULL REFERENCES project(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
is_owner boolean DEFAULT false,
|
|
is_admin boolean DEFAULT false,
|
|
can_edit boolean DEFAULT false,
|
|
|
|
PRIMARY KEY (profile_id, project_id)
|
|
);
|
|
|
|
COMMENT ON TABLE project_profile_rel
|
|
IS 'Relation between projects and profiles (NM)';
|
|
|
|
CREATE INDEX project_profile_rel__profile_id__idx
|
|
ON project_profile_rel(profile_id);
|
|
|
|
CREATE INDEX project_profile_rel__project_id__idx
|
|
ON project_profile_rel(project_id);
|
|
|
|
|
|
|
|
CREATE TABLE file (
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
project_id uuid NOT NULL REFERENCES project(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
deleted_at timestamptz DEFAULT NULL,
|
|
|
|
name text NOT NULL
|
|
);
|
|
|
|
CREATE TABLE file_profile_rel (
|
|
file_id uuid NOT NULL REFERENCES file(id) ON DELETE CASCADE,
|
|
profile_id uuid NOT NULL REFERENCES profile(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
is_owner boolean DEFAULT false,
|
|
is_admin boolean DEFAULT false,
|
|
can_edit boolean DEFAULT false,
|
|
|
|
PRIMARY KEY (file_id, profile_id)
|
|
);
|
|
|
|
COMMENT ON TABLE file_profile_rel
|
|
IS 'Relation between files and profiles (NM)';
|
|
|
|
CREATE INDEX file_profile_rel__profile_id__idx
|
|
ON file_profile_rel(profile_id);
|
|
|
|
CREATE INDEX file_profile_rel__file_id__idx
|
|
ON file_profile_rel(file_id);
|
|
|
|
CREATE TRIGGER file_profile_rel__modified_at__tgr
|
|
BEFORE UPDATE ON file_profile_rel
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|
|
|
|
|
|
CREATE TABLE file_image (
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
file_id uuid NOT NULL REFERENCES file(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
deleted_at timestamptz DEFAULT NULL,
|
|
|
|
name text NOT NULL,
|
|
|
|
path text NOT NULL,
|
|
width int NOT NULL,
|
|
height int NOT NULL,
|
|
mtype text NOT NULL,
|
|
|
|
thumb_path text NOT NULL,
|
|
thumb_width int NOT NULL,
|
|
thumb_height int NOT NULL,
|
|
thumb_quality int NOT NULL,
|
|
thumb_mtype text NOT NULL
|
|
);
|
|
|
|
CREATE INDEX file_image__file_id__idx
|
|
ON file_image(file_id);
|
|
|
|
CREATE TRIGGER file_image__modified_at__tgr
|
|
BEFORE UPDATE ON file_image
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|
|
|
|
CREATE TRIGGER file_image__on_delete__tgr
|
|
AFTER DELETE ON file_image
|
|
FOR EACH ROW EXECUTE PROCEDURE handle_delete();
|
|
|
|
|
|
|
|
CREATE TABLE page (
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
file_id uuid NOT NULL REFERENCES file(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
deleted_at timestamptz DEFAULT NULL,
|
|
|
|
version bigint NOT NULL DEFAULT 0,
|
|
revn bigint NOT NULL DEFAULT 0,
|
|
|
|
share_token text NULL DEFAULT NULL,
|
|
|
|
ordering smallint NOT NULL,
|
|
|
|
name text NOT NULL,
|
|
data bytea NOT NULL
|
|
);
|
|
|
|
CREATE INDEX page__file_id__idx
|
|
ON page(file_id);
|
|
|
|
ALTER TABLE page
|
|
ALTER COLUMN data SET STORAGE EXTERNAL,
|
|
ALTER COLUMN share_token SET STORAGE PLAIN;
|
|
|
|
CREATE FUNCTION handle_page_update()
|
|
RETURNS TRIGGER AS $pagechange$
|
|
DECLARE
|
|
current_dt timestamptz := clock_timestamp();
|
|
proj_id uuid;
|
|
BEGIN
|
|
NEW.modified_at := current_dt;
|
|
|
|
UPDATE file
|
|
SET modified_at = current_dt
|
|
WHERE id = OLD.file_id
|
|
RETURNING project_id
|
|
INTO STRICT proj_id;
|
|
|
|
--- Update projects modified_at attribute when a
|
|
--- page of that project is modified.
|
|
UPDATE project
|
|
SET modified_at = current_dt
|
|
WHERE id = proj_id;
|
|
|
|
RETURN NEW;
|
|
END;
|
|
$pagechange$ LANGUAGE plpgsql;
|
|
|
|
CREATE TRIGGER page__on_update__tgr
|
|
BEFORE UPDATE ON page
|
|
FOR EACH ROW EXECUTE PROCEDURE handle_page_update();
|
|
|
|
|
|
|
|
CREATE TABLE page_version (
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
|
|
page_id uuid NOT NULL REFERENCES page(id) ON DELETE CASCADE,
|
|
profile_id uuid NULL REFERENCES profile(id) ON DELETE SET NULL,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
deleted_at timestamptz DEFAULT NULL,
|
|
|
|
version bigint NOT NULL DEFAULT 0,
|
|
|
|
label text NOT NULL DEFAULT '',
|
|
data bytea NOT NULL,
|
|
|
|
changes bytea NULL DEFAULT NULL
|
|
);
|
|
|
|
CREATE INDEX page_version__profile_id__idx
|
|
ON page_version(profile_id);
|
|
|
|
CREATE INDEX page_version__page_id__idx
|
|
ON page_version(page_id);
|
|
|
|
CREATE TRIGGER page_version__modified_at__tgr
|
|
BEFORE UPDATE ON page_version
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|
|
|
|
|
|
|
|
CREATE TABLE page_change (
|
|
id uuid PRIMARY KEY DEFAULT uuid_generate_v4(),
|
|
page_id uuid NOT NULL REFERENCES page(id) ON DELETE CASCADE,
|
|
|
|
created_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
modified_at timestamptz NOT NULL DEFAULT clock_timestamp(),
|
|
|
|
revn bigint NOT NULL DEFAULT 0,
|
|
|
|
label text NOT NULL DEFAULT '',
|
|
data bytea NOT NULL,
|
|
|
|
changes bytea NULL DEFAULT NULL
|
|
);
|
|
|
|
CREATE INDEX page_change__page_id__idx
|
|
ON page_change(page_id);
|
|
|
|
CREATE TRIGGER page_change__modified_at__tgr
|
|
BEFORE UPDATE ON page_change
|
|
FOR EACH ROW EXECUTE PROCEDURE update_modified_at();
|