From 28b2d9673a5342bdddf0aaee84effe4f054e4c85 Mon Sep 17 00:00:00 2001 From: dr-waterstorm Date: Thu, 24 Nov 2022 14:58:13 +0100 Subject: [PATCH] Feature/support modern password hashes (#182) * Added ARGON2 password hashing * added missing ldap tag Co-authored-by: Jens Rauch --- README.md | 2 +- www/includes/ldap_functions.inc.php | 5 +++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index a290dc1..f1f25f4 100644 --- a/README.md +++ b/README.md @@ -163,7 +163,7 @@ These settings should only be changed if you're trying to make the user manager * `USERNAME_REGEX` (default: *^[a-z][a-zA-Z0-9\._-]{3,32}$*): The regular expression used to ensure account names and group names are safe to use on servers. See [Username format](#username-format). -* `PASSWORD_HASH` (no default): Select which hashing method which will be used to store passwords in LDAP. Options are (in order of precedence) `SHA512CRYPT`, `SHA256CRYPT`, `MD5CRYPT`, `SSHA`, `SHA`, `SMD5`, `MD5`, `CRYPT` & `CLEAR`. If your chosen method isn't available on your system then the strongest available method will be automatically selected - `SSHA` is the strongest method guaranteed to be available. Cleartext passwords should NEVER be used in any situation outside of a test. +* `PASSWORD_HASH` (no default): Select which hashing method which will be used to store passwords in LDAP. Options are (in order of precedence) `SHA512CRYPT`, `SHA256CRYPT`, `MD5CRYPT`, `SSHA`, `SHA`, `SMD5`, `MD5`, `ARGON2`, `CRYPT` & `CLEAR`. If your chosen method isn't available on your system then the strongest available method will be automatically selected - `SSHA` is the strongest method guaranteed to be available. Note that for `ARGON2` to work you need to have the ARGON2 plugin enabled, if you do not the passwords will be saved but the user cannot authenticate against it. Cleartext passwords should NEVER be used in any situation outside of a test. * `ACCEPT_WEAK_PASSWORDS` (default: *FALSE*): Set this to *TRUE* to prevent a password being rejected for being too weak. The password strength indicators will still gauge the strength of the password. Don't enable this in a production environment. diff --git a/www/includes/ldap_functions.inc.php b/www/includes/ldap_functions.inc.php index 6ec1e8d..1117fc0 100644 --- a/www/includes/ldap_functions.inc.php +++ b/www/includes/ldap_functions.inc.php @@ -205,6 +205,7 @@ function ldap_hashed_password($password) { "SHA", "SMD5", "MD5", + "ARGON2", "CRYPT", "CLEAR" ); @@ -276,6 +277,10 @@ function ldap_hashed_password($password) { $hashed_pwd = '{SSHA}' . base64_encode(sha1($password . $salt, TRUE) . $salt); break; + case 'ARGON2': + $hashed_pwd = '{ARGON2}' . password_hash($password, PASSWORD_ARGON2ID, ['memory_cost' => 2048, 'time_cost' => 4, 'threads' => 3]); + break; + case 'CRYPT': $salt = generate_salt(2); $hashed_pwd = '{CRYPT}' . crypt($password, $salt);