mirror of
https://github.com/Kozea/Radicale.git
synced 2025-04-04 13:47:37 +03:00
added compatibility with a case-insensitive authentication provider
This commit is contained in:
parent
76dc9dce0d
commit
239e17d735
5 changed files with 17 additions and 4 deletions
3
config
3
config
|
@ -70,6 +70,9 @@
|
||||||
# Message displayed in the client when a password is needed
|
# Message displayed in the client when a password is needed
|
||||||
#realm = Radicale - Password Required
|
#realm = Radicale - Password Required
|
||||||
|
|
||||||
|
# Сonvert username to lowercase, must be true for case-insensitive auth providers
|
||||||
|
#lc_username = False
|
||||||
|
|
||||||
|
|
||||||
[rights]
|
[rights]
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,8 @@ def load(configuration: "config.Configuration") -> "BaseAuth":
|
||||||
|
|
||||||
class BaseAuth:
|
class BaseAuth:
|
||||||
|
|
||||||
|
_lc_username: bool
|
||||||
|
|
||||||
def __init__(self, configuration: "config.Configuration") -> None:
|
def __init__(self, configuration: "config.Configuration") -> None:
|
||||||
"""Initialize BaseAuth.
|
"""Initialize BaseAuth.
|
||||||
|
|
||||||
|
@ -53,6 +55,7 @@ class BaseAuth:
|
||||||
|
|
||||||
"""
|
"""
|
||||||
self.configuration = configuration
|
self.configuration = configuration
|
||||||
|
self._lc_username = configuration.get("auth", "lc_username")
|
||||||
|
|
||||||
def get_external_login(self, environ: types.WSGIEnviron) -> Union[
|
def get_external_login(self, environ: types.WSGIEnviron) -> Union[
|
||||||
Tuple[()], Tuple[str, str]]:
|
Tuple[()], Tuple[str, str]]:
|
||||||
|
@ -67,7 +70,7 @@ class BaseAuth:
|
||||||
"""
|
"""
|
||||||
return ()
|
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
|
"""Check credentials and map login to internal user
|
||||||
|
|
||||||
``login`` the login name
|
``login`` the login name
|
||||||
|
@ -79,3 +82,6 @@ class BaseAuth:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
raise NotImplementedError
|
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)
|
||||||
|
|
|
@ -127,7 +127,7 @@ class Auth(auth.BaseAuth):
|
||||||
# assumed plaintext
|
# assumed plaintext
|
||||||
return self._plain(hash_value, password)
|
return self._plain(hash_value, password)
|
||||||
|
|
||||||
def login(self, login: str, password: str) -> str:
|
def _login(self, login: str, password: str) -> str:
|
||||||
"""Validate credentials.
|
"""Validate credentials.
|
||||||
|
|
||||||
Iterate through htpasswd credential file until login matches, extract
|
Iterate through htpasswd credential file until login matches, extract
|
||||||
|
|
|
@ -27,5 +27,5 @@ from radicale import auth
|
||||||
|
|
||||||
class Auth(auth.BaseAuth):
|
class Auth(auth.BaseAuth):
|
||||||
|
|
||||||
def login(self, login: str, password: str) -> str:
|
def _login(self, login: str, password: str) -> str:
|
||||||
return login
|
return login
|
||||||
|
|
|
@ -177,7 +177,11 @@ DEFAULT_CONFIG_SCHEMA: types.CONFIG_SCHEMA = OrderedDict([
|
||||||
("delay", {
|
("delay", {
|
||||||
"value": "1",
|
"value": "1",
|
||||||
"help": "incorrect authentication delay",
|
"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([
|
("rights", OrderedDict([
|
||||||
("type", {
|
("type", {
|
||||||
"value": "owner_only",
|
"value": "owner_only",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue