2016-01-18 13:58:17 +03:00
|
|
|
<?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;
|
2016-05-13 12:56:47 +03:00
|
|
|
use OCA\Files_External\Lib\StorageConfig;
|
|
|
|
use OCA\Files_External\NotFoundException;
|
2016-05-13 12:22:28 +03:00
|
|
|
use OCA\Files_External\Service\GlobalStoragesService;
|
2016-01-18 13:58:17 +03:00
|
|
|
use OCP\IGroupManager;
|
|
|
|
use OCP\IUserManager;
|
|
|
|
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
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|