diff options
author | Sachin Joshi <satchin.joshi@gmail.com> | 2019-07-12 22:19:30 +0545 |
---|---|---|
committer | Sachin Joshi <satchin.joshi@gmail.com> | 2019-07-12 22:56:14 +0545 |
commit | f8e3ae61545de45ce4dd395471149ed1e71e0343 (patch) | |
tree | bbd6205bfe1bf3ed84c4a1f06a13707245cd980a /lib | |
parent | b6567c9f4e290ba8ad928c9ed10e72d2589dd89a (diff) | |
download | pleroma-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.ex | 7 |
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 |