summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWilliam Pitcock <nenolod@dereferenced.org>2018-11-10 12:04:09 +0000
committerWilliam Pitcock <nenolod@dereferenced.org>2018-11-10 12:04:09 +0000
commitf8310114a6a4154118e54ebaac6f4a96941be4a6 (patch)
treeadc53b8885ba2ab1599786fa260b06872d5f3ddd
parentc9c1f9dee2fe12fe55703255497f4a14eb0d4e13 (diff)
downloadpleroma-f8310114a6a4154118e54ebaac6f4a96941be4a6.tar.gz
pleroma-f8310114a6a4154118e54ebaac6f4a96941be4a6.zip
activitypub: object view: sanitize both the activity and the object when an activity is given for rendering
-rw-r--r--lib/pleroma/web/activity_pub/views/object_view.ex14
1 files changed, 13 insertions, 1 deletions
diff --git a/lib/pleroma/web/activity_pub/views/object_view.ex b/lib/pleroma/web/activity_pub/views/object_view.ex
index df734a871..1911ddfb7 100644
--- a/lib/pleroma/web/activity_pub/views/object_view.ex
+++ b/lib/pleroma/web/activity_pub/views/object_view.ex
@@ -1,11 +1,23 @@
defmodule Pleroma.Web.ActivityPub.ObjectView do
use Pleroma.Web, :view
+ alias Pleroma.{Object, Activity}
alias Pleroma.Web.ActivityPub.Transmogrifier
- def render("object.json", %{object: object}) do
+ def render("object.json", %{object: %Object{} = object}) do
base = Pleroma.Web.ActivityPub.Utils.make_json_ld_header()
additional = Transmogrifier.prepare_object(object.data)
Map.merge(base, additional)
end
+
+ def render("object.json", %{object: %Activity{} = activity}) do
+ base = Pleroma.Web.ActivityPub.Utils.make_json_ld_header()
+ object = Object.normalize(activity.data["object"])
+
+ additional =
+ Transmogrifier.prepare_object(activity.data)
+ |> Map.put("object", Transmogrifier.prepare_object(object.data))
+
+ Map.merge(base, additional)
+ end
end