diff options
author | Vincent Petry <pvince81@owncloud.com> | 2015-10-29 16:40:39 +0100 |
---|---|---|
committer | Vincent Petry <pvince81@owncloud.com> | 2015-10-29 17:41:49 +0100 |
commit | 781bca2437628d2f932abd60c5dcec0ece4504e3 (patch) | |
tree | 9729ae043ff4061570e95f127db82a4197b5ee62 /settings | |
parent | 73d9699be9d2a343b0573dc6a5bcc65f5f9c7303 (diff) | |
download | nextcloud-server-781bca2437628d2f932abd60c5dcec0ece4504e3.tar.gz nextcloud-server-781bca2437628d2f932abd60c5dcec0ece4504e3.zip |
Fix everyone count for subadmins
Also moved the logic to the UsersController
Diffstat (limited to 'settings')
-rw-r--r-- | settings/ajax/geteveryonecount.php | 55 | ||||
-rw-r--r-- | settings/controller/userscontroller.php | 36 | ||||
-rw-r--r-- | settings/js/users/groups.js | 6 | ||||
-rw-r--r-- | settings/routes.php | 3 |
4 files changed, 40 insertions, 60 deletions
diff --git a/settings/ajax/geteveryonecount.php b/settings/ajax/geteveryonecount.php deleted file mode 100644 index 002c849fd39..00000000000 --- a/settings/ajax/geteveryonecount.php +++ /dev/null @@ -1,55 +0,0 @@ -<?php -/** - * @author Clark Tomlinson <fallen013@gmail.com> - * @author Lukas Reschke <lukas@owncloud.com> - * @author Morris Jobke <hey@morrisjobke.de> - * - * @copyright Copyright (c) 2015, ownCloud, Inc. - * @license AGPL-3.0 - * - * This code is free software: you can redistribute it and/or modify - * it under the terms of the GNU Affero General Public License, version 3, - * as published by the Free Software Foundation. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Affero General Public License for more details. - * - * You should have received a copy of the GNU Affero General Public License, version 3, - * along with this program. If not, see <http://www.gnu.org/licenses/> - * - */ - -OC_JSON::callCheck(); -OC_JSON::checkSubAdminUser(); - -$userCount = 0; - -$currentUser = \OC::$server->getUserSession()->getUser()->getUID(); - -if (!OC_User::isAdminUser($currentUser)) { - $groups = \OC::$server->getGroupManager()->getSubAdmin()->getSubAdminsGroups(\OC::$server->getUserSession()->getUser()); - // New class returns IGroup[] so convert back - foreach ($groups as $key => $group) { - $groups[$key] = $group->getGID(); - } - - - foreach ($groups as $group) { - $userCount += count(OC_Group::usersInGroup($group)); - - } -} else { - - $userCountArray = \OC::$server->getUserManager()->countUsers(); - - if (!empty($userCountArray)) { - foreach ($userCountArray as $classname => $usercount) { - $userCount += $usercount; - } - } -} - - -OC_JSON::success(array('count' => $userCount)); diff --git a/settings/controller/userscontroller.php b/settings/controller/userscontroller.php index 8183bc4739b..fed9e268a7c 100644 --- a/settings/controller/userscontroller.php +++ b/settings/controller/userscontroller.php @@ -548,4 +548,40 @@ class UsersController extends Controller { ); } + /** + * Count all unique users visible for the current admin/subadmin. + * + * @NoAdminRequired + * + * @return DataResponse + */ + public function stats() { + $userCount = 0; + if ($this->isAdmin) { + $countByBackend = $this->userManager->countUsers(); + + if (!empty($countByBackend)) { + foreach ($countByBackend as $count) { + $userCount += $count; + } + } + } else { + $groups = $this->groupManager->getSubAdmin()->getSubAdminsGroups($this->userSession->getUser()); + + foreach ($groups as $group) { + foreach($group->getUsers() as $uid => $displayName) { + $uniqueUsers[$uid] = true; + } + } + + $userCount = count($uniqueUsers); + } + + return new DataResponse( + [ + 'totalUsers' => $userCount + ] + ); + } + } diff --git a/settings/js/users/groups.js b/settings/js/users/groups.js index c8d2ef7c5b1..2639191d918 100644 --- a/settings/js/users/groups.js +++ b/settings/js/users/groups.js @@ -304,10 +304,10 @@ GroupList = { $.ajax({ type: "GET", dataType: "json", - url: OC.generateUrl('/settings/ajax/geteveryonecount') + url: OC.generateUrl('/settings/users/stats') }).success(function (data) { - $('#everyonegroup').data('usercount', data.count); - $('#everyonecount').text(data.count); + $('#everyonegroup').data('usercount', data.totalUsers); + $('#everyonecount').text(data.totalUsers); }); } }; diff --git a/settings/routes.php b/settings/routes.php index 10c3117c183..6ba38388d3a 100644 --- a/settings/routes.php +++ b/settings/routes.php @@ -47,6 +47,7 @@ $application->registerRoutes($this, [ ['name' => 'AppSettings#changeExperimentalConfigState', 'url' => '/settings/apps/experimental', 'verb' => 'POST'], ['name' => 'SecuritySettings#trustedDomains', 'url' => '/settings/admin/security/trustedDomains', 'verb' => 'POST'], ['name' => 'Users#setMailAddress', 'url' => '/settings/users/{id}/mailAddress', 'verb' => 'PUT'], + ['name' => 'Users#stats', 'url' => '/settings/users/stats', 'verb' => 'GET'], ['name' => 'LogSettings#setLogLevel', 'url' => '/settings/admin/log/level', 'verb' => 'POST'], ['name' => 'LogSettings#getEntries', 'url' => '/settings/admin/log/entries', 'verb' => 'GET'], ['name' => 'LogSettings#download', 'url' => '/settings/admin/log/download', 'verb' => 'GET'], @@ -69,8 +70,6 @@ $this->create('settings_admin', '/settings/admin') ->actionInclude('settings/admin.php'); // Settings ajax actions // users -$this->create('settings_ajax_everyonecount', '/settings/ajax/geteveryonecount') - ->actionInclude('settings/ajax/geteveryonecount.php'); $this->create('settings_ajax_setquota', '/settings/ajax/setquota.php') ->actionInclude('settings/ajax/setquota.php'); $this->create('settings_ajax_togglegroups', '/settings/ajax/togglegroups.php') |