mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-09-09 07:58:52 -06:00
52 lines
1.8 KiB
SQL
52 lines
1.8 KiB
SQL
create extension "uuid-ossp";
|
|
|
|
create table comment_report (
|
|
id uuid primary key default uuid_generate_v4(),
|
|
time timestamp not null default now(),
|
|
reason text,
|
|
resolved bool not null default false,
|
|
user_id int references user_ on update cascade on delete cascade not null, -- user reporting comment
|
|
comment_id int references comment on update cascade on delete cascade not null, -- comment being reported
|
|
comment_text text not null,
|
|
comment_time timestamp not null,
|
|
unique(comment_id, user_id) -- users should only be able to report a comment once
|
|
);
|
|
|
|
create table post_report (
|
|
id uuid primary key default uuid_generate_v4(),
|
|
time timestamp not null default now(),
|
|
reason text,
|
|
resolved bool not null default false,
|
|
user_id int references user_ on update cascade on delete cascade not null, -- user reporting post
|
|
post_id int references post on update cascade on delete cascade not null, -- post being reported
|
|
post_name varchar(100) not null,
|
|
post_url text,
|
|
post_body text,
|
|
post_time timestamp not null,
|
|
unique(post_id, user_id) -- users should only be able to report a post once
|
|
);
|
|
|
|
create or replace view comment_report_view as
|
|
select cr.*,
|
|
c.post_id,
|
|
p.community_id,
|
|
f.name as user_name,
|
|
u.id as creator_id,
|
|
u.name as creator_name
|
|
from comment_report cr
|
|
left join comment c on c.id = cr.comment_id
|
|
left join post p on p.id = c.post_id
|
|
left join user_ u on u.id = c.creator_id
|
|
left join user_ f on f.id = cr.user_id;
|
|
|
|
create or replace view post_report_view as
|
|
select pr.*,
|
|
p.community_id,
|
|
f.name as user_name,
|
|
u.id as creator_id,
|
|
u.name as creator_name
|
|
from post_report pr
|
|
left join post p on p.id = pr.post_id
|
|
left join user_ u on u.id = p.creator_id
|
|
left join user_ f on f.id = pr.user_id;
|