mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-24 07:58:10 +00:00
Pass remote follow avatar into media proxy
This commit is contained in:
parent
d91e9cee04
commit
2efc0ffcf0
2 changed files with 50 additions and 1 deletions
|
@ -6,5 +6,9 @@ defmodule Pleroma.Web.TwitterAPI.RemoteFollowView do
|
||||||
use Pleroma.Web, :view
|
use Pleroma.Web, :view
|
||||||
import Phoenix.HTML.Form
|
import Phoenix.HTML.Form
|
||||||
|
|
||||||
defdelegate avatar_url(user), to: Pleroma.User
|
def avatar_url(user) do
|
||||||
|
user
|
||||||
|
|> Pleroma.User.avatar_url()
|
||||||
|
|> Pleroma.Web.MediaProxy.url()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -410,4 +410,49 @@ defmodule Pleroma.Web.TwitterAPI.RemoteFollowControllerTest do
|
||||||
assert response =~ "Error following account"
|
assert response =~ "Error following account"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "avatar url" do
|
||||||
|
test "without media proxy" do
|
||||||
|
clear_config([:media_proxy, :enabled], false)
|
||||||
|
|
||||||
|
user =
|
||||||
|
insert(:user, %{
|
||||||
|
local: false,
|
||||||
|
avatar: %{"url" => [%{"href" => "https://remote.org/avatar.png"}]}
|
||||||
|
})
|
||||||
|
|
||||||
|
avatar_url = Pleroma.Web.TwitterAPI.RemoteFollowView.avatar_url(user)
|
||||||
|
|
||||||
|
assert avatar_url == "https://remote.org/avatar.png"
|
||||||
|
end
|
||||||
|
|
||||||
|
test "with media proxy" do
|
||||||
|
clear_config([:media_proxy, :enabled], true)
|
||||||
|
|
||||||
|
user =
|
||||||
|
insert(:user, %{
|
||||||
|
local: false,
|
||||||
|
avatar: %{"url" => [%{"href" => "https://remote.org/avatar.png"}]}
|
||||||
|
})
|
||||||
|
|
||||||
|
avatar_url = Pleroma.Web.TwitterAPI.RemoteFollowView.avatar_url(user)
|
||||||
|
url = Pleroma.Web.Endpoint.url()
|
||||||
|
|
||||||
|
assert String.starts_with?(avatar_url, url)
|
||||||
|
end
|
||||||
|
|
||||||
|
test "local avatar is not proxied" do
|
||||||
|
clear_config([:media_proxy, :enabled], true)
|
||||||
|
|
||||||
|
user =
|
||||||
|
insert(:user, %{
|
||||||
|
local: true,
|
||||||
|
avatar: %{"url" => [%{"href" => "#{Pleroma.Web.Endpoint.url()}/localuser/avatar.png"}]}
|
||||||
|
})
|
||||||
|
|
||||||
|
avatar_url = Pleroma.Web.TwitterAPI.RemoteFollowView.avatar_url(user)
|
||||||
|
|
||||||
|
assert avatar_url == "#{Pleroma.Web.Endpoint.url()}/localuser/avatar.png"
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue