From e655dcfa37888693f305fe1264a571c5610e6f48 Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Fri, 14 Jun 2024 14:14:15 +0200 Subject: [PATCH] feat: add command to send raw commands to redis Signed-off-by: Robin Appelman --- core/Command/Memcache/RedisCommand.php | 56 +++++++++++++++++++++ core/register_command.php | 2 + lib/composer/composer/autoload_classmap.php | 1 + lib/composer/composer/autoload_static.php | 1 + 4 files changed, 60 insertions(+) create mode 100644 core/Command/Memcache/RedisCommand.php diff --git a/core/Command/Memcache/RedisCommand.php b/core/Command/Memcache/RedisCommand.php new file mode 100644 index 0000000000000..4da627c6b8451 --- /dev/null +++ b/core/Command/Memcache/RedisCommand.php @@ -0,0 +1,56 @@ + + * SPDX-License-Identifier: AGPL-3.0-or-later + */ + +namespace OC\Core\Command\Memcache; + +use OC\Core\Command\Base; +use OC\RedisFactory; +use OCP\ICertificateManager; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Output\OutputInterface; + +class RedisCommand extends Base { + public function __construct( + protected ICertificateManager $certificateManager, + protected RedisFactory $redisFactory, + ) { + parent::__construct(); + } + + protected function configure(): void { + $this + ->setName('memcache:redis:command') + ->setDescription('Send raw redis command to the configured redis server') + ->addArgument('redis-command', InputArgument::REQUIRED | InputArgument::IS_ARRAY, 'The command to run'); + parent::configure(); + } + + protected function execute(InputInterface $input, OutputInterface $output): int { + $command = $input->getArgument('redis-command'); + if (!$this->redisFactory->isAvailable()) { + $output->writeln("No redis server configured"); + return 1; + } + try { + $redis = $this->redisFactory->getInstance(); + } catch (\Exception $e) { + $output->writeln('Failed to connect to redis: ' . $e->getMessage()); + return 1; + } + + $redis->setOption(\Redis::OPT_REPLY_LITERAL, true); + $result = $redis->rawCommand(...$command); + if ($result === false) { + $output->writeln("Redis command failed"); + return 1; + } + $output->writeln($result); + return 0; + } +} diff --git a/core/register_command.php b/core/register_command.php index 5185da496b6e4..46af2a6b22a21 100644 --- a/core/register_command.php +++ b/core/register_command.php @@ -140,6 +140,8 @@ $application->add(Server::get(Command\Security\BruteforceResetAttempts::class)); $application->add(Server::get(Command\SetupChecks::class)); $application->add(Server::get(Command\FilesMetadata\Get::class)); + + $application->add(Server::get(Command\Memcache\RedisCommand::class)); } else { $application->add(Server::get(Command\Maintenance\Install::class)); } diff --git a/lib/composer/composer/autoload_classmap.php b/lib/composer/composer/autoload_classmap.php index ae747f8d24836..c331c3eb0f16e 100644 --- a/lib/composer/composer/autoload_classmap.php +++ b/lib/composer/composer/autoload_classmap.php @@ -1149,6 +1149,7 @@ 'OC\\Core\\Command\\Maintenance\\RepairShareOwnership' => $baseDir . '/core/Command/Maintenance/RepairShareOwnership.php', 'OC\\Core\\Command\\Maintenance\\UpdateHtaccess' => $baseDir . '/core/Command/Maintenance/UpdateHtaccess.php', 'OC\\Core\\Command\\Maintenance\\UpdateTheme' => $baseDir . '/core/Command/Maintenance/UpdateTheme.php', + 'OC\\Core\\Command\\Memcache\\RedisCommand' => $baseDir . '/core/Command/Memcache/RedisCommand.php', 'OC\\Core\\Command\\Preview\\Generate' => $baseDir . '/core/Command/Preview/Generate.php', 'OC\\Core\\Command\\Preview\\Repair' => $baseDir . '/core/Command/Preview/Repair.php', 'OC\\Core\\Command\\Preview\\ResetRenderedTexts' => $baseDir . '/core/Command/Preview/ResetRenderedTexts.php', diff --git a/lib/composer/composer/autoload_static.php b/lib/composer/composer/autoload_static.php index 45393c5481eb4..c72517690a310 100644 --- a/lib/composer/composer/autoload_static.php +++ b/lib/composer/composer/autoload_static.php @@ -1182,6 +1182,7 @@ class ComposerStaticInit749170dad3f5e7f9ca158f5a9f04f6a2 'OC\\Core\\Command\\Maintenance\\RepairShareOwnership' => __DIR__ . '/../../..' . '/core/Command/Maintenance/RepairShareOwnership.php', 'OC\\Core\\Command\\Maintenance\\UpdateHtaccess' => __DIR__ . '/../../..' . '/core/Command/Maintenance/UpdateHtaccess.php', 'OC\\Core\\Command\\Maintenance\\UpdateTheme' => __DIR__ . '/../../..' . '/core/Command/Maintenance/UpdateTheme.php', + 'OC\\Core\\Command\\Memcache\\RedisCommand' => __DIR__ . '/../../..' . '/core/Command/Memcache/RedisCommand.php', 'OC\\Core\\Command\\Preview\\Generate' => __DIR__ . '/../../..' . '/core/Command/Preview/Generate.php', 'OC\\Core\\Command\\Preview\\Repair' => __DIR__ . '/../../..' . '/core/Command/Preview/Repair.php', 'OC\\Core\\Command\\Preview\\ResetRenderedTexts' => __DIR__ . '/../../..' . '/core/Command/Preview/ResetRenderedTexts.php',