logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma
commit: ea57e42b257ac49c1e9383fac8e5d8d6d961b8c8
parent: 10e40206c6890cc1d88a391ab620ef859ed71521
Author: lambadalambda <gitgud@rogerbraun.net>
Date:   Mon,  4 Sep 2017 14:49:55 -0400

Merge branch 'deletions' into 'develop'

Deletions

See merge request !26

Diffstat:

Mlib/pleroma/web/activity_pub/activity_pub.ex17+++++++++++++++++
Mlib/pleroma/web/ostatus/activity_representer.ex19+++++++++++++++++++
Mlib/pleroma/web/ostatus/handlers/delete_handler.ex9++++-----
Mlib/pleroma/web/router.ex1+
Mlib/pleroma/web/twitter_api/representers/activity_representer.ex20++++++++++++++++++++
Mlib/pleroma/web/twitter_api/twitter_api.ex6++++++
Mlib/pleroma/web/twitter_api/twitter_api_controller.ex13++++++++++++-
Mtest/web/activity_pub/activity_pub_test.exs16++++++++++++++++
Mtest/web/ostatus/activity_representer_test.exs23+++++++++++++++++++++++
Mtest/web/ostatus/incoming_documents/delete_handling_test.exs4+++-
Mtest/web/twitter_api/representers/activity_representer_test.exs13+++++++++++++
11 files changed, 134 insertions(+), 7 deletions(-)

diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -75,6 +75,23 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do end end + def delete(%Object{data: %{"id" => id, "actor" => actor}} = object, local \\ true) do + user = User.get_cached_by_ap_id(actor) + data = %{ + "type" => "Delete", + "actor" => actor, + "object" => id, + "to" => [user.follower_address, "https://www.w3.org/ns/activitystreams#Public"] + } + with 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)), + {:ok, activity} <- insert(data, local), + :ok <- maybe_federate(activity) do + {:ok, activity} + end + end + def fetch_activities_for_context(context) do query = from activity in Activity, where: fragment("? @> ?", activity.data, ^%{ type: "Create", context: context }), diff --git a/lib/pleroma/web/ostatus/activity_representer.ex b/lib/pleroma/web/ostatus/activity_representer.ex @@ -199,6 +199,25 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenter do ] ++ mentions ++ author end + def to_simple_form(%{data: %{"type" => "Delete"}} = activity, user, with_author) do + h = fn(str) -> [to_charlist(str)] end + + updated_at = activity.data["published"] + inserted_at = activity.data["published"] + + author = if with_author, do: [{:author, UserRepresenter.to_simple_form(user)}], else: [] + + [ + {:"activity:object-type", ['http://activitystrea.ms/schema/1.0/activity']}, + {:"activity:verb", ['http://activitystrea.ms/schema/1.0/delete']}, + {:id, h.(activity.data["object"])}, + {:title, ['An object was deleted']}, + {:content, [type: 'html'], ['An object was deleted']}, + {:published, h.(inserted_at)}, + {:updated, h.(updated_at)} + ] ++ author + end + def wrap_with_entry(simple_form) do [{ :entry, [ diff --git a/lib/pleroma/web/ostatus/handlers/delete_handler.ex b/lib/pleroma/web/ostatus/handlers/delete_handler.ex @@ -2,14 +2,13 @@ defmodule Pleroma.Web.OStatus.DeleteHandler do require Logger alias Pleroma.Web.{XML, OStatus} alias Pleroma.{Activity, Object, Repo} + alias Pleroma.Web.ActivityPub.ActivityPub def handle_delete(entry, doc \\ nil) 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 + object when not is_nil(object) <- Object.get_by_ap_id(id), + {:ok, delete} <- ActivityPub.delete(object, false) do + delete end end end diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex @@ -82,6 +82,7 @@ defmodule Pleroma.Web.Router do post "/statuses/update", TwitterAPI.Controller, :status_update post "/statuses/retweet/:id", TwitterAPI.Controller, :retweet + post "/statuses/destroy/:id", TwitterAPI.Controller, :delete_post post "/friendships/create", TwitterAPI.Controller, :follow post "/friendships/destroy", TwitterAPI.Controller, :unfollow diff --git a/lib/pleroma/web/twitter_api/representers/activity_representer.ex b/lib/pleroma/web/twitter_api/representers/activity_representer.ex @@ -96,6 +96,25 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do } end + def to_map(%Activity{data: %{"type" => "Delete", "published" => created_at, "object" => deleted_object }} = activity, %{user: user} = opts) do + created_at = created_at |> Utils.date_to_asctime + + %{ + "id" => activity.id, + "uri" => activity.data["object"], + "user" => UserView.render("show.json", %{user: user, for: opts[:for]}), + "attentions" => [], + "statusnet_html" => "deleted notice {{tag", + "text" => "deleted notice {{tag" , + "is_local" => activity.local, + "is_post_verb" => false, + "created_at" => created_at, + "in_reply_to_status_id" => nil, + "external_url" => activity.data["id"], + "activity_type" => "delete" + } + end + def to_map(%Activity{data: %{"object" => %{"content" => content} = object}} = activity, %{user: user} = opts) do created_at = object["published"] |> Utils.date_to_asctime like_count = object["like_count"] || 0 @@ -117,6 +136,7 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do %{ "id" => activity.id, + "uri" => activity.data["object"]["id"], "user" => UserView.render("show.json", %{user: user, for: opts[:for]}), "statusnet_html" => HtmlSanitizeEx.basic_html(content) |> Formatter.finmojifiy, "text" => HtmlSanitizeEx.strip_tags(content), diff --git a/lib/pleroma/web/twitter_api/twitter_api.ex b/lib/pleroma/web/twitter_api/twitter_api.ex @@ -265,6 +265,12 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do ActivityRepresenter.to_map(activity, Map.merge(opts, %{users: [user, announced_actor], announced_activity: announced_activity})) end + defp activity_to_status(%Activity{data: %{"type" => "Delete"}} = activity, opts) do + actor = get_in(activity.data, ["actor"]) + user = User.get_cached_by_ap_id(actor) + ActivityRepresenter.to_map(activity, Map.merge(opts, %{user: user})) + end + defp activity_to_status(activity, opts) do actor = get_in(activity.data, ["actor"]) user = User.get_cached_by_ap_id(actor) diff --git a/lib/pleroma/web/twitter_api/twitter_api_controller.ex b/lib/pleroma/web/twitter_api/twitter_api_controller.ex @@ -2,7 +2,7 @@ defmodule Pleroma.Web.TwitterAPI.Controller do use Pleroma.Web, :controller alias Pleroma.Web.TwitterAPI.{TwitterAPI, UserView} alias Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter - alias Pleroma.{Repo, Activity, User} + alias Pleroma.{Repo, Activity, User, Object} alias Pleroma.Web.ActivityPub.ActivityPub alias Ecto.Changeset @@ -94,6 +94,17 @@ defmodule Pleroma.Web.TwitterAPI.Controller do end end + def delete_post(%{assigns: %{user: user}} = conn, %{"id" => id}) do + with %Activity{data: %{"object" => %{"id" => object_id}}} <- Repo.get(Activity, id), + %Object{} = object <- Object.get_by_ap_id(object_id), + true <- user.ap_id == object.data["actor"], + {:ok, delete} <- ActivityPub.delete(object) |> IO.inspect do + json = ActivityRepresenter.to_json(delete, %{user: user, for: user}) + conn + |> json_reply(200, json) + end + end + def unfollow(%{assigns: %{user: user}} = conn, params) do case TwitterAPI.unfollow(user, params) do {:ok, user, unfollowed} -> diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs @@ -246,6 +246,22 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do end end + describe "deletion" do + test "it creates a delete activity and deletes the original object" do + note = insert(:note_activity) + object = Object.get_by_ap_id(note.data["object"]["id"]) + {:ok, delete} = ActivityPub.delete(object) + + assert delete.data["type"] == "Delete" + assert delete.data["actor"] == note.data["actor"] + assert delete.data["object"] == note.data["object"]["id"] + + assert Repo.get(Activity, delete.id) != nil + + assert Repo.get(Object, object.id) == nil + end + end + def data_uri do "" end diff --git a/test/web/ostatus/activity_representer_test.exs b/test/web/ostatus/activity_representer_test.exs @@ -225,6 +225,29 @@ defmodule Pleroma.Web.OStatus.ActivityRepresenterTest do assert clean(res) == clean(expected) end + test "a delete" do + user = insert(:user) + activity = %Activity{data: %{ "id" => "ap_id", "type" => "Delete", "actor" => user.ap_id, "object" => "some_id", "published" => "2017-06-18T12:00:18+00:00" }} + + tuple = ActivityRepresenter.to_simple_form(activity, nil) + + refute is_nil(tuple) + + res = :xmerl.export_simple_content(tuple, :xmerl_xml) |> IO.iodata_to_binary + + expected = """ + <activity:object-type>http://activitystrea.ms/schema/1.0/activity</activity:object-type> + <activity:verb>http://activitystrea.ms/schema/1.0/delete</activity:verb> + <id>#{activity.data["object"]}</id> + <title>An object was deleted</title> + <content type="html">An object was deleted</content> + <published>#{activity.data["published"]}</published> + <updated>#{activity.data["published"]}</updated> + """ + + assert clean(res) == clean(expected) + end + test "an unknown activity" do tuple = ActivityRepresenter.to_simple_form(%Activity{}, nil) assert is_nil(tuple) diff --git a/test/web/ostatus/incoming_documents/delete_handling_test.exs b/test/web/ostatus/incoming_documents/delete_handling_test.exs @@ -16,13 +16,15 @@ defmodule Pleroma.Web.OStatus.DeleteHandlingTest do 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) + {:ok, [delete]} = 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"]) + + assert delete.data["type"] == "Delete" end end end diff --git a/test/web/twitter_api/representers/activity_representer_test.exs b/test/web/twitter_api/representers/activity_representer_test.exs @@ -148,4 +148,17 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do assert map["is_post_verb"] == false assert map["activity_type"] == "undo" end + + test "a delete activity" do + object = insert(:note) + user = User.get_by_ap_id(object.data["actor"]) + + {:ok, delete} = ActivityPub.delete(object) + + map = ActivityRepresenter.to_map(delete, %{user: user}) + + assert map["is_post_verb"] == false + assert map["activity_type"] == "delete" + assert map["id"] == object.data["id"] + end end