1 defmodule Pleroma.Repo.Migrations.AddVisibilityFunction do
6 create or replace function activity_visibility(actor varchar, recipients varchar[], data jsonb) returns varchar as $$
9 public varchar := 'https://www.w3.org/ns/activitystreams#Public';
11 SELECT COALESCE(users.follower_address, '') into fa from users where users.ap_id = actor;
13 IF data->'to' ? public THEN
15 ELSIF data->'cc' ? public THEN
17 ELSIF ARRAY[fa] && recipients THEN
19 ELSIF not(ARRAY[fa, public] && recipients) THEN
25 $$ LANGUAGE plpgsql IMMUTABLE;
31 index(:activities, ["activity_visibility(actor, recipients, data)"],
32 name: :activities_visibility_index
39 index(:activities, ["activity_visibility(actor, recipients, data)"],
40 name: :activities_visibility_index
44 execute("drop function activity_visibility(actor varchar, recipients varchar[], data jsonb)")