diff options
author | Mark Felder <feld@feld.me> | 2023-05-26 12:08:50 -0400 |
---|---|---|
committer | Mark Felder <feld@feld.me> | 2023-05-26 12:34:01 -0400 |
commit | 38bcf6b19e3d83cb6c4e6c82d237a26edcab167a (patch) | |
tree | 348c7672584d44fa028ed1fb61a2478714a56c2f /lib | |
parent | 5433742faf0acfe759799c1b7907b1aff44ecaf3 (diff) | |
download | pleroma-38bcf6b19e3d83cb6c4e6c82d237a26edcab167a.tar.gz pleroma-38bcf6b19e3d83cb6c4e6c82d237a26edcab167a.zip |
MediaProxyController: Apply CSP sandbox
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/media_proxy/media_proxy_controller.ex | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/pleroma/web/media_proxy/media_proxy_controller.ex b/lib/pleroma/web/media_proxy/media_proxy_controller.ex index d2ad62c13..bda5b36ed 100644 --- a/lib/pleroma/web/media_proxy/media_proxy_controller.ex +++ b/lib/pleroma/web/media_proxy/media_proxy_controller.ex @@ -12,6 +12,8 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do alias Pleroma.Web.MediaProxy alias Plug.Conn + plug(:sandbox) + def remote(conn, %{"sig" => sig64, "url" => url64}) do with {_, true} <- {:enabled, MediaProxy.enabled?()}, {:ok, url} <- MediaProxy.decode_url(sig64, url64), @@ -202,4 +204,9 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do defp media_proxy_opts do Config.get([:media_proxy, :proxy_opts], []) end + + defp sandbox(conn, _params) do + conn + |> merge_resp_headers([{"content-security-policy", "sandbox;"}]) + end end |