aboutsummaryrefslogtreecommitdiffstats
path: root/core/Command/Group/AddUser.php
diff options
context:
space:
mode:
Diffstat (limited to 'core/Command/Group/AddUser.php')
-rw-r--r--core/Command/Group/AddUser.php79
1 files changed, 79 insertions, 0 deletions
diff --git a/core/Command/Group/AddUser.php b/core/Command/Group/AddUser.php
new file mode 100644
index 00000000000..999113390af
--- /dev/null
+++ b/core/Command/Group/AddUser.php
@@ -0,0 +1,79 @@
+<?php
+
+/**
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
+ */
+namespace OC\Core\Command\Group;
+
+use OC\Core\Command\Base;
+use OCP\IGroup;
+use OCP\IGroupManager;
+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 AddUser extends Base {
+ public function __construct(
+ protected IUserManager $userManager,
+ protected IGroupManager $groupManager,
+ ) {
+ parent::__construct();
+ }
+
+ protected function configure() {
+ $this
+ ->setName('group:adduser')
+ ->setDescription('add a user to a group')
+ ->addArgument(
+ 'group',
+ InputArgument::REQUIRED,
+ 'group to add the user to'
+ )->addArgument(
+ 'user',
+ InputArgument::REQUIRED,
+ 'user to add to the group'
+ );
+ }
+
+ protected function execute(InputInterface $input, OutputInterface $output): int {
+ $group = $this->groupManager->get($input->getArgument('group'));
+ if (is_null($group)) {
+ $output->writeln('<error>group not found</error>');
+ return 1;
+ }
+ $user = $this->userManager->get($input->getArgument('user'));
+ if (is_null($user)) {
+ $output->writeln('<error>user not found</error>');
+ return 1;
+ }
+ $group->addUser($user);
+ return 0;
+ }
+
+ /**
+ * @param string $argumentName
+ * @param CompletionContext $context
+ * @return string[]
+ */
+ public function completeArgumentValues($argumentName, CompletionContext $context) {
+ if ($argumentName === 'group') {
+ return array_map(static fn (IGroup $group) => $group->getGID(), $this->groupManager->search($context->getCurrentWord()));
+ }
+ if ($argumentName === 'user') {
+ $groupId = $context->getWordAtIndex($context->getWordIndex() - 1);
+ $group = $this->groupManager->get($groupId);
+ if ($group === null) {
+ return [];
+ }
+
+ $members = array_map(static fn (IUser $user) => $user->getUID(), $group->searchUsers($context->getCurrentWord()));
+ $users = array_map(static fn (IUser $user) => $user->getUID(), $this->userManager->search($context->getCurrentWord()));
+ return array_diff($users, $members);
+ }
+ return [];
+ }
+}