Bladeren bron

Merge branch 'mr/20190122-activity-visibility-update' into 'develop'

slightly changes definition so that autovacuum works parallel safe too

Closes #540

See merge request pleroma/pleroma!697
tags/v0.9.9
href 5 jaren geleden
bovenliggende
commit
b624b7a150
1 gewijzigde bestanden met toevoegingen van 36 en 0 verwijderingen
  1. +36
    -0
      priv/repo/migrations/20190122153157_update_activity_visibility.exs

+ 36
- 0
priv/repo/migrations/20190122153157_update_activity_visibility.exs Bestand weergeven

@@ -0,0 +1,36 @@
defmodule Pleroma.Repo.Migrations.UpdateActivityVisibility do
use Ecto.Migration
@disable_ddl_transaction true

def up do
definition = """
create or replace function activity_visibility(actor varchar, recipients varchar[], data jsonb) returns varchar as $$
DECLARE
fa varchar;
public varchar := 'https://www.w3.org/ns/activitystreams#Public';
BEGIN
SELECT COALESCE(users.follower_address, '') into fa from users where users.ap_id = actor;

IF data->'to' ? public THEN
RETURN 'public';
ELSIF data->'cc' ? public THEN
RETURN 'unlisted';
ELSIF ARRAY[fa] && recipients THEN
RETURN 'private';
ELSIF not(ARRAY[fa, public] && recipients) THEN
RETURN 'direct';
ELSE
RETURN 'unknown';
END IF;
END;
$$ LANGUAGE plpgsql IMMUTABLE PARALLEL SAFE SECURITY DEFINER;
"""

execute(definition)

end

def down do

end
end

Laden…
Annuleren
Opslaan