Merge pull request #5978 from MrPetovan/task/make-username-length-configurable
Make username length configurable
This commit is contained in:
commit
277fe547a1
2 changed files with 29 additions and 6 deletions
|
@ -369,6 +369,18 @@ throttle_limit_month = 0
|
||||||
; For instance if your URL is 'http://example.com/directory/subdirectory', set urlpath to 'directory/subdirectory'.
|
; For instance if your URL is 'http://example.com/directory/subdirectory', set urlpath to 'directory/subdirectory'.
|
||||||
urlpath =
|
urlpath =
|
||||||
|
|
||||||
|
; username_min_length (Integer)
|
||||||
|
; The minimum character length a username can be.
|
||||||
|
; This length is check once the username has been trimmed and multiple spaces have been collapsed into one.
|
||||||
|
; Minimum for this config value is 1. Maximum is 64 as the resulting profile URL mustn't be longer than 255 chars.
|
||||||
|
username_min_length = 3
|
||||||
|
|
||||||
|
; username_max_length (Integer)
|
||||||
|
; The maximum character length a username can be.
|
||||||
|
; This length is check once the username has been trimmed and multiple spaces have been collapsed into one.
|
||||||
|
; Minimum for this config value is 1. Maximum is 64 as the resulting profile URL mustn't be longer than 255 chars.
|
||||||
|
username_max_length = 48
|
||||||
|
|
||||||
; worker_cooldown (Integer)
|
; worker_cooldown (Integer)
|
||||||
; Cooldown period in seconds after each worker function call.
|
; Cooldown period in seconds after each worker function call.
|
||||||
worker_cooldown = 0
|
worker_cooldown = 0
|
||||||
|
|
|
@ -466,19 +466,30 @@ class User
|
||||||
// collapse multiple spaces in name
|
// collapse multiple spaces in name
|
||||||
$username = preg_replace('/ +/', ' ', $username);
|
$username = preg_replace('/ +/', ' ', $username);
|
||||||
|
|
||||||
if (mb_strlen($username) > 48) {
|
$username_min_length = max(1, min(64, intval(Config::get('system', 'username_min_length', 3))));
|
||||||
throw new Exception(L10n::t('Please use a shorter name.'));
|
$username_max_length = max(1, min(64, intval(Config::get('system', 'username_max_length', 48))));
|
||||||
|
|
||||||
|
if ($username_min_length > $username_max_length) {
|
||||||
|
logger(L10n::t('system.username_min_length (%s) and system.username_max_length (%s) are excluding each other, swapping values.', $username_min_length, $username_max_length), LOGGER_WARNING);
|
||||||
|
$tmp = $username_min_length;
|
||||||
|
$username_min_length = $username_max_length;
|
||||||
|
$username_max_length = $tmp;
|
||||||
}
|
}
|
||||||
if (mb_strlen($username) < 3) {
|
|
||||||
throw new Exception(L10n::t('Name too short.'));
|
if (mb_strlen($username) < $username_min_length) {
|
||||||
|
throw new Exception(L10n::tt('Username should be at least %s character.', 'Username should be at least %s characters.', $username_min_length));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mb_strlen($username) > $username_max_length) {
|
||||||
|
throw new Exception(L10n::tt('Username should be at most %s character.', 'Username should be at most %s characters.', $username_max_length));
|
||||||
}
|
}
|
||||||
|
|
||||||
// So now we are just looking for a space in the full name.
|
// So now we are just looking for a space in the full name.
|
||||||
$loose_reg = Config::get('system', 'no_regfullname');
|
$loose_reg = Config::get('system', 'no_regfullname');
|
||||||
if (!$loose_reg) {
|
if (!$loose_reg) {
|
||||||
$username = mb_convert_case($username, MB_CASE_TITLE, 'UTF-8');
|
$username = mb_convert_case($username, MB_CASE_TITLE, 'UTF-8');
|
||||||
if (!strpos($username, ' ')) {
|
if (strpos($username, ' ') === false) {
|
||||||
throw new Exception(L10n::t("That doesn't appear to be your full \x28First Last\x29 name."));
|
throw new Exception(L10n::t("That doesn't appear to be your full (First Last) name."));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue