summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDenis Mosolov <denismosolov@gmail.com>2018-07-22 20:29:07 +0300
committerDenis Mosolov <denismosolov@gmail.com>2018-08-16 10:31:20 +0300
commit0b18e2c75da4474d9ab7c018209b17d584185939 (patch)
tree90a9d88bce431e5fa554ed3ff0e804a23c97107a
parent61397ee091287e983d0ff345b0e43fb4a3329f19 (diff)
downloadnextcloud-server-0b18e2c75da4474d9ab7c018209b17d584185939.tar.gz
nextcloud-server-0b18e2c75da4474d9ab7c018209b17d584185939.zip
Add an options to create and remove groups via occ
Signed-off-by: Denis Mosolov <denismosolov@gmail.com>
-rw-r--r--core/Command/Group/Add.php67
-rw-r--r--core/Command/Group/Delete.php74
-rw-r--r--core/register_command.php2
-rw-r--r--lib/composer/composer/autoload_classmap.php2
-rw-r--r--lib/composer/composer/autoload_static.php2
-rw-r--r--tests/Core/Command/Group/AddTest.php98
-rw-r--r--tests/Core/Command/Group/DeleteTest.php148
7 files changed, 393 insertions, 0 deletions
diff --git a/core/Command/Group/Add.php b/core/Command/Group/Add.php
new file mode 100644
index 00000000000..61253cf163d
--- /dev/null
+++ b/core/Command/Group/Add.php
@@ -0,0 +1,67 @@
+<?php
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2018 Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @author Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @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 <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OC\Core\Command\Group;
+
+use OC\Core\Command\Base;
+use OCP\IGroupManager;
+use Symfony\Component\Console\Input\InputArgument;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+
+class Add extends Base {
+ /** @var IGroupManager */
+ protected $groupManager;
+
+ /**
+ * @param IGroupManager $groupManager
+ */
+ public function __construct(IGroupManager $groupManager) {
+ $this->groupManager = $groupManager;
+ parent::__construct();
+ }
+
+ protected function configure() {
+ $this
+ ->setName('group:add')
+ ->setDescription('Add a group')
+ ->addArgument(
+ 'groupid',
+ InputArgument::REQUIRED,
+ 'Group name'
+ );
+ }
+
+ protected function execute(InputInterface $input, OutputInterface $output) {
+ $gid = $input->getArgument('groupid');
+ $group = $this->groupManager->get($gid);
+ if ($group) {
+ $output->writeln('<error>Group "' . $gid . '" already exists.</error>');
+ return 1;
+ } else {
+ $group = $this->groupManager->createGroup($gid);
+ $output->writeln('Created group "' . $group->getGID() . '"');
+ }
+ }
+}
diff --git a/core/Command/Group/Delete.php b/core/Command/Group/Delete.php
new file mode 100644
index 00000000000..a4b630a6387
--- /dev/null
+++ b/core/Command/Group/Delete.php
@@ -0,0 +1,74 @@
+<?php
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2018 Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @author Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @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 <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OC\Core\Command\Group;
+
+use OC\Core\Command\Base;
+use OCP\IGroupManager;
+use Symfony\Component\Console\Input\InputArgument;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+
+class Delete extends Base {
+ /** @var IGroupManager */
+ protected $groupManager;
+
+ /**
+ * @param IGroupManager $groupManager
+ */
+ public function __construct(IGroupManager $groupManager) {
+ $this->groupManager = $groupManager;
+ parent::__construct();
+ }
+
+ protected function configure() {
+ $this
+ ->setName('group:delete')
+ ->setDescription('Remove a group')
+ ->addArgument(
+ 'groupid',
+ InputArgument::REQUIRED,
+ 'Group name'
+ );
+ }
+
+ protected function execute(InputInterface $input, OutputInterface $output) {
+ $gid = $input->getArgument('groupid');
+ if ($gid === 'admin') {
+ $output->writeln('<error>Group "' . $gid . '" could not be deleted.</error>');
+ return 1;
+ }
+ if (! $this->groupManager->groupExists($gid)) {
+ $output->writeln('<error>Group "' . $gid . '" does not exist.</error>');
+ return 1;
+ }
+ $group = $this->groupManager->get($gid);
+ if ($group->delete()) {
+ $output->writeln('Group "' . $gid . '" was removed');
+ } else {
+ $output->writeln('<error>Group "' . $gid . '" could not be deleted. Please check the logs.</error>');
+ return 1;
+ }
+ }
+}
diff --git a/core/register_command.php b/core/register_command.php
index 0115c179bf9..744ee23e16b 100644
--- a/core/register_command.php
+++ b/core/register_command.php
@@ -154,6 +154,8 @@ if (\OC::$server->getConfig()->getSystemValue('installed', false)) {
$application->add(new OC\Core\Command\User\ListCommand(\OC::$server->getUserManager()));
$application->add(new OC\Core\Command\User\Info(\OC::$server->getUserManager(), \OC::$server->getGroupManager()));
+ $application->add(new OC\Core\Command\Group\Add(\OC::$server->getGroupManager()));
+ $application->add(new OC\Core\Command\Group\Delete(\OC::$server->getGroupManager()));
$application->add(new OC\Core\Command\Group\ListCommand(\OC::$server->getGroupManager()));
$application->add(new OC\Core\Command\Group\AddUser(\OC::$server->getUserManager(), \OC::$server->getGroupManager()));
$application->add(new OC\Core\Command\Group\RemoveUser(\OC::$server->getUserManager(), \OC::$server->getGroupManager()));
diff --git a/lib/composer/composer/autoload_classmap.php b/lib/composer/composer/autoload_classmap.php
index 44b7cd5244f..8b571f48f88 100644
--- a/lib/composer/composer/autoload_classmap.php
+++ b/lib/composer/composer/autoload_classmap.php
@@ -541,7 +541,9 @@ return array(
'OC\\Core\\Command\\Encryption\\SetDefaultModule' => $baseDir . '/core/Command/Encryption/SetDefaultModule.php',
'OC\\Core\\Command\\Encryption\\ShowKeyStorageRoot' => $baseDir . '/core/Command/Encryption/ShowKeyStorageRoot.php',
'OC\\Core\\Command\\Encryption\\Status' => $baseDir . '/core/Command/Encryption/Status.php',
+ 'OC\\Core\\Command\\Group\\Add' => $baseDir . '/core/Command/Group/Add.php',
'OC\\Core\\Command\\Group\\AddUser' => $baseDir . '/core/Command/Group/AddUser.php',
+ 'OC\\Core\\Command\\Group\\Delete' => $baseDir . '/core/Command/Group/Delete.php',
'OC\\Core\\Command\\Group\\ListCommand' => $baseDir . '/core/Command/Group/ListCommand.php',
'OC\\Core\\Command\\Group\\RemoveUser' => $baseDir . '/core/Command/Group/RemoveUser.php',
'OC\\Core\\Command\\Integrity\\CheckApp' => $baseDir . '/core/Command/Integrity/CheckApp.php',
diff --git a/lib/composer/composer/autoload_static.php b/lib/composer/composer/autoload_static.php
index 815f94d5711..6aa0efa29de 100644
--- a/lib/composer/composer/autoload_static.php
+++ b/lib/composer/composer/autoload_static.php
@@ -571,7 +571,9 @@ class ComposerStaticInit53792487c5a8370acc0b06b1a864ff4c
'OC\\Core\\Command\\Encryption\\SetDefaultModule' => __DIR__ . '/../../..' . '/core/Command/Encryption/SetDefaultModule.php',
'OC\\Core\\Command\\Encryption\\ShowKeyStorageRoot' => __DIR__ . '/../../..' . '/core/Command/Encryption/ShowKeyStorageRoot.php',
'OC\\Core\\Command\\Encryption\\Status' => __DIR__ . '/../../..' . '/core/Command/Encryption/Status.php',
+ 'OC\\Core\\Command\\Group\\Add' => __DIR__ . '/../../..' . '/core/Command/Group/Add.php',
'OC\\Core\\Command\\Group\\AddUser' => __DIR__ . '/../../..' . '/core/Command/Group/AddUser.php',
+ 'OC\\Core\\Command\\Group\\Delete' => __DIR__ . '/../../..' . '/core/Command/Group/Delete.php',
'OC\\Core\\Command\\Group\\ListCommand' => __DIR__ . '/../../..' . '/core/Command/Group/ListCommand.php',
'OC\\Core\\Command\\Group\\RemoveUser' => __DIR__ . '/../../..' . '/core/Command/Group/RemoveUser.php',
'OC\\Core\\Command\\Integrity\\CheckApp' => __DIR__ . '/../../..' . '/core/Command/Integrity/CheckApp.php',
diff --git a/tests/Core/Command/Group/AddTest.php b/tests/Core/Command/Group/AddTest.php
new file mode 100644
index 00000000000..8aa2f040de1
--- /dev/null
+++ b/tests/Core/Command/Group/AddTest.php
@@ -0,0 +1,98 @@
+<?php
+/**
+ * @copyright 2018, Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @author Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @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 Afferoq 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 <http://www.gnu.org/licenses/>.
+ *
+ */
+namespace Test\Core\Command\Group;
+
+use OC\Core\Command\Group\Add;
+use OCP\IGroup;
+use OCP\IGroupManager;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+use Test\TestCase;
+
+class AddTest extends TestCase {
+
+ /** @var IGroupManager|\PHPUnit_Framework_MockObject_MockObject */
+ private $groupManager;
+
+ /** @var Add */
+ private $command;
+
+ /** @var InputInterface|\PHPUnit_Framework_MockObject_MockObject */
+ private $input;
+
+ /** @var OutputInterface|\PHPUnit_Framework_MockObject_MockObject */
+ private $output;
+
+ public function setUp() {
+ parent::setUp();
+
+ $this->groupManager = $this->createMock(IGroupManager::class);
+ $this->command = new Add($this->groupManager);
+
+ $this->input = $this->createMock(InputInterface::class);
+ $this->input->method('getArgument')
+ ->willReturnCallback(function($arg) {
+ if ($arg === 'groupid') {
+ return 'myGroup';
+ }
+ throw new \Exception();
+ });
+ $this->output = $this->createMock(OutputInterface::class);
+ }
+
+ public function testGroupExists() {
+ $gid = 'myGroup';
+ $group = $this->createMock(IGroup::class);
+ $this->groupManager->method('get')
+ ->with($gid)
+ ->willReturn($group);
+
+ $this->groupManager->expects($this->never())
+ ->method('createGroup');
+ $this->output->expects($this->once())
+ ->method('writeln')
+ ->with($this->equalTo('<error>Group "' . $gid . '" already exists.</error>'));
+
+ $this->invokePrivate($this->command, 'execute', [$this->input, $this->output]);
+ }
+
+ public function testAdd() {
+ $gid = 'myGroup';
+ $group = $this->createMock(IGroup::class);
+ $group->method('getGID')
+ ->willReturn($gid);
+ $this->groupManager->method('createGroup')
+ ->willReturn($group);
+
+ $this->groupManager->expects($this->once())
+ ->method('createGroup')
+ ->with($this->equalTo($gid));
+ $this->output->expects($this->once())
+ ->method('writeln')
+ ->with($this->equalTo('Created group "' . $group->getGID() . '"'));
+
+ $this->invokePrivate($this->command, 'execute', [$this->input, $this->output]);
+ }
+
+
+}
diff --git a/tests/Core/Command/Group/DeleteTest.php b/tests/Core/Command/Group/DeleteTest.php
new file mode 100644
index 00000000000..708e10b0581
--- /dev/null
+++ b/tests/Core/Command/Group/DeleteTest.php
@@ -0,0 +1,148 @@
+<?php
+/**
+ * @copyright 2018, Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @author Denis Mosolov <denismosolov@gmail.com>
+ *
+ * @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 Afferoq 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 <http://www.gnu.org/licenses/>.
+ *
+ */
+namespace Test\Core\Command\Group;
+
+use OC\Core\Command\Group\Delete;
+use OCP\IGroup;
+use OCP\IGroupManager;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+use Test\TestCase;
+
+class DeleteTest extends TestCase {
+
+ /** @var IGroupManager|\PHPUnit_Framework_MockObject_MockObject */
+ private $groupManager;
+
+ /** @var Delete */
+ private $command;
+
+ /** @var InputInterface|\PHPUnit_Framework_MockObject_MockObject */
+ private $input;
+
+ /** @var OutputInterface|\PHPUnit_Framework_MockObject_MockObject */
+ private $output;
+
+ public function setUp() {
+ parent::setUp();
+
+ $this->groupManager = $this->createMock(IGroupManager::class);
+ $this->command = new Delete($this->groupManager);
+
+ $this->input = $this->createMock(InputInterface::class);
+ $this->output = $this->createMock(OutputInterface::class);
+ }
+
+ public function testDoesNotExists() {
+ $gid = 'myGroup';
+ $this->input->method('getArgument')
+ ->willReturnCallback(function($arg) use ($gid) {
+ if ($arg === 'groupid') {
+ return $gid;
+ }
+ throw new \Exception();
+ });
+ $this->groupManager->method('groupExists')
+ ->with($gid)
+ ->willReturn(false);
+
+ $this->groupManager->expects($this->never())
+ ->method('get');
+ $this->output->expects($this->once())
+ ->method('writeln')
+ ->with($this->equalTo('<error>Group "' . $gid . '" does not exist.</error>'));
+
+ $this->invokePrivate($this->command, 'execute', [$this->input, $this->output]);
+ }
+
+ public function testDeleteAdmin() {
+ $gid = 'admin';
+ $this->input->method('getArgument')
+ ->willReturnCallback(function($arg) use ($gid) {
+ if ($arg === 'groupid') {
+ return $gid;
+ }
+ throw new \Exception();
+ });
+
+ $this->groupManager->expects($this->never())
+ ->method($this->anything());
+ $this->output->expects($this->once())
+ ->method('writeln')
+ ->with($this->equalTo('<error>Group "' . $gid . '" could not be deleted.</error>'));
+
+ $this->invokePrivate($this->command, 'execute', [$this->input, $this->output]);
+ }
+
+ public function testDeleteFailed() {
+ $gid = 'myGroup';
+ $this->input->method('getArgument')
+ ->willReturnCallback(function($arg) use ($gid) {
+ if ($arg === 'groupid') {
+ return $gid;
+ }
+ throw new \Exception();
+ });
+ $group = $this->createMock(IGroup::class);
+ $group->method('delete')
+ ->willReturn(false);
+ $this->groupManager->method('groupExists')
+ ->with($gid)
+ ->willReturn(true);
+ $this->groupManager->method('get')
+ ->with($gid)
+ ->willReturn($group);
+
+ $this->output->expects($this->once())
+ ->method('writeln')
+ ->with($this->equalTo('<error>Group "' . $gid . '" could not be deleted. Please check the logs.</error>'));
+
+ $this->invokePrivate($this->command, 'execute', [$this->input, $this->output]);
+ }
+
+ public function testDelete() {
+ $gid = 'myGroup';
+ $this->input->method('getArgument')
+ ->willReturnCallback(function($arg) use ($gid) {
+ if ($arg === 'groupid') {
+ return $gid;
+ }
+ throw new \Exception();
+ });
+ $group = $this->createMock(IGroup::class);
+ $group->method('delete')
+ ->willReturn(true);
+ $this->groupManager->method('groupExists')
+ ->with($gid)
+ ->willReturn(true);
+ $this->groupManager->method('get')
+ ->with($gid)
+ ->willReturn($group);
+
+ $this->output->expects($this->once())
+ ->method('writeln')
+ ->with($this->equalTo('Group "' . $gid . '" was removed'));
+
+ $this->invokePrivate($this->command, 'execute', [$this->input, $this->output]);
+ }
+}