From: Sachin Joshi Date: Mon, 15 Jul 2019 15:45:56 +0000 (+0545) Subject: Merge branch 'develop' into match-file-name X-Git-Url: https://git.squeep.com/?a=commitdiff_plain;h=1d906ffa82633af21233c3030fbe2d127b5b77f9;p=akkoma Merge branch 'develop' into match-file-name # Conflicts: # lib/pleroma/web/media_proxy/media_proxy_controller.ex --- 1d906ffa82633af21233c3030fbe2d127b5b77f9 diff --cc lib/pleroma/web/media_proxy/media_proxy_controller.ex index a711b54e9,1e9520d46..8403850ff --- a/lib/pleroma/web/media_proxy/media_proxy_controller.ex +++ b/lib/pleroma/web/media_proxy/media_proxy_controller.ex @@@ -27,18 -27,15 +27,20 @@@ defmodule Pleroma.Web.MediaProxy.MediaP end end - def filename_matches(has_filename, path, url) do - filename = url |> MediaProxy.filename() + def filename_matches(%{"filename" => _} = _, path, url) do + filename = MediaProxy.filename(url) - if has_filename && filename && does_not_match(path, filename) do - if filename && Path.basename(path) != filename do ++ if filename && does_not_match(path, filename) do {:wrong_filename, filename} else :ok end 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 diff --cc test/web/media_proxy/media_proxy_test.exs index 176b09914,cb4807e0b..edbbf9b66 --- a/test/web/media_proxy/media_proxy_test.exs +++ b/test/web/media_proxy/media_proxy_test.exs @@@ -106,19 -106,14 +106,25 @@@ defmodule Pleroma.Web.MediaProxyTest d "/my%2Flong%2Furl%2F2019%2F07%2FS.jpg", "http://pleroma.social/my%2Flong%2Furl%2F2019%2F07%2FS.jpg" ) == :ok + + assert MediaProxyController.filename_matches( + %{"filename" => "/my%2Flong%2Furl%2F2019%2F07%2FS.jp"}, + "/my%2Flong%2Furl%2F2019%2F07%2FS.jp", + "http://pleroma.social/my%2Flong%2Furl%2F2019%2F07%2FS.jpg" + ) == {:wrong_filename, "my%2Flong%2Furl%2F2019%2F07%2FS.jpg"} end + test "encoded url are tried to match for proxy as `conn.request_path` encodes the url" do + # conn.request_path will return encoded url + request_path = "/ANALYSE-DAI-_-LE-STABLECOIN-100-D%C3%89CENTRALIS%C3%89-BQ.jpg" + + assert MediaProxyController.filename_matches( + true, + request_path, + "https://mydomain.com/uploads/2019/07/ANALYSE-DAI-_-LE-STABLECOIN-100-DÉCENTRALISÉ-BQ.jpg" + ) == :ok + end + test "uses the configured base_url" do base_url = Pleroma.Config.get([:media_proxy, :base_url])