diff options
| -rw-r--r-- | lib/mix/tasks/pleroma/database.ex | 18 | ||||
| -rw-r--r-- | lib/pleroma/activity_expiration.ex | 1 | ||||
| -rw-r--r-- | lib/pleroma/web/activity_pub/side_effects.ex | 12 | ||||
| -rw-r--r-- | priv/repo/migrations/20200808173046_only_expire_creates.exs | 19 | ||||
| -rw-r--r-- | test/web/activity_pub/side_effects_test.exs | 19 | 
5 files changed, 64 insertions, 5 deletions
| diff --git a/lib/mix/tasks/pleroma/database.ex b/lib/mix/tasks/pleroma/database.ex index d57e59b11..0142071a8 100644 --- a/lib/mix/tasks/pleroma/database.ex +++ b/lib/mix/tasks/pleroma/database.ex @@ -134,14 +134,28 @@ defmodule Mix.Tasks.Pleroma.Database do      Pleroma.Activity      |> join(:left, [a], u in assoc(a, :expiration)) +    |> join(:inner, [a, _u], o in Object, +      on: +        fragment( +          "(?->>'id') = COALESCE((?)->'object'->> 'id', (?)->>'object')", +          o.data, +          a.data, +          a.data +        ) +    )      |> where(local: true)      |> where([a, u], is_nil(u)) +    |> where([a], fragment("(? ->> 'type'::text) = 'Create'", a.data)) +    |> where([_a, _u, o], fragment("?->>'type' = 'Note'", o.data))      |> Pleroma.RepoStreamer.chunk_stream(100)      |> Stream.each(fn activities ->        Enum.each(activities, fn activity -> -        expires_at = Timex.shift(activity.inserted_at, days: days) +        user = User.get_cached_by_ap_id(activity.actor) -        Pleroma.ActivityExpiration.create(activity, expires_at, false) +        if activity.id not in user.pinned_activities do +          expires_at = Timex.shift(activity.inserted_at, days: days) +          Pleroma.ActivityExpiration.create(activity, expires_at, false) +        end        end)      end)      |> Stream.run() diff --git a/lib/pleroma/activity_expiration.ex b/lib/pleroma/activity_expiration.ex index 7cc9668b3..84edf68ef 100644 --- a/lib/pleroma/activity_expiration.ex +++ b/lib/pleroma/activity_expiration.ex @@ -46,6 +46,7 @@ defmodule Pleroma.ActivityExpiration do      ActivityExpiration      |> where([exp], exp.scheduled_at < ^naive_datetime) +    |> limit(50)      |> Repo.all()    end diff --git a/lib/pleroma/web/activity_pub/side_effects.ex b/lib/pleroma/web/activity_pub/side_effects.ex index 5104d38ee..bff7c6629 100644 --- a/lib/pleroma/web/activity_pub/side_effects.ex +++ b/lib/pleroma/web/activity_pub/side_effects.ex @@ -22,6 +22,8 @@ defmodule Pleroma.Web.ActivityPub.SideEffects do    alias Pleroma.Web.Streamer    alias Pleroma.Workers.BackgroundWorker +  require Logger +    def handle(object, meta \\ [])    # Tasks this handle @@ -217,13 +219,15 @@ defmodule Pleroma.Web.ActivityPub.SideEffects do    # - Stream out the activity    def handle(%{data: %{"type" => "Delete", "object" => deleted_object}} = object, meta) do      deleted_object = -      Object.normalize(deleted_object, false) || User.get_cached_by_ap_id(deleted_object) +      Object.normalize(deleted_object, false) || +        User.get_cached_by_ap_id(deleted_object)      result =        case deleted_object do          %Object{} ->            with {:ok, deleted_object, activity} <- Object.delete(deleted_object), -               %User{} = user <- User.get_cached_by_ap_id(deleted_object.data["actor"]) do +               {_, actor} when is_binary(actor) <- {:actor, deleted_object.data["actor"]}, +               %User{} = user <- User.get_cached_by_ap_id(actor) do              User.remove_pinnned_activity(user, activity)              {:ok, user} = ActivityPub.decrease_note_count_if_public(user, deleted_object) @@ -237,6 +241,10 @@ defmodule Pleroma.Web.ActivityPub.SideEffects do              ActivityPub.stream_out(object)              ActivityPub.stream_out_participations(deleted_object, user)              :ok +          else +            {:actor, _} -> +              Logger.error("The object doesn't have an actor: #{inspect(deleted_object)}") +              :no_object_actor            end          %User{} -> diff --git a/priv/repo/migrations/20200808173046_only_expire_creates.exs b/priv/repo/migrations/20200808173046_only_expire_creates.exs new file mode 100644 index 000000000..9df52956f --- /dev/null +++ b/priv/repo/migrations/20200808173046_only_expire_creates.exs @@ -0,0 +1,19 @@ +defmodule Pleroma.Repo.Migrations.OnlyExpireCreates do +  use Ecto.Migration + +  def up do +    statement = """ +    DELETE FROM +      activity_expirations a_exp USING activities a, objects o +    WHERE +      a_exp.activity_id = a.id AND (o.data->>'id') = COALESCE(a.data->'object'->>'id', a.data->>'object') +      AND (a.data->>'type' != 'Create' OR o.data->>'type' != 'Note'); +    """ + +    execute(statement) +  end + +  def down do +    :ok +  end +end diff --git a/test/web/activity_pub/side_effects_test.exs b/test/web/activity_pub/side_effects_test.exs index 4a08eb7ee..9efbaad04 100644 --- a/test/web/activity_pub/side_effects_test.exs +++ b/test/web/activity_pub/side_effects_test.exs @@ -19,8 +19,9 @@ defmodule Pleroma.Web.ActivityPub.SideEffectsTest do    alias Pleroma.Web.ActivityPub.SideEffects    alias Pleroma.Web.CommonAPI -  import Pleroma.Factory +  import ExUnit.CaptureLog    import Mock +  import Pleroma.Factory    describe "handle_after_transaction" do      test "it streams out notifications and streams" do @@ -221,6 +222,22 @@ defmodule Pleroma.Web.ActivityPub.SideEffectsTest do        assert User.get_cached_by_ap_id(user.ap_id).deactivated      end + +    test "it logs issues with objects deletion", %{ +      delete: delete, +      object: object +    } do +      {:ok, object} = +        object +        |> Object.change(%{data: Map.delete(object.data, "actor")}) +        |> Repo.update() + +      Object.invalid_object_cache(object) + +      assert capture_log(fn -> +               {:error, :no_object_actor} = SideEffects.handle(delete) +             end) =~ "object doesn't have an actor" +    end    end    describe "EmojiReact objects" do | 
