mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-10 12:05:57 +00:00
116 lines
3.1 KiB
MySQL
116 lines
3.1 KiB
MySQL
|
-- Edit community aggregates to include voters as active users
|
||
|
CREATE OR REPLACE FUNCTION community_aggregates_activity (i text)
|
||
|
RETURNS TABLE (
|
||
|
count_ bigint,
|
||
|
community_id_ integer)
|
||
|
LANGUAGE plpgsql
|
||
|
AS $$
|
||
|
BEGIN
|
||
|
RETURN query
|
||
|
SELECT
|
||
|
count(*),
|
||
|
community_id
|
||
|
FROM (
|
||
|
SELECT
|
||
|
c.creator_id,
|
||
|
p.community_id
|
||
|
FROM
|
||
|
comment c
|
||
|
INNER JOIN post p ON c.post_id = p.id
|
||
|
INNER JOIN person pe ON c.creator_id = pe.id
|
||
|
WHERE
|
||
|
c.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.bot_account = FALSE
|
||
|
UNION
|
||
|
SELECT
|
||
|
p.creator_id,
|
||
|
p.community_id
|
||
|
FROM
|
||
|
post p
|
||
|
INNER JOIN person pe ON p.creator_id = pe.id
|
||
|
WHERE
|
||
|
p.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.bot_account = FALSE
|
||
|
UNION
|
||
|
SELECT
|
||
|
pl.person_id,
|
||
|
p.community_id
|
||
|
FROM
|
||
|
post_like pl
|
||
|
INNER JOIN post p ON pl.post_id = p.id
|
||
|
INNER JOIN person pe ON pl.person_id = pe.id
|
||
|
WHERE
|
||
|
pl.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.bot_account = FALSE
|
||
|
UNION
|
||
|
SELECT
|
||
|
cl.person_id,
|
||
|
p.community_id
|
||
|
FROM
|
||
|
comment_like cl
|
||
|
INNER JOIN comment c ON cl.comment_id = comment.id
|
||
|
INNER JOIN post p ON comment.post_id = p.id
|
||
|
INNER JOIN person pe ON cl.person_id = pe.id
|
||
|
WHERE
|
||
|
cl.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.bot_account = FALSE) a
|
||
|
GROUP BY
|
||
|
community_id;
|
||
|
END;
|
||
|
$$;
|
||
|
|
||
|
-- Edit site aggregates to include voters and people who have read posts as active users
|
||
|
CREATE OR REPLACE FUNCTION site_aggregates_activity (i text)
|
||
|
RETURNS integer
|
||
|
LANGUAGE plpgsql
|
||
|
AS $$
|
||
|
DECLARE
|
||
|
count_ integer;
|
||
|
BEGIN
|
||
|
SELECT
|
||
|
count(*) INTO count_
|
||
|
FROM (
|
||
|
SELECT
|
||
|
c.creator_id
|
||
|
FROM
|
||
|
comment c
|
||
|
INNER JOIN person pe ON c.creator_id = pe.id
|
||
|
WHERE
|
||
|
c.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.local = TRUE
|
||
|
AND pe.bot_account = FALSE
|
||
|
UNION
|
||
|
SELECT
|
||
|
p.creator_id
|
||
|
FROM
|
||
|
post p
|
||
|
INNER JOIN person pe ON p.creator_id = pe.id
|
||
|
WHERE
|
||
|
p.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.local = TRUE
|
||
|
AND pe.bot_account = FALSE
|
||
|
UNION
|
||
|
SELECT
|
||
|
pl.person_id
|
||
|
FROM
|
||
|
post_like pl
|
||
|
INNER JOIN person pe ON pl.person_id = pe.id
|
||
|
WHERE
|
||
|
pl.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.local = TRUE
|
||
|
AND pe.bot_account = FALSE
|
||
|
UNION
|
||
|
SELECT
|
||
|
cl.person_id
|
||
|
FROM
|
||
|
comment_like cl
|
||
|
INNER JOIN person pe ON cl.person_id = pe.id
|
||
|
WHERE
|
||
|
cl.published > ('now'::timestamp - i::interval)
|
||
|
AND pe.local = TRUE
|
||
|
AND pe.bot_account = FALSE) a;
|
||
|
RETURN count_;
|
||
|
END;
|
||
|
$$;
|
||
|
|