141 lines
3.7 KiB
SQL
141 lines
3.7 KiB
SQL
|
|
-- vtubers table
|
|
CREATE TABLE api.vtubers (
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
display_name TEXT NOT NULL,
|
|
chaturbate TEXT,
|
|
twitter TEXT,
|
|
patreon TEXT,
|
|
twitch TEXT,
|
|
tiktok TEXT,
|
|
onlyfans TEXT,
|
|
youtube TEXT,
|
|
linktree TEXT,
|
|
carrd TEXT,
|
|
fansly TEXT,
|
|
pornhub TEXT,
|
|
discord TEXT,
|
|
reddit TEXT,
|
|
throne TEXT,
|
|
instagram TEXT,
|
|
facebook TEXT,
|
|
merch TEXT,
|
|
slug TEXT NOT NULL,
|
|
description1 TEXT,
|
|
description2 TEXT,
|
|
image TEXT NOT NULL,
|
|
theme_color VARCHAR(7) NOT NULL,
|
|
image_blur TEXT DEFAULT '',
|
|
fansly_id TEXT,
|
|
chaturbate_id TEXT,
|
|
twitter_id TEXT
|
|
-- F.Y.I., relations as follows
|
|
-- toys (one-to-many)
|
|
-- vods (one-to-many)
|
|
-- streams (one-to-many)
|
|
);
|
|
GRANT all ON api.vtubers TO automation;
|
|
GRANT SELECT ON api.vtubers TO web_anon;
|
|
|
|
|
|
-- streams table
|
|
CREATE TABLE api.streams (
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
url TEXT NOT NULL,
|
|
platform_notification_type TEXT,
|
|
date timestamp(6) without time zone,
|
|
created_at timestamp(6) without time zone,
|
|
vtuber uuid,
|
|
FOREIGN KEY (vtuber) REFERENCES api.vtubers(id),
|
|
tweet TEXT,
|
|
archive_status TEXT,
|
|
is_chaturbate_stream BOOLEAN,
|
|
is_fansly_stream BOOLEAN
|
|
);
|
|
GRANT all ON api.streams TO automation;
|
|
GRANT SELECT ON api.streams TO web_anon;
|
|
|
|
-- toys table
|
|
CREATE TABLE api.toys (
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
-- relation. one toy to many tags
|
|
-- relation. one toy to many vtubers
|
|
make TEXT NOT NULL,
|
|
model TEXT NOT NULL,
|
|
image TEXT NOT NULL DEFAULT 'https://futureporn-b2.b-cdn.net/default-thumbnail.webp'
|
|
);
|
|
GRANT all ON api.toys TO automation;
|
|
GRANT SELECT ON api.toys TO web_anon;
|
|
|
|
|
|
-- tags table
|
|
CREATE TABLE api.tags (
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
name TEXT NOT NULL UNIQUE,
|
|
toy_id uuid,
|
|
FOREIGN KEY (toy_id) REFERENCES api.toys
|
|
);
|
|
GRANT all ON api.tags TO automation;
|
|
GRANT SELECT ON api.tags TO web_anon;
|
|
|
|
-- toys-tags junction table
|
|
CREATE TABLE api.toys_tags(
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
toy_id uuid,
|
|
tag_id uuid,
|
|
CONSTRAINT fk_toys FOREIGN KEY(toy_id) REFERENCES api.toys(id),
|
|
CONSTRAINT fk_tags FOREIGN KEY(tag_id) REFERENCES api.tags(id)
|
|
);
|
|
GRANT all ON api.toys_tags TO automation;
|
|
GRANT SELECT ON api.toys_tags TO web_anon;
|
|
|
|
-- tags-vods junction table
|
|
-- toys-vtubers junction table
|
|
CREATE TABLE api.toys_vtubers(
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
toy_id uuid,
|
|
vtuber_id uuid,
|
|
CONSTRAINT fk_toys FOREIGN KEY(toy_id) REFERENCES api.toys(id),
|
|
CONSTRAINT fk_vtubers FOREIGN KEY(vtuber_id) REFERENCES api.vtubers(id)
|
|
);
|
|
GRANT all ON api.toys_vtubers TO automation;
|
|
GRANT SELECT ON api.toys_vtubers TO web_anon;
|
|
|
|
|
|
|
|
|
|
-- vods table
|
|
CREATE TABLE api.vods (
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
stream_id uuid NOT NULL,
|
|
FOREIGN KEY (stream_id) REFERENCES api.streams(id),
|
|
video_cid TEXT UNIQUE,
|
|
CONSTRAINT check_video_cid CHECK (video_cid ~ 'Qm[1-9A-HJ-NP-Za-km-z]{44,}|b[A-Za-z2-7]{58,}|B[A-Z2-7]{58,}|z[1-9A-HJ-NP-Za-km-z]{48,}|F[0-9A-F]{50,}'),
|
|
announce_title TEXT,
|
|
announce_url TEXT,
|
|
note TEXT,
|
|
date timestamp(6) without time zone,
|
|
spoilers TEXT,
|
|
title TEXT,
|
|
uploader uuid,
|
|
mux_asset_id TEXT,
|
|
mux_playback_id TEXT,
|
|
s3_key TEXT,
|
|
s3_id TEXT,
|
|
thumbnail TEXT
|
|
);
|
|
GRANT all ON api.vods TO automation;
|
|
GRANT SELECT ON api.vods TO web_anon;
|
|
|
|
|
|
-- tags-vods junction table
|
|
CREATE TABLE api.tags_vods(
|
|
id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
tag_id uuid,
|
|
vod_id uuid,
|
|
CONSTRAINT fk_tags FOREIGN KEY(tag_id) REFERENCES api.tags(id),
|
|
CONSTRAINT fk_vods FOREIGN KEY(vod_id) REFERENCES api.vods(id)
|
|
);
|
|
GRANT all ON api.tags_vods TO automation;
|
|
GRANT SELECT ON api.tags_vods TO web_anon;
|