aboutsummaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorCôme Chilliet <91878298+come-nc@users.noreply.github.com>2023-09-21 15:23:36 +0200
committerGitHub <noreply@github.com>2023-09-21 15:23:36 +0200
commit39d4c8759b922d1a2383c619a54991e0a4161ce3 (patch)
treee252991531c1bd252c19749480fa82a6f263ab4d /apps
parentff9de2efb6a1a755428bfb7b89d562c5fc46138d (diff)
parent0273b96eef8111def6bb3d5773a46f543802cb02 (diff)
downloadnextcloud-server-39d4c8759b922d1a2383c619a54991e0a4161ce3.tar.gz
nextcloud-server-39d4c8759b922d1a2383c619a54991e0a4161ce3.zip
Merge pull request #39695 from fsamapoor/refactor_files_version_app_commands
Refactors files version app commands.
Diffstat (limited to 'apps')
-rw-r--r--apps/files_versions/lib/Command/CleanUp.php79
-rw-r--r--apps/files_versions/lib/Command/Expire.php20
-rw-r--r--apps/files_versions/lib/Command/ExpireVersions.php67
3 files changed, 64 insertions, 102 deletions
diff --git a/apps/files_versions/lib/Command/CleanUp.php b/apps/files_versions/lib/Command/CleanUp.php
index d7bb4caa483..519b3689a58 100644
--- a/apps/files_versions/lib/Command/CleanUp.php
+++ b/apps/files_versions/lib/Command/CleanUp.php
@@ -34,24 +34,14 @@ use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
class CleanUp extends Command {
-
- /** @var IUserManager */
- protected $userManager;
-
- /** @var IRootFolder */
- protected $rootFolder;
-
- /**
- * @param IRootFolder $rootFolder
- * @param IUserManager $userManager
- */
- public function __construct(IRootFolder $rootFolder, IUserManager $userManager) {
+ public function __construct(
+ protected IRootFolder $rootFolder,
+ protected IUserManager $userManager,
+ ) {
parent::__construct();
- $this->userManager = $userManager;
- $this->rootFolder = $rootFolder;
}
- protected function configure() {
+ protected function configure(): void {
$this
->setName('versions:cleanup')
->setDescription('Delete versions')
@@ -76,7 +66,7 @@ class CleanUp extends Command {
if ($path) {
if (!preg_match('#^/([^/]+)/files(/.*)?$#', $path, $pathMatches)) {
$output->writeln("<error>Invalid path given</error>");
- return 1;
+ return self::FAILURE;
}
$users = [ $pathMatches[1] ];
@@ -85,48 +75,47 @@ class CleanUp extends Command {
if (!empty($users)) {
foreach ($users as $user) {
- if ($this->userManager->userExists($user)) {
- $output->writeln("Delete versions of <info>$user</info>");
- $this->deleteVersions($user, $path);
- } else {
+ if (!$this->userManager->userExists($user)) {
$output->writeln("<error>Unknown user $user</error>");
- return 1;
+ return self::FAILURE;
}
+
+ $output->writeln("Delete versions of <info>$user</info>");
+ $this->deleteVersions($user, $path);
}
- } else {
- $output->writeln('Delete all versions');
- foreach ($this->userManager->getBackends() as $backend) {
- $name = get_class($backend);
+ return self::SUCCESS;
+ }
- if ($backend instanceof IUserBackend) {
- $name = $backend->getBackendName();
- }
+ $output->writeln('Delete all versions');
+ foreach ($this->userManager->getBackends() as $backend) {
+ $name = get_class($backend);
- $output->writeln("Delete versions for users on backend <info>$name</info>");
-
- $limit = 500;
- $offset = 0;
- do {
- $users = $backend->getUsers('', $limit, $offset);
- foreach ($users as $user) {
- $output->writeln(" <info>$user</info>");
- $this->deleteVersions($user);
- }
- $offset += $limit;
- } while (count($users) >= $limit);
+ if ($backend instanceof IUserBackend) {
+ $name = $backend->getBackendName();
}
+
+ $output->writeln("Delete versions for users on backend <info>$name</info>");
+
+ $limit = 500;
+ $offset = 0;
+ do {
+ $users = $backend->getUsers('', $limit, $offset);
+ foreach ($users as $user) {
+ $output->writeln(" <info>$user</info>");
+ $this->deleteVersions($user);
+ }
+ $offset += $limit;
+ } while (count($users) >= $limit);
}
- return 0;
+
+ return self::SUCCESS;
}
/**
* delete versions for the given user
- *
- * @param string $user
- * @param string|null $path
*/
- protected function deleteVersions(string $user, string $path = null): void {
+ protected function deleteVersions(string $user, ?string $path = null): void {
\OC_Util::tearDownFS();
\OC_Util::setupFS($user);
diff --git a/apps/files_versions/lib/Command/Expire.php b/apps/files_versions/lib/Command/Expire.php
index 62b2343a5e0..688a6e869e9 100644
--- a/apps/files_versions/lib/Command/Expire.php
+++ b/apps/files_versions/lib/Command/Expire.php
@@ -33,22 +33,13 @@ use Psr\Log\LoggerInterface;
class Expire implements ICommand {
use FileAccess;
- /**
- * @var string
- */
- private $fileName;
-
- /**
- * @var string
- */
- private $user;
-
- public function __construct(string $user, string $fileName) {
- $this->user = $user;
- $this->fileName = $fileName;
+ public function __construct(
+ private string $user,
+ private string $fileName,
+ ) {
}
- public function handle() {
+ public function handle(): void {
/** @var IUserManager $userManager */
$userManager = \OC::$server->get(IUserManager::class);
if (!$userManager->userExists($this->user)) {
@@ -62,7 +53,6 @@ class Expire implements ICommand {
// In case of external storage and session credentials, the expiration
// fails because the command does not have those credentials
- /** @var LoggerInterface */
$logger = \OC::$server->get(LoggerInterface::class);
$logger->warning($e->getMessage(), [
'exception' => $e,
diff --git a/apps/files_versions/lib/Command/ExpireVersions.php b/apps/files_versions/lib/Command/ExpireVersions.php
index 43068e21451..d8e59b40dba 100644
--- a/apps/files_versions/lib/Command/ExpireVersions.php
+++ b/apps/files_versions/lib/Command/ExpireVersions.php
@@ -36,30 +36,14 @@ use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
class ExpireVersions extends Command {
-
- /**
- * @var Expiration
- */
- private $expiration;
-
- /**
- * @var IUserManager
- */
- private $userManager;
-
- /**
- * @param IUserManager $userManager
- * @param Expiration $expiration
- */
- public function __construct(IUserManager $userManager,
- Expiration $expiration) {
+ public function __construct(
+ private IUserManager $userManager,
+ private Expiration $expiration,
+ ) {
parent::__construct();
-
- $this->userManager = $userManager;
- $this->expiration = $expiration;
}
- protected function configure() {
+ protected function configure(): void {
$this
->setName('versions:expire')
->setDescription('Expires the users file versions')
@@ -74,35 +58,36 @@ class ExpireVersions extends Command {
$maxAge = $this->expiration->getMaxAgeAsTimestamp();
if (!$maxAge) {
$output->writeln("Auto expiration is configured - expiration will be handled automatically according to the expiration patterns detailed at the following link https://docs.nextcloud.com/server/latest/admin_manual/configuration_files/file_versioning.html.");
- return 1;
+ return self::FAILURE;
}
$users = $input->getArgument('user_id');
if (!empty($users)) {
foreach ($users as $user) {
- if ($this->userManager->userExists($user)) {
- $output->writeln("Remove deleted files of <info>$user</info>");
- $userObject = $this->userManager->get($user);
- $this->expireVersionsForUser($userObject);
- } else {
+ if (!$this->userManager->userExists($user)) {
$output->writeln("<error>Unknown user $user</error>");
- return 1;
+ return self::FAILURE;
}
+
+ $output->writeln("Remove deleted files of <info>$user</info>");
+ $userObject = $this->userManager->get($user);
+ $this->expireVersionsForUser($userObject);
}
- } else {
- $p = new ProgressBar($output);
- $p->start();
- $this->userManager->callForSeenUsers(function (IUser $user) use ($p) {
- $p->advance();
- $this->expireVersionsForUser($user);
- });
- $p->finish();
- $output->writeln('');
+ return self::SUCCESS;
}
- return 0;
+
+ $p = new ProgressBar($output);
+ $p->start();
+ $this->userManager->callForSeenUsers(function (IUser $user) use ($p) {
+ $p->advance();
+ $this->expireVersionsForUser($user);
+ });
+ $p->finish();
+ $output->writeln('');
+ return self::SUCCESS;
}
- public function expireVersionsForUser(IUser $user) {
+ public function expireVersionsForUser(IUser $user): void {
$uid = $user->getUID();
if (!$this->setupFS($uid)) {
return;
@@ -112,10 +97,8 @@ class ExpireVersions extends Command {
/**
* Act on behalf on versions item owner
- * @param string $user
- * @return boolean
*/
- protected function setupFS($user) {
+ protected function setupFS(string $user): bool {
\OC_Util::tearDownFS();
\OC_Util::setupFS($user);