diff options
author | Liam Dennehy <liam@wiemax.net> | 2018-06-28 17:14:45 +0200 |
---|---|---|
committer | Liam Dennehy <liam@wiemax.net> | 2018-06-28 17:14:45 +0200 |
commit | 6bc3d3781d9003b9bcdaa47bbe00674fbf272c29 (patch) | |
tree | 4869ac40c371a26532531ea37c066ab5ddc68797 /apps/files_trashbin/lib/Command/CleanUp.php | |
parent | 388ea2234f96be1fc774d4dc02b71e7d67d31910 (diff) | |
download | nextcloud-server-6bc3d3781d9003b9bcdaa47bbe00674fbf272c29.tar.gz nextcloud-server-6bc3d3781d9003b9bcdaa47bbe00674fbf272c29.zip |
Default behaviour when no users are specified on trashbin:cleanup
* Add option --all-users to explicitly clean all trashbins
* Reject no users on commandline and no --all-users
* Warn when --all-users and userids are specified
Signed-off-by: Liam Dennehy <liam@wiemax.net>
Diffstat (limited to 'apps/files_trashbin/lib/Command/CleanUp.php')
-rw-r--r-- | apps/files_trashbin/lib/Command/CleanUp.php | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/apps/files_trashbin/lib/Command/CleanUp.php b/apps/files_trashbin/lib/Command/CleanUp.php index b727dd9e133..d1931b6b3e1 100644 --- a/apps/files_trashbin/lib/Command/CleanUp.php +++ b/apps/files_trashbin/lib/Command/CleanUp.php @@ -29,6 +29,7 @@ use OCP\IUserBackend; use OCP\IUserManager; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; @@ -62,13 +63,22 @@ class CleanUp extends Command { ->addArgument( 'user_id', InputArgument::OPTIONAL | InputArgument::IS_ARRAY, - 'remove deleted files of the given user(s), if no user is given all deleted files will be removed' + 'remove deleted files of the given user(s)' + ) + ->addOption( + 'all-users', + null, + InputOption::VALUE_NONE, + 'run action on all users' ); } protected function execute(InputInterface $input, OutputInterface $output) { $users = $input->getArgument('user_id'); if (!empty($users)) { + if ($input->getOption('all-users')) { + $output->writeln('Option --all-users supplied along with users, restricting to supplied users'); + } foreach ($users as $user) { if ($this->userManager->userExists($user)) { $output->writeln("Remove deleted files of <info>$user</info>"); @@ -77,8 +87,8 @@ class CleanUp extends Command { $output->writeln("<error>Unknown user $user</error>"); } } - } else { - $output->writeln('Remove all deleted files'); + } elseif ($input->getOption('all-users')) { + $output->writeln('Remove deleted files for all users'); foreach ($this->userManager->getBackends() as $backend) { $name = get_class($backend); if ($backend instanceof IUserBackend) { |