X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Factivity.ex;h=d06fd917d9921d06c12f93de02ba016bd13ed001;hb=dd097a406baf15e983454ab8f13635b4af2a8de4;hp=ab8861b277b7683660e6ca031dd8f69db664522c;hpb=b4da2bc1d009ecca0d7821abe3577d1a920c41c0;p=akkoma diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex index ab8861b27..d06fd917d 100644 --- a/lib/pleroma/activity.ex +++ b/lib/pleroma/activity.ex @@ -98,7 +98,10 @@ defmodule Pleroma.Activity do end def get_by_id(id) do - Repo.get(Activity, id) + Activity + |> where([a], a.id == ^id) + |> restrict_deactivated_users() + |> Repo.one() end def get_by_id_with_object(id) do @@ -166,6 +169,7 @@ defmodule Pleroma.Activity do def get_create_by_object_ap_id(ap_id) when is_binary(ap_id) do create_by_object_ap_id(ap_id) + |> restrict_deactivated_users() |> Repo.one() end @@ -291,4 +295,14 @@ defmodule Pleroma.Activity do _ -> {:error, "Not found"} end end + + def restrict_deactivated_users(query) do + from(activity in query, + where: + fragment( + "? not in (SELECT ap_id FROM users WHERE info->'deactivated' @> 'true')", + activity.actor + ) + ) + end end