akkoma/test/pleroma/web/plugs/remote_ip_test.exs

121 lines
2.7 KiB
Elixir
Raw Normal View History

2019-09-27 15:59:23 -06:00
# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
2019-09-27 15:59:23 -06:00
# SPDX-License-Identifier: AGPL-3.0-only
2020-06-23 09:16:47 -06:00
defmodule Pleroma.Web.Plugs.RemoteIpTest do
use ExUnit.Case
2019-09-27 15:59:23 -06:00
use Plug.Test
2020-06-24 00:30:32 -06:00
alias Pleroma.Web.Plugs.RemoteIp
2019-09-27 15:59:23 -06:00
import Pleroma.Tests.Helpers, only: [clear_config: 2]
setup do
clear_config([RemoteIp, :enabled], true)
clear_config([RemoteIp, :headers], ["x-forwarded-for"])
clear_config([RemoteIp, :proxies], [])
clear_config(
[RemoteIp, :reserved],
[
"127.0.0.0/8",
"::1/128",
"fc00::/7",
"10.0.0.0/8",
"172.16.0.0/12",
"192.168.0.0/16"
]
)
end
2019-09-27 15:59:23 -06:00
test "disabled" do
clear_config([RemoteIp, :enabled], false)
2019-09-27 15:59:23 -06:00
%{remote_ip: remote_ip} = conn(:get, "/")
conn =
:get
|> conn("/")
2019-09-27 15:59:23 -06:00
|> put_req_header("x-forwarded-for", "1.1.1.1")
|> RemoteIp.call(nil)
assert conn.remote_ip == remote_ip
end
test "enabled" do
conn =
:get
|> conn("/")
2019-09-27 15:59:23 -06:00
|> put_req_header("x-forwarded-for", "1.1.1.1")
|> RemoteIp.call(nil)
assert conn.remote_ip == {1, 1, 1, 1}
end
test "custom headers" do
clear_config([RemoteIp, :enabled], true)
clear_config([RemoteIp, :headers], ["cf-connecting-ip"])
2019-09-27 15:59:23 -06:00
conn =
:get
|> conn("/")
2019-09-27 15:59:23 -06:00
|> put_req_header("x-forwarded-for", "1.1.1.1")
|> RemoteIp.call(nil)
refute conn.remote_ip == {1, 1, 1, 1}
conn =
:get
|> conn("/")
2019-09-27 15:59:23 -06:00
|> put_req_header("cf-connecting-ip", "1.1.1.1")
|> RemoteIp.call(nil)
assert conn.remote_ip == {1, 1, 1, 1}
end
test "custom proxies" do
conn =
:get
|> conn("/")
2019-09-27 15:59:23 -06:00
|> put_req_header("x-forwarded-for", "173.245.48.1, 1.1.1.1, 173.245.48.2")
|> RemoteIp.call(nil)
refute conn.remote_ip == {1, 1, 1, 1}
clear_config([RemoteIp, :proxies], ["173.245.48.0/20"])
2019-09-27 15:59:23 -06:00
conn =
:get
|> conn("/")
2019-09-27 15:59:23 -06:00
|> put_req_header("x-forwarded-for", "173.245.48.1, 1.1.1.1, 173.245.48.2")
|> RemoteIp.call(nil)
assert conn.remote_ip == {1, 1, 1, 1}
end
test "proxies set without CIDR format" do
clear_config([RemoteIp, :proxies], ["173.245.48.1"])
conn =
:get
|> conn("/")
|> put_req_header("x-forwarded-for", "173.245.48.1, 1.1.1.1")
|> RemoteIp.call(nil)
assert conn.remote_ip == {1, 1, 1, 1}
2020-10-07 13:32:09 -06:00
end
2020-10-07 13:16:53 -06:00
test "proxies set `nonsensical` CIDR" do
clear_config([RemoteIp, :reserved], ["127.0.0.0/8"])
clear_config([RemoteIp, :proxies], ["10.0.0.3/24"])
2020-10-07 13:16:53 -06:00
conn =
:get
|> conn("/")
2020-10-07 13:16:53 -06:00
|> put_req_header("x-forwarded-for", "10.0.0.3, 1.1.1.1")
|> RemoteIp.call(nil)
assert conn.remote_ip == {1, 1, 1, 1}
end
2019-09-27 15:59:23 -06:00
end