From 114eb6ba321bf50e984f7a86073c8ebefb12d1f8 Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Wed, 21 Sep 2016 14:39:32 +0200 Subject: Autocomplete for l10n:* and twofactorauth:* Signed-off-by: Joas Schilling --- core/Command/L10n/CreateJs.php | 32 +++++++++++++++++- core/Command/TwoFactorAuth/Base.php | 60 ++++++++++++++++++++++++++++++++++ core/Command/TwoFactorAuth/Disable.php | 9 +++-- core/Command/TwoFactorAuth/Enable.php | 9 +++-- 4 files changed, 99 insertions(+), 11 deletions(-) create mode 100644 core/Command/TwoFactorAuth/Base.php diff --git a/core/Command/L10n/CreateJs.php b/core/Command/L10n/CreateJs.php index 53e897e6b43..e52f588b831 100644 --- a/core/Command/L10n/CreateJs.php +++ b/core/Command/L10n/CreateJs.php @@ -25,13 +25,15 @@ namespace OC\Core\Command\L10n; use DirectoryIterator; +use Stecman\Component\Symfony\Console\BashCompletion\Completion\CompletionAwareInterface; +use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Output\OutputInterface; use UnexpectedValueException; -class CreateJs extends Command { +class CreateJs extends Command implements CompletionAwareInterface { protected function configure() { $this @@ -135,4 +137,32 @@ class CreateJs extends Command { return array($TRANSLATIONS, $PLURAL_FORMS); } + + /** + * Return possible values for the named option + * + * @param string $optionName + * @param CompletionContext $context + * @return string[] + */ + public function completeOptionValues($optionName, CompletionContext $context) { + return []; + } + + /** + * Return possible values for the named argument + * + * @param string $argumentName + * @param CompletionContext $context + * @return string[] + */ + public function completeArgumentValues($argumentName, CompletionContext $context) { + if ($argumentName === 'app') { + return \OC_App::getAllApps(); + } else if ($argumentName === 'lang') { + $appName = $context->getWordAtIndex($context->getWordIndex() - 1); + return $this->getAllLanguages(\OC_App::getAppPath($appName)); + } + return []; + } } diff --git a/core/Command/TwoFactorAuth/Base.php b/core/Command/TwoFactorAuth/Base.php new file mode 100644 index 00000000000..e99703ecd73 --- /dev/null +++ b/core/Command/TwoFactorAuth/Base.php @@ -0,0 +1,60 @@ + + * + * @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\TwoFactorAuth; + +use OCP\IUserManager; +use OCP\IUser; +use Stecman\Component\Symfony\Console\BashCompletion\Completion\CompletionAwareInterface; +use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext; + +class Base extends \OC\Core\Command\Base implements CompletionAwareInterface { + + /** @var IUserManager */ + protected $userManager; + + /** + * Return possible values for the named option + * + * @param string $optionName + * @param CompletionContext $context + * @return string[] + */ + public function completeOptionValues($optionName, CompletionContext $context) { + return []; + } + + /** + * Return possible values for the named argument + * + * @param string $argumentName + * @param CompletionContext $context + * @return string[] + */ + public function completeArgumentValues($argumentName, CompletionContext $context) { + if ($argumentName === 'uid') { + return array_map(function(IUser $user) { + return $user->getUID(); + }, $this->userManager->search($context->getCurrentWord(), 100)); + } + return []; + } +} diff --git a/core/Command/TwoFactorAuth/Disable.php b/core/Command/TwoFactorAuth/Disable.php index 60e1bf7181f..d0303edac39 100644 --- a/core/Command/TwoFactorAuth/Disable.php +++ b/core/Command/TwoFactorAuth/Disable.php @@ -23,8 +23,7 @@ namespace OC\Core\Command\TwoFactorAuth; use OC\Authentication\TwoFactorAuth\Manager; -use OC\User\Manager as UserManager; -use OC\Core\Command\Base; +use OCP\IUserManager; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; @@ -34,10 +33,10 @@ class Disable extends Base { /** @var Manager */ private $manager; - /** @var UserManager */ - private $userManager; + /** @var IUserManager */ + protected $userManager; - public function __construct(Manager $manager, UserManager $userManager) { + public function __construct(Manager $manager, IUserManager $userManager) { parent::__construct('twofactorauth:disable'); $this->manager = $manager; $this->userManager = $userManager; diff --git a/core/Command/TwoFactorAuth/Enable.php b/core/Command/TwoFactorAuth/Enable.php index 54fc6cdf065..a15fb83b666 100644 --- a/core/Command/TwoFactorAuth/Enable.php +++ b/core/Command/TwoFactorAuth/Enable.php @@ -23,8 +23,7 @@ namespace OC\Core\Command\TwoFactorAuth; use OC\Authentication\TwoFactorAuth\Manager; -use OC\User\Manager as UserManager; -use OC\Core\Command\Base; +use OCP\IUserManager; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; @@ -34,10 +33,10 @@ class Enable extends Base { /** @var Manager */ private $manager; - /** @var UserManager */ - private $userManager; + /** @var IUserManager */ + protected $userManager; - public function __construct(Manager $manager, UserManager $userManager) { + public function __construct(Manager $manager, IUserManager $userManager) { parent::__construct('twofactorauth:enable'); $this->manager = $manager; $this->userManager = $userManager; -- cgit v1.2.3