summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIvan Tashkinov <ivantashkinov@gmail.com>2020-09-12 11:20:41 +0300
committerIvan Tashkinov <ivantashkinov@gmail.com>2020-09-12 11:20:41 +0300
commitcd234a5321b9d33146b90be95d84fa67aa4f7707 (patch)
treef8aa0c27bb1953329658a9742de195ccb5240d0a
parent32831f371ff426ac0c6f5d6c1381313f5f92af42 (diff)
[#2497] Media preview proxy: preview bypass for small images
(basing on Content-Length and Content-Type).
-rw-r--r--lib/pleroma/web/media_proxy/media_proxy_controller.ex25
1 files changed, 19 insertions, 6 deletions
diff --git a/lib/pleroma/web/media_proxy/media_proxy_controller.ex b/lib/pleroma/web/media_proxy/media_proxy_controller.ex
index 08d62a51a..78df7763e 100644
--- a/lib/pleroma/web/media_proxy/media_proxy_controller.ex
+++ b/lib/pleroma/web/media_proxy/media_proxy_controller.ex
@@ -11,6 +11,8 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do
alias Pleroma.Web.MediaProxy
alias Plug.Conn
+ @min_content_length_for_preview 100 * 1024
+
def remote(conn, %{"sig" => sig64, "url" => url64}) do
with {_, true} <- {:enabled, MediaProxy.enabled?()},
{:ok, url} <- MediaProxy.decode_url(sig64, url64),
@@ -54,8 +56,12 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do
with {:ok, %{status: status} = head_response} when status in 200..299 <-
Pleroma.HTTP.request("head", media_proxy_url, [], [], pool: :media) do
content_type = Tesla.get_header(head_response, "content-type")
- handle_preview(content_type, conn, media_proxy_url)
+ content_length = Tesla.get_header(head_response, "content-length")
+ content_length = content_length && String.to_integer(content_length)
+
+ handle_preview(content_type, content_length, conn, media_proxy_url)
else
+ # If HEAD failed, redirecting to media proxy URI doesn't make much sense; returning an error
{_, %{status: status}} ->
send_resp(conn, :failed_dependency, "Can't fetch HTTP headers (HTTP #{status}).")
@@ -69,29 +75,36 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do
defp handle_preview(
"image/" <> _ = _content_type,
+ _content_length,
%{params: %{"output_format" => "jpeg"}} = conn,
media_proxy_url
) do
handle_jpeg_preview(conn, media_proxy_url)
end
- defp handle_preview("image/gif" = _content_type, conn, media_proxy_url) do
+ defp handle_preview("image/gif" = _content_type, _content_length, conn, media_proxy_url) do
+ redirect(conn, external: media_proxy_url)
+ end
+
+ defp handle_preview("image/" <> _ = _content_type, content_length, conn, media_proxy_url)
+ when is_integer(content_length) and content_length > 0 and
+ content_length < @min_content_length_for_preview do
redirect(conn, external: media_proxy_url)
end
- defp handle_preview("image/png" <> _ = _content_type, conn, media_proxy_url) do
+ defp handle_preview("image/png" <> _ = _content_type, _content_length, conn, media_proxy_url) do
handle_png_preview(conn, media_proxy_url)
end
- defp handle_preview("image/" <> _ = _content_type, conn, media_proxy_url) do
+ defp handle_preview("image/" <> _ = _content_type, _content_length, conn, media_proxy_url) do
handle_jpeg_preview(conn, media_proxy_url)
end
- defp handle_preview("video/" <> _ = _content_type, conn, media_proxy_url) do
+ defp handle_preview("video/" <> _ = _content_type, _content_length, conn, media_proxy_url) do
handle_video_preview(conn, media_proxy_url)
end
- defp handle_preview(_unsupported_content_type, conn, media_proxy_url) do
+ defp handle_preview(_unsupported_content_type, _content_length, conn, media_proxy_url) do
fallback_on_preview_error(conn, media_proxy_url)
end