summaryrefslogtreecommitdiffstats
path: root/apps/files_trashbin/lib/Command/CleanUp.php
diff options
context:
space:
mode:
authorLiam Dennehy <liam@wiemax.net>2018-06-28 17:14:45 +0200
committerLiam Dennehy <liam@wiemax.net>2018-06-28 17:14:45 +0200
commit6bc3d3781d9003b9bcdaa47bbe00674fbf272c29 (patch)
tree4869ac40c371a26532531ea37c066ab5ddc68797 /apps/files_trashbin/lib/Command/CleanUp.php
parent388ea2234f96be1fc774d4dc02b71e7d67d31910 (diff)
downloadnextcloud-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.php16
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) {