diff options
Diffstat (limited to 'apps/files_external/command/applicable.php')
-rw-r--r-- | apps/files_external/command/applicable.php | 157 |
1 files changed, 0 insertions, 157 deletions
diff --git a/apps/files_external/command/applicable.php b/apps/files_external/command/applicable.php deleted file mode 100644 index 7e6c99d2915..00000000000 --- a/apps/files_external/command/applicable.php +++ /dev/null @@ -1,157 +0,0 @@ -<?php -/** - * @author Robin Appelman <icewind@owncloud.com> - * - * @copyright Copyright (c) 2016, ownCloud, Inc. - * @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 OCA\Files_External\Command; - -use OC\Core\Command\Base; -use OCA\Files_external\Lib\StorageConfig; -use OCA\Files_external\NotFoundException; -use OCA\Files_external\Service\GlobalStoragesService; -use OCP\IGroupManager; -use OCP\IUserManager; -use Symfony\Component\Console\Command\Command; -use Symfony\Component\Console\Helper\Table; -use Symfony\Component\Console\Helper\TableHelper; -use Symfony\Component\Console\Input\InputArgument; -use Symfony\Component\Console\Input\InputInterface; -use Symfony\Component\Console\Input\InputOption; -use Symfony\Component\Console\Output\OutputInterface; - -class Applicable extends Base { - /** - * @var GlobalStoragesService - */ - protected $globalService; - - /** - * @var IUserManager - */ - private $userManager; - - /** - * @var IGroupManager - */ - private $groupManager; - - function __construct( - GlobalStoragesService $globalService, - IUserManager $userManager, - IGroupManager $groupManager - ) { - parent::__construct(); - $this->globalService = $globalService; - $this->userManager = $userManager; - $this->groupManager = $groupManager; - } - - protected function configure() { - $this - ->setName('files_external:applicable') - ->setDescription('Manage applicable users and groups for a mount') - ->addArgument( - 'mount_id', - InputArgument::REQUIRED, - 'The id of the mount to edit' - )->addOption( - 'add-user', - null, - InputOption::VALUE_IS_ARRAY | InputOption::VALUE_REQUIRED, - 'user to add as applicable' - )->addOption( - 'remove-user', - null, - InputOption::VALUE_IS_ARRAY | InputOption::VALUE_REQUIRED, - 'user to remove as applicable' - )->addOption( - 'add-group', - null, - InputOption::VALUE_IS_ARRAY | InputOption::VALUE_REQUIRED, - 'group to add as applicable' - )->addOption( - 'remove-group', - null, - InputOption::VALUE_IS_ARRAY | InputOption::VALUE_REQUIRED, - 'group to remove as applicable' - )->addOption( - 'remove-all', - null, - InputOption::VALUE_NONE, - 'Set the mount to be globally applicable' - ); - parent::configure(); - } - - protected function execute(InputInterface $input, OutputInterface $output) { - $mountId = $input->getArgument('mount_id'); - try { - $mount = $this->globalService->getStorage($mountId); - } catch (NotFoundException $e) { - $output->writeln('<error>Mount with id "' . $mountId . ' not found, check "occ files_external:list" to get available mounts</error>'); - return 404; - } - - if ($mount->getType() === StorageConfig::MOUNT_TYPE_PERSONAl) { - $output->writeln('<error>Can\'t change applicables on personal mounts</error>'); - return 1; - } - - $addUsers = $input->getOption('add-user'); - $removeUsers = $input->getOption('remove-user'); - $addGroups = $input->getOption('add-group'); - $removeGroups = $input->getOption('remove-group'); - - $applicableUsers = $mount->getApplicableUsers(); - $applicableGroups = $mount->getApplicableGroups(); - - if ((count($addUsers) + count($removeUsers) + count($addGroups) + count($removeGroups) > 0) || $input->getOption('remove-all')) { - foreach ($addUsers as $addUser) { - if (!$this->userManager->userExists($addUser)) { - $output->writeln('<error>User "' . $addUser . '" not found</error>'); - return 404; - } - } - foreach ($addGroups as $addGroup) { - if (!$this->groupManager->groupExists($addGroup)) { - $output->writeln('<error>Group "' . $addGroup . '" not found</error>'); - return 404; - } - } - - if ($input->getOption('remove-all')) { - $applicableUsers = []; - $applicableGroups = []; - } else { - $applicableUsers = array_unique(array_merge($applicableUsers, $addUsers)); - $applicableUsers = array_values(array_diff($applicableUsers, $removeUsers)); - $applicableGroups = array_unique(array_merge($applicableGroups, $addGroups)); - $applicableGroups = array_values(array_diff($applicableGroups, $removeGroups)); - } - $mount->setApplicableUsers($applicableUsers); - $mount->setApplicableGroups($applicableGroups); - $this->globalService->updateStorage($mount); - } - - $this->writeArrayInOutputFormat($input, $output, [ - 'users' => $applicableUsers, - 'groups' => $applicableGroups - ]); - } -} |