aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorSachin Joshi <satchin.joshi@gmail.com>2019-07-12 22:19:30 +0545
committerSachin Joshi <satchin.joshi@gmail.com>2019-07-12 22:56:14 +0545
commitf8e3ae61545de45ce4dd395471149ed1e71e0343 (patch)
treebbd6205bfe1bf3ed84c4a1f06a13707245cd980a /lib
parentb6567c9f4e290ba8ad928c9ed10e72d2589dd89a (diff)
downloadpleroma-f8e3ae61545de45ce4dd395471149ed1e71e0343.tar.gz
try to always match the filename for proxy url
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/media_proxy/controller.ex7
1 files changed, 6 insertions, 1 deletions
diff --git a/lib/pleroma/web/media_proxy/controller.ex b/lib/pleroma/web/media_proxy/controller.ex
index ea33d7685..a711b54e9 100644
--- a/lib/pleroma/web/media_proxy/controller.ex
+++ b/lib/pleroma/web/media_proxy/controller.ex
@@ -30,10 +30,15 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do
def filename_matches(has_filename, path, url) do
filename = url |> MediaProxy.filename()
- if has_filename && filename && Path.basename(path) != filename do
+ if has_filename && filename && does_not_match(path, filename) do
{:wrong_filename, filename}
else
:ok
end
end
+
+ defp does_not_match(path, filename) do
+ basename = Path.basename(path)
+ basename != filename and URI.decode(basename) != filename and URI.encode(basename) != filename
+ end
end