diff options
| author | lambda <pleromagit@rogerbraun.net> | 2018-11-17 22:43:45 +0000 | 
|---|---|---|
| committer | lambda <pleromagit@rogerbraun.net> | 2018-11-17 22:43:45 +0000 | 
| commit | 51435014269567d4d05e9961cd0fa884cfbbb072 (patch) | |
| tree | 97b704754516db4f929cf7bb79cc9c5a0365134a /lib | |
| parent | b471344b6361945aff94685db8d3065da0e5228a (diff) | |
| parent | f6be980f4faaef9408333fe59f0bb915dd087fd0 (diff) | |
| download | pleroma-51435014269567d4d05e9961cd0fa884cfbbb072.tar.gz pleroma-51435014269567d4d05e9961cd0fa884cfbbb072.zip | |
Merge branch 'security/as2-object-render-hardening' into 'develop'
activitypub: object view: avoid leaking private details
See merge request pleroma/pleroma!463
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/activity_pub/views/object_view.ex | 13 | 
1 files changed, 12 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 1911ddfb7..ff664636c 100644 --- a/lib/pleroma/web/activity_pub/views/object_view.ex +++ b/lib/pleroma/web/activity_pub/views/object_view.ex @@ -10,7 +10,7 @@ defmodule Pleroma.Web.ActivityPub.ObjectView do      Map.merge(base, additional)    end -  def render("object.json", %{object: %Activity{} = activity}) do +  def render("object.json", %{object: %Activity{data: %{"type" => "Create"}} = activity}) do      base = Pleroma.Web.ActivityPub.Utils.make_json_ld_header()      object = Object.normalize(activity.data["object"]) @@ -20,4 +20,15 @@ defmodule Pleroma.Web.ActivityPub.ObjectView do      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", object.data["id"]) + +    Map.merge(base, additional) +  end  end | 
