123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- <?php
- /**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Joas Schilling <coding@schilljs.com>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * 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, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
- */
- namespace OC\Core\Command\User;
- use OC\Core\Command\Base;
- use OCP\IUser;
- use OCP\IUserManager;
- use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext;
- use Symfony\Component\Console\Input\InputArgument;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- class Enable extends Base {
- public function __construct(
- protected IUserManager $userManager,
- ) {
- parent::__construct();
- }
- protected function configure() {
- $this
- ->setName('user:enable')
- ->setDescription('enables the specified user')
- ->addArgument(
- 'uid',
- InputArgument::REQUIRED,
- 'the username'
- );
- }
- protected function execute(InputInterface $input, OutputInterface $output): int {
- $user = $this->userManager->get($input->getArgument('uid'));
- if (is_null($user)) {
- $output->writeln('<error>User does not exist</error>');
- return 1;
- }
- $user->setEnabled(true);
- $output->writeln('<info>The specified user is enabled</info>');
- return 0;
- }
- /**
- * @param string $argumentName
- * @param CompletionContext $context
- * @return string[]
- */
- public function completeArgumentValues($argumentName, CompletionContext $context) {
- if ($argumentName === 'uid') {
- return array_map(
- static fn (IUser $user) => $user->getUID(),
- array_filter(
- $this->userManager->search($context->getCurrentWord()),
- static fn (IUser $user) => !$user->isEnabled()
- )
- );
- }
- return [];
- }
- }
|