added compatibility with a case-insensitive authentication provider

This commit is contained in:
IM 2024-04-17 18:31:51 +03:00
parent 76dc9dce0d
commit 239e17d735
5 changed files with 17 additions and 4 deletions

3
config
View file

@ -70,6 +70,9 @@
# Message displayed in the client when a password is needed
#realm = Radicale - Password Required
# Сonvert username to lowercase, must be true for case-insensitive auth providers
#lc_username = False
[rights]

View file

@ -44,6 +44,8 @@ def load(configuration: "config.Configuration") -> "BaseAuth":
class BaseAuth:
_lc_username: bool
def __init__(self, configuration: "config.Configuration") -> None:
"""Initialize BaseAuth.
@ -53,6 +55,7 @@ class BaseAuth:
"""
self.configuration = configuration
self._lc_username = configuration.get("auth", "lc_username")
def get_external_login(self, environ: types.WSGIEnviron) -> Union[
Tuple[()], Tuple[str, str]]:
@ -67,7 +70,7 @@ class BaseAuth:
"""
return ()
def login(self, login: str, password: str) -> str:
def _login(self, login: str, password: str) -> str:
"""Check credentials and map login to internal user
``login`` the login name
@ -79,3 +82,6 @@ class BaseAuth:
"""
raise NotImplementedError
def login(self, login: str, password: str) -> str:
return self._login(login, password).lower() if self._lc_username else self._login(login, password)

View file

@ -127,7 +127,7 @@ class Auth(auth.BaseAuth):
# assumed plaintext
return self._plain(hash_value, password)
def login(self, login: str, password: str) -> str:
def _login(self, login: str, password: str) -> str:
"""Validate credentials.
Iterate through htpasswd credential file until login matches, extract

View file

@ -27,5 +27,5 @@ from radicale import auth
class Auth(auth.BaseAuth):
def login(self, login: str, password: str) -> str:
def _login(self, login: str, password: str) -> str:
return login

View file

@ -177,7 +177,11 @@ DEFAULT_CONFIG_SCHEMA: types.CONFIG_SCHEMA = OrderedDict([
("delay", {
"value": "1",
"help": "incorrect authentication delay",
"type": positive_float})])),
"type": positive_float}),
("lc_username", {
"value": "False",
"help": "convert username to lowercase, must be true for case-insensitive auth providers",
"type": bool})])),
("rights", OrderedDict([
("type", {
"value": "owner_only",