mirror of
https://github.com/verdigado/organization_folders.git
synced 2024-12-06 11:22:41 +01:00
many small resource member related improvements
This commit is contained in:
parent
8bfa9dfa29
commit
9ebae48238
9 changed files with 70 additions and 45 deletions
|
@ -8,8 +8,9 @@ use Symfony\Component\Console\Input\InputInterface;
|
|||
use Symfony\Component\Console\Output\OutputInterface;
|
||||
|
||||
use OCA\OrganizationFolders\Command\BaseCommand;
|
||||
use OCA\OrganizationFolders\Enum\MemberType;
|
||||
use OCA\OrganizationFolders\Enum\MemberPermissionLevel;
|
||||
use OCA\OrganizationFolders\Model\Principal;
|
||||
use OCA\OrganizationFolders\Enum\PrincipalType;
|
||||
use OCA\OrganizationFolders\Enum\ResourceMemberPermissionLevel;
|
||||
|
||||
class CreateResourceMember extends BaseCommand {
|
||||
protected function configure(): void {
|
||||
|
@ -18,27 +19,26 @@ class CreateResourceMember extends BaseCommand {
|
|||
->setDescription('Create a new member of resource')
|
||||
->addOption('resource-id', null, InputOption::VALUE_REQUIRED, 'Id of resource to create member of')
|
||||
->addOption('permission-level', null, InputOption::VALUE_REQUIRED, 'Permissions level of member (valid values: MEMBER, MANAGER)')
|
||||
->addOption('type', null, InputOption::VALUE_REQUIRED, 'Type of principal (valid values: USER, GROUP, ROLE)')
|
||||
->addOption('principal', null, InputOption::VALUE_OPTIONAL, 'For type user: "[user_id]", for group: "[group_name]", for role: "[organization_provider_id]:[role_id]"');
|
||||
->addOption('principal-type', null, InputOption::VALUE_REQUIRED, 'Type of principal (valid values: USER, GROUP, ROLE)')
|
||||
->addOption('principal-id', null, InputOption::VALUE_OPTIONAL, 'For type user: "[user_id]", for group: "[group_name]", for role: "[organization_provider_id]:[role_id]"');
|
||||
|
||||
parent::configure();
|
||||
}
|
||||
|
||||
protected function execute(InputInterface $input, OutputInterface $output): int {
|
||||
$resourceId = $input->getOption('resource-id');
|
||||
$permissionLevel = MemberPermissionLevel::fromNameOrValue($input->getOption('permission-level'));
|
||||
$type = MemberType::fromNameOrValue($input->getOption('type'));
|
||||
$principal = $input->getOption('principal');
|
||||
$permissionLevel = ResourceMemberPermissionLevel::fromNameOrValue($input->getOption('permission-level'));
|
||||
$principalType = PrincipalType::fromNameOrValue($input->getOption('principal-type'));
|
||||
$principalId = $input->getOption('principal-id');
|
||||
|
||||
try {
|
||||
$resource = $this->resourceMemberService->create(
|
||||
$member = $this->resourceMemberService->create(
|
||||
resourceId: $resourceId,
|
||||
permissionLevel: $permissionLevel,
|
||||
type: $type,
|
||||
principal: $principal,
|
||||
principal: new Principal($principalType, $principalId),
|
||||
);
|
||||
|
||||
$this->writeTableInOutputFormat($input, $output, [$this->formatTableSerializable($resource)]);
|
||||
$this->writeTableInOutputFormat($input, $output, [$this->formatTableSerializable($member)]);
|
||||
return 0;
|
||||
} catch (Exception $e) {
|
||||
$output->writeln("<error>Exception \"{$e->getMessage()}\" at {$e->getFile()} line {$e->getLine()}</error>");
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue