diff options
author | William Pitcock <nenolod@dereferenced.org> | 2018-11-10 12:04:09 +0000 |
---|---|---|
committer | William Pitcock <nenolod@dereferenced.org> | 2018-11-10 12:04:09 +0000 |
commit | f8310114a6a4154118e54ebaac6f4a96941be4a6 (patch) | |
tree | adc53b8885ba2ab1599786fa260b06872d5f3ddd | |
parent | c9c1f9dee2fe12fe55703255497f4a14eb0d4e13 (diff) | |
download | pleroma-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.ex | 14 |
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 |