aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorCôme Chilliet <91878298+come-nc@users.noreply.github.com>2024-05-23 14:51:11 +0200
committerGitHub <noreply@github.com>2024-05-23 14:51:11 +0200
commit2fa099a6e1c905abe0d12167082e2946d8065a3a (patch)
tree21c4406830dde188fa61de49fbf5399fca5f7fff /lib
parente38fcf88b2ce0d84e5a8d0d0b6f0872efe147a72 (diff)
parent9a523e9204200770c4f7ebfd5fe5d1f8287fd2b8 (diff)
downloadnextcloud-server-2fa099a6e1c905abe0d12167082e2946d8065a3a.tar.gz
nextcloud-server-2fa099a6e1c905abe0d12167082e2946d8065a3a.zip
Merge pull request #45370 from nextcloud/feat/add-back-search-in-disabled-users
feat: Add back searching in disabled user list
Diffstat (limited to 'lib')
-rw-r--r--lib/private/User/Manager.php13
-rw-r--r--lib/public/IUserManager.php3
-rw-r--r--lib/public/User/Backend/IProvideEnabledStateBackend.php3
3 files changed, 15 insertions, 4 deletions
diff --git a/lib/private/User/Manager.php b/lib/private/User/Manager.php
index c7611da382d..c55854358cf 100644
--- a/lib/private/User/Manager.php
+++ b/lib/private/User/Manager.php
@@ -333,7 +333,7 @@ class Manager extends PublicEmitter implements IUserManager {
/**
* @return IUser[]
*/
- public function getDisabledUsers(?int $limit = null, int $offset = 0): array {
+ public function getDisabledUsers(?int $limit = null, int $offset = 0, string $search = ''): array {
$users = $this->config->getUsersForUserValue('core', 'enabled', 'false');
$users = array_combine(
$users,
@@ -342,6 +342,15 @@ class Manager extends PublicEmitter implements IUserManager {
$users
)
);
+ if ($search !== '') {
+ $users = array_filter(
+ $users,
+ fn (IUser $user): bool =>
+ mb_stripos($user->getUID(), $search) !== false ||
+ mb_stripos($user->getDisplayName(), $search) !== false ||
+ mb_stripos($user->getEMailAddress() ?? '', $search) !== false,
+ );
+ }
$tempLimit = ($limit === null ? null : $limit + $offset);
foreach ($this->backends as $backend) {
@@ -349,7 +358,7 @@ class Manager extends PublicEmitter implements IUserManager {
break;
}
if ($backend instanceof IProvideEnabledStateBackend) {
- $backendUsers = $backend->getDisabledUserList(($tempLimit === null ? null : $tempLimit - count($users)));
+ $backendUsers = $backend->getDisabledUserList(($tempLimit === null ? null : $tempLimit - count($users)), 0, $search);
foreach ($backendUsers as $uid) {
$users[$uid] = new LazyUser($uid, $this, null, $backend);
}
diff --git a/lib/public/IUserManager.php b/lib/public/IUserManager.php
index 0a94c5ad928..94ab487d318 100644
--- a/lib/public/IUserManager.php
+++ b/lib/public/IUserManager.php
@@ -142,8 +142,9 @@ interface IUserManager {
/**
* @return IUser[]
* @since 28.0.0
+ * @since 30.0.0 $search parameter added
*/
- public function getDisabledUsers(?int $limit = null, int $offset = 0): array;
+ public function getDisabledUsers(?int $limit = null, int $offset = 0, string $search = ''): array;
/**
* Search known users (from phonebook sync) by displayName
diff --git a/lib/public/User/Backend/IProvideEnabledStateBackend.php b/lib/public/User/Backend/IProvideEnabledStateBackend.php
index f12d99fd1a6..3fd517048fb 100644
--- a/lib/public/User/Backend/IProvideEnabledStateBackend.php
+++ b/lib/public/User/Backend/IProvideEnabledStateBackend.php
@@ -49,8 +49,9 @@ interface IProvideEnabledStateBackend {
* Get the list of disabled users, to merge with the ones disabled in database
*
* @since 28.0.0
+ * @since 30.0.0 $search parameter added
*
* @return string[]
*/
- public function getDisabledUserList(?int $limit = null, int $offset = 0): array;
+ public function getDisabledUserList(?int $limit = null, int $offset = 0, string $search = ''): array;
}