From eed32112c504d6333232a1d77e8007f2bdfa40b7 Mon Sep 17 00:00:00 2001 From: Lucas Azevedo Date: Wed, 23 Aug 2023 20:15:42 -0300 Subject: [PATCH] feat: Add user:auth-tokens command Signed-off-by: Lucas Azevedo --- core/Command/User/AuthTokens.php | 70 ++++++++++++++++++++++++++++++++ core/register_command.php | 1 + 2 files changed, 71 insertions(+) create mode 100644 core/Command/User/AuthTokens.php diff --git a/core/Command/User/AuthTokens.php b/core/Command/User/AuthTokens.php new file mode 100644 index 00000000000..938efd952a5 --- /dev/null +++ b/core/Command/User/AuthTokens.php @@ -0,0 +1,70 @@ + + * + * @author Lucas Azevedo + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + */ +namespace OC\Core\Command\User; + +use OC\Core\Command\Base; +use OC\Authentication\Token\IProvider; +use OC\Authentication\Token\IToken; +use OCP\IUserManager; +use Symfony\Component\Console\Input\InputArgument; +use Symfony\Component\Console\Input\InputInterface; +use Symfony\Component\Console\Output\OutputInterface; + +class AuthTokens extends Base { + public function __construct( + protected IUserManager $userManager, + protected IProvider $tokenProvider, + ) { + parent::__construct(); + } + + protected function configure() { + parent::configure(); + + $this + ->setName('user:auth-tokens') + ->setDescription('List authentication tokens of an user') + ->addArgument( + 'user', + InputArgument::REQUIRED, + 'User to list auth tokens for' + ); + } + + protected function execute(InputInterface $input, OutputInterface $output): int { + $user = $this->userManager->get($input->getArgument('user')); + + if (is_null($user)) { + $output->writeln('user not found'); + return 1; + } + + $tokens = $this->tokenProvider->getTokenByUser($user->getUID()); + + $data = array_map(fn (IToken $token) => $token->jsonSerialize(), $tokens); + + $this->writeArrayInOutputFormat($input, $output, $data); + + return 0; + } +} diff --git a/core/register_command.php b/core/register_command.php index c9b6cc99901..c82c076c207 100644 --- a/core/register_command.php +++ b/core/register_command.php @@ -193,6 +193,7 @@ if (\OC::$server->getConfig()->getSystemValue('installed', false)) { $application->add(new OC\Core\Command\User\ListCommand(\OC::$server->getUserManager(), \OC::$server->getGroupManager())); $application->add(new OC\Core\Command\User\Info(\OC::$server->getUserManager(), \OC::$server->getGroupManager())); $application->add(new OC\Core\Command\User\AddAppPassword(\OC::$server->get(\OCP\IUserManager::class), \OC::$server->get(\OC\Authentication\Token\IProvider::class), \OC::$server->get(\OCP\Security\ISecureRandom::class), \OC::$server->get(\OCP\EventDispatcher\IEventDispatcher::class))); + $application->add(new OC\Core\Command\User\AuthTokens(\OC::$server->get(\OCP\IUserManager::class), \OC::$server->get(\OC\Authentication\Token\IProvider::class))); $application->add(new OC\Core\Command\Group\Add(\OC::$server->getGroupManager())); $application->add(new OC\Core\Command\Group\Delete(\OC::$server->getGroupManager())); -- 2.39.5