Fix deletion not deleting relevant actions.
authorRoger Braun <roger@rogerbraun.net>
Wed, 16 Aug 2017 14:29:25 +0000 (16:29 +0200)
committerRoger Braun <roger@rogerbraun.net>
Wed, 16 Aug 2017 14:29:25 +0000 (16:29 +0200)
lib/pleroma/activity.ex
lib/pleroma/web/ostatus/handlers/delete_handler.ex
test/web/ostatus/incoming_documents/delete_handling_test.exs

index 0b7188abaea64c990a06464140b8b164c2f473ff..f226c4c5f351d797a9eac90bc835645c230c10bd 100644 (file)
@@ -15,11 +15,17 @@ defmodule Pleroma.Activity do
       where: fragment("(?)->>'id' = ?", activity.data, ^to_string(ap_id)))
   end
 
+  # Wrong name, only returns create activities
   def all_by_object_ap_id_q(ap_id) do
     from activity in Activity,
       where: fragment("(?)->'object'->>'id' = ?", activity.data, ^to_string(ap_id))
   end
 
+  def all_non_create_by_object_ap_id_q(ap_id) do
+    from activity in Activity,
+      where: fragment("(?)->>'object' = ?", activity.data, ^to_string(ap_id))
+  end
+
   def all_by_object_ap_id(ap_id) do
     Repo.all(all_by_object_ap_id_q(ap_id))
   end
index 2e5f9469b9b7f11cc8533ced4557a065fa40d29f..f54a037a0ef3cdf56e5ff9b70b7f8c40b76806fc 100644 (file)
@@ -7,6 +7,7 @@ defmodule Pleroma.Web.OStatus.DeleteHandler do
     with id <- XML.string_from_xpath("//id", entry),
          object when not is_nil(object) <- Object.get_by_ap_id(id) do
       Repo.delete(object)
+      Repo.delete_all(Activity.all_non_create_by_object_ap_id_q(id))
       Repo.delete_all(Activity.all_by_object_ap_id_q(id))
       nil
     end
index 8cd6e295e9807b0c33cb11cd35e5944c0c842a2b..989c87afa14fd4a6258b198b725243541de19bdf 100644 (file)
@@ -9,12 +9,17 @@ defmodule Pleroma.Web.OStatus.DeleteHandlingTest do
     test "it removes the mentioned activity" do
       note = insert(:note_activity)
       second_note = insert(:note_activity)
+      user = insert(:user)
+      object = Object.get_by_ap_id(note.data["object"]["id"])
+
+      {:ok, like, object} = Pleroma.Web.ActivityPub.ActivityPub.like(user, object)
 
       incoming = File.read!("test/fixtures/delete.xml")
       |> String.replace("tag:mastodon.sdf.org,2017-06-10:objectId=310513:objectType=Status", note.data["object"]["id"])
       {:ok, []} = OStatus.handle_incoming(incoming)
 
       refute Repo.get(Activity, note.id)
+      refute Repo.get(Activity, like.id)
       refute Object.get_by_ap_id(note.data["object"]["id"])
       assert Repo.get(Activity, second_note.id)
       assert Object.get_by_ap_id(second_note.data["object"]["id"])