diff options
author | feld <feld@feld.me> | 2019-07-15 22:04:58 +0000 |
---|---|---|
committer | feld <feld@feld.me> | 2019-07-15 22:04:58 +0000 |
commit | 9f987dd017f352d63c7441e2cce301aea07082a8 (patch) | |
tree | 116c60eb6154344e4df2c59cd2a4d8b023948490 /lib | |
parent | 03bcb40883dafa2886110e2b625c4cc5c21106f1 (diff) | |
parent | 1d906ffa82633af21233c3030fbe2d127b5b77f9 (diff) | |
download | pleroma-9f987dd017f352d63c7441e2cce301aea07082a8.tar.gz |
Merge branch 'match-file-name' into 'develop'
try to always match the filename for proxy url
See merge request pleroma/pleroma!1405
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/media_proxy/media_proxy_controller.ex | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/lib/pleroma/web/media_proxy/media_proxy_controller.ex b/lib/pleroma/web/media_proxy/media_proxy_controller.ex index 1e9520d46..8403850ff 100644 --- a/lib/pleroma/web/media_proxy/media_proxy_controller.ex +++ b/lib/pleroma/web/media_proxy/media_proxy_controller.ex @@ -30,7 +30,7 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do def filename_matches(%{"filename" => _} = _, path, url) do filename = MediaProxy.filename(url) - if filename && Path.basename(path) != filename do + if filename && does_not_match(path, filename) do {:wrong_filename, filename} else :ok @@ -38,4 +38,9 @@ defmodule Pleroma.Web.MediaProxy.MediaProxyController do end def filename_matches(_, _, _), do: :ok + + 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 |