diff options
author | Joas Schilling <coding@schilljs.com> | 2021-05-25 13:03:29 +0200 |
---|---|---|
committer | backportbot[bot] <backportbot[bot]@users.noreply.github.com> | 2021-06-01 08:36:06 +0000 |
commit | d25446fd58f4429303d7ad51761de3d8d43a4bb1 (patch) | |
tree | 337da72dba14b5a81fdb7e846ed9c86d19f9e592 /core/Command/User | |
parent | b4c3e8dbc8011c6af73e96694f52d26f678b537e (diff) | |
download | nextcloud-server-d25446fd58f4429303d7ad51761de3d8d43a4bb1.tar.gz nextcloud-server-d25446fd58f4429303d7ad51761de3d8d43a4bb1.zip |
Make user:report command scale
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'core/Command/User')
-rw-r--r-- | core/Command/User/Report.php | 39 |
1 files changed, 26 insertions, 13 deletions
diff --git a/core/Command/User/Report.php b/core/Command/User/Report.php index 66bc9bd3de1..b537884d9d6 100644 --- a/core/Command/User/Report.php +++ b/core/Command/User/Report.php @@ -1,4 +1,6 @@ <?php + +declare(strict_types=1); /** * @copyright Copyright (c) 2016, ownCloud, Inc. * @@ -27,40 +29,49 @@ namespace OC\Core\Command\User; +use OC\Files\View; use OCP\IConfig; use OCP\IUserManager; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Helper\Table; use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Output\OutputInterface; class Report extends Command { + public const DEFAULT_COUNT_DIRS_MAX_USERS = 500; + /** @var IUserManager */ protected $userManager; /** @var IConfig */ private $config; - /** - * @param IUserManager $userManager - */ - public function __construct(IUserManager $userManager, IConfig $config) { + public function __construct(IUserManager $userManager, + IConfig $config) { $this->userManager = $userManager; $this->config = $config; parent::__construct(); } - protected function configure() { + protected function configure(): void { $this ->setName('user:report') - ->setDescription('shows how many users have access'); + ->setDescription('shows how many users have access') + ->addOption( + 'count-dirs', + null, + InputOption::VALUE_NONE, + 'Also count the number of user directories in the database (could time out on huge installations, therefore defaults to no with ' . self::DEFAULT_COUNT_DIRS_MAX_USERS . '+ users)' + ) + ; } protected function execute(InputInterface $input, OutputInterface $output): int { $table = new Table($output); $table->setHeaders(['User Report', '']); $userCountArray = $this->countUsers(); + $total = 0; if (!empty($userCountArray)) { - $total = 0; $rows = []; foreach ($userCountArray as $classname => $users) { $total += $users; @@ -72,10 +83,12 @@ class Report extends Command { } else { $rows[] = ['No backend enabled that supports user counting', '']; } - - $userDirectoryCount = $this->countUserDirectories(); $rows[] = [' ']; - $rows[] = ['user directories', $userDirectoryCount]; + + if ($total <= self::DEFAULT_COUNT_DIRS_MAX_USERS || $input->getOption('count-dirs')) { + $userDirectoryCount = $this->countUserDirectories(); + $rows[] = ['user directories', $userDirectoryCount]; + } $disabledUsers = $this->config->getUsersForUserValue('core', 'enabled', 'false'); $disabledUsersCount = count($disabledUsers); @@ -86,12 +99,12 @@ class Report extends Command { return 0; } - private function countUsers() { + private function countUsers(): array { return $this->userManager->countUsers(); } - private function countUserDirectories() { - $dataview = new \OC\Files\View('/'); + private function countUserDirectories(): int { + $dataview = new View('/'); $userDirectories = $dataview->getDirectoryContent('/', 'httpd/unix-directory'); return count($userDirectories); } |