mirror of
https://github.com/Kozea/Radicale.git
synced 2025-04-05 22:27:36 +03:00
add warning in case authentication based on environment is selected and server is not listen to loopback addresses only
This commit is contained in:
parent
e22fbe282b
commit
358ae55540
1 changed files with 23 additions and 4 deletions
|
@ -55,15 +55,34 @@ CACHE_LOGIN_TYPES: Sequence[str] = (
|
||||||
"pam",
|
"pam",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
INSECURE_IF_NO_LOOPBACK_TYPES: Sequence[str] = (
|
||||||
|
"remote_user",
|
||||||
|
"http_x_remote_user",
|
||||||
|
)
|
||||||
|
|
||||||
AUTH_SOCKET_FAMILY: Sequence[str] = ("AF_UNIX", "AF_INET", "AF_INET6")
|
AUTH_SOCKET_FAMILY: Sequence[str] = ("AF_UNIX", "AF_INET", "AF_INET6")
|
||||||
|
|
||||||
|
|
||||||
def load(configuration: "config.Configuration") -> "BaseAuth":
|
def load(configuration: "config.Configuration") -> "BaseAuth":
|
||||||
"""Load the authentication module chosen in configuration."""
|
"""Load the authentication module chosen in configuration."""
|
||||||
if configuration.get("auth", "type") == "none":
|
_type = configuration.get("auth", "type")
|
||||||
logger.warning("No user authentication is selected: '[auth] type=none' (insecure)")
|
if _type == "none":
|
||||||
if configuration.get("auth", "type") == "denyall":
|
logger.warning("No user authentication is selected: '[auth] type=none' (INSECURE)")
|
||||||
logger.warning("All access is blocked by: '[auth] type=denyall'")
|
elif _type == "denyall":
|
||||||
|
logger.warning("All user authentication is blocked by: '[auth] type=denyall'")
|
||||||
|
elif _type in INSECURE_IF_NO_LOOPBACK_TYPES:
|
||||||
|
hosts: List[Tuple[str, int]] = configuration.get("server", "hosts")
|
||||||
|
localhost_only = True
|
||||||
|
address_lo = []
|
||||||
|
address = []
|
||||||
|
for address_port in hosts:
|
||||||
|
if address_port[0] in [ "localhost", "localhost6", "127.0.0.1", "::1" ]:
|
||||||
|
address_lo.append(utils.format_address(address_port))
|
||||||
|
else:
|
||||||
|
address.append(utils.format_address(address_port))
|
||||||
|
localhost_only = False
|
||||||
|
if localhost_only is False:
|
||||||
|
logger.warning("User authentication '[auth] type=%s' is selected but server is not only listen on loopback address (potentially INSECURE): %s", _type, " ".join(address))
|
||||||
return utils.load_plugin(INTERNAL_TYPES, "auth", "Auth", BaseAuth,
|
return utils.load_plugin(INTERNAL_TYPES, "auth", "Auth", BaseAuth,
|
||||||
configuration)
|
configuration)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue