@@ -76,7 +76,7 @@ |
||
| 76 | 76 | $data = [ |
| 77 | 77 | 'user_id' => $user->getUID(), |
| 78 | 78 | 'display_name' => $user->getDisplayName(), |
| 79 | - 'email' => (string)$user->getSystemEMailAddress(), |
|
| 79 | + 'email' => (string) $user->getSystemEMailAddress(), |
|
| 80 | 80 | 'cloud_id' => $user->getCloudId(), |
| 81 | 81 | 'enabled' => $user->isEnabled(), |
| 82 | 82 | 'groups' => $groups, |
@@ -17,95 +17,95 @@ |
||
| 17 | 17 | use Symfony\Component\Console\Output\OutputInterface; |
| 18 | 18 | |
| 19 | 19 | class Info extends Base { |
| 20 | - public function __construct( |
|
| 21 | - protected IUserManager $userManager, |
|
| 22 | - protected IGroupManager $groupManager, |
|
| 23 | - ) { |
|
| 24 | - parent::__construct(); |
|
| 25 | - } |
|
| 20 | + public function __construct( |
|
| 21 | + protected IUserManager $userManager, |
|
| 22 | + protected IGroupManager $groupManager, |
|
| 23 | + ) { |
|
| 24 | + parent::__construct(); |
|
| 25 | + } |
|
| 26 | 26 | |
| 27 | - protected function configure() { |
|
| 28 | - $this |
|
| 29 | - ->setName('user:info') |
|
| 30 | - ->setDescription('show user info') |
|
| 31 | - ->addArgument( |
|
| 32 | - 'user', |
|
| 33 | - InputArgument::REQUIRED, |
|
| 34 | - 'user to show' |
|
| 35 | - )->addOption( |
|
| 36 | - 'output', |
|
| 37 | - null, |
|
| 38 | - InputOption::VALUE_OPTIONAL, |
|
| 39 | - 'Output format (plain, json or json_pretty, default is plain)', |
|
| 40 | - $this->defaultOutputFormat |
|
| 41 | - ); |
|
| 42 | - } |
|
| 27 | + protected function configure() { |
|
| 28 | + $this |
|
| 29 | + ->setName('user:info') |
|
| 30 | + ->setDescription('show user info') |
|
| 31 | + ->addArgument( |
|
| 32 | + 'user', |
|
| 33 | + InputArgument::REQUIRED, |
|
| 34 | + 'user to show' |
|
| 35 | + )->addOption( |
|
| 36 | + 'output', |
|
| 37 | + null, |
|
| 38 | + InputOption::VALUE_OPTIONAL, |
|
| 39 | + 'Output format (plain, json or json_pretty, default is plain)', |
|
| 40 | + $this->defaultOutputFormat |
|
| 41 | + ); |
|
| 42 | + } |
|
| 43 | 43 | |
| 44 | - protected function execute(InputInterface $input, OutputInterface $output): int { |
|
| 45 | - $user = $this->userManager->get($input->getArgument('user')); |
|
| 46 | - if (is_null($user)) { |
|
| 47 | - $output->writeln('<error>user not found</error>'); |
|
| 48 | - return 1; |
|
| 49 | - } |
|
| 50 | - $groups = $this->groupManager->getUserGroupIds($user); |
|
| 51 | - $data = [ |
|
| 52 | - 'user_id' => $user->getUID(), |
|
| 53 | - 'display_name' => $user->getDisplayName(), |
|
| 54 | - 'email' => (string)$user->getSystemEMailAddress(), |
|
| 55 | - 'cloud_id' => $user->getCloudId(), |
|
| 56 | - 'enabled' => $user->isEnabled(), |
|
| 57 | - 'groups' => $groups, |
|
| 58 | - 'quota' => $user->getQuota(), |
|
| 59 | - 'storage' => $this->getStorageInfo($user), |
|
| 60 | - 'first_seen' => $this->formatLoginDate($user->getFirstLogin()), |
|
| 61 | - 'last_seen' => $this->formatLoginDate($user->getLastLogin()), |
|
| 62 | - 'user_directory' => $user->getHome(), |
|
| 63 | - 'backend' => $user->getBackendClassName() |
|
| 64 | - ]; |
|
| 65 | - $this->writeArrayInOutputFormat($input, $output, $data); |
|
| 66 | - return 0; |
|
| 67 | - } |
|
| 44 | + protected function execute(InputInterface $input, OutputInterface $output): int { |
|
| 45 | + $user = $this->userManager->get($input->getArgument('user')); |
|
| 46 | + if (is_null($user)) { |
|
| 47 | + $output->writeln('<error>user not found</error>'); |
|
| 48 | + return 1; |
|
| 49 | + } |
|
| 50 | + $groups = $this->groupManager->getUserGroupIds($user); |
|
| 51 | + $data = [ |
|
| 52 | + 'user_id' => $user->getUID(), |
|
| 53 | + 'display_name' => $user->getDisplayName(), |
|
| 54 | + 'email' => (string)$user->getSystemEMailAddress(), |
|
| 55 | + 'cloud_id' => $user->getCloudId(), |
|
| 56 | + 'enabled' => $user->isEnabled(), |
|
| 57 | + 'groups' => $groups, |
|
| 58 | + 'quota' => $user->getQuota(), |
|
| 59 | + 'storage' => $this->getStorageInfo($user), |
|
| 60 | + 'first_seen' => $this->formatLoginDate($user->getFirstLogin()), |
|
| 61 | + 'last_seen' => $this->formatLoginDate($user->getLastLogin()), |
|
| 62 | + 'user_directory' => $user->getHome(), |
|
| 63 | + 'backend' => $user->getBackendClassName() |
|
| 64 | + ]; |
|
| 65 | + $this->writeArrayInOutputFormat($input, $output, $data); |
|
| 66 | + return 0; |
|
| 67 | + } |
|
| 68 | 68 | |
| 69 | - private function formatLoginDate(int $timestamp): string { |
|
| 70 | - if ($timestamp < 0) { |
|
| 71 | - return 'unknown'; |
|
| 72 | - } elseif ($timestamp === 0) { |
|
| 73 | - return 'never'; |
|
| 74 | - } else { |
|
| 75 | - return date(\DateTimeInterface::ATOM, $timestamp); // ISO-8601 |
|
| 76 | - } |
|
| 77 | - } |
|
| 69 | + private function formatLoginDate(int $timestamp): string { |
|
| 70 | + if ($timestamp < 0) { |
|
| 71 | + return 'unknown'; |
|
| 72 | + } elseif ($timestamp === 0) { |
|
| 73 | + return 'never'; |
|
| 74 | + } else { |
|
| 75 | + return date(\DateTimeInterface::ATOM, $timestamp); // ISO-8601 |
|
| 76 | + } |
|
| 77 | + } |
|
| 78 | 78 | |
| 79 | - /** |
|
| 80 | - * @param IUser $user |
|
| 81 | - * @return array |
|
| 82 | - */ |
|
| 83 | - protected function getStorageInfo(IUser $user): array { |
|
| 84 | - \OC_Util::tearDownFS(); |
|
| 85 | - \OC_Util::setupFS($user->getUID()); |
|
| 86 | - try { |
|
| 87 | - $storage = \OC_Helper::getStorageInfo('/'); |
|
| 88 | - } catch (NotFoundException $e) { |
|
| 89 | - return []; |
|
| 90 | - } |
|
| 91 | - return [ |
|
| 92 | - 'free' => $storage['free'], |
|
| 93 | - 'used' => $storage['used'], |
|
| 94 | - 'total' => $storage['total'], |
|
| 95 | - 'relative' => $storage['relative'], |
|
| 96 | - 'quota' => $storage['quota'], |
|
| 97 | - ]; |
|
| 98 | - } |
|
| 79 | + /** |
|
| 80 | + * @param IUser $user |
|
| 81 | + * @return array |
|
| 82 | + */ |
|
| 83 | + protected function getStorageInfo(IUser $user): array { |
|
| 84 | + \OC_Util::tearDownFS(); |
|
| 85 | + \OC_Util::setupFS($user->getUID()); |
|
| 86 | + try { |
|
| 87 | + $storage = \OC_Helper::getStorageInfo('/'); |
|
| 88 | + } catch (NotFoundException $e) { |
|
| 89 | + return []; |
|
| 90 | + } |
|
| 91 | + return [ |
|
| 92 | + 'free' => $storage['free'], |
|
| 93 | + 'used' => $storage['used'], |
|
| 94 | + 'total' => $storage['total'], |
|
| 95 | + 'relative' => $storage['relative'], |
|
| 96 | + 'quota' => $storage['quota'], |
|
| 97 | + ]; |
|
| 98 | + } |
|
| 99 | 99 | |
| 100 | - /** |
|
| 101 | - * @param string $argumentName |
|
| 102 | - * @param CompletionContext $context |
|
| 103 | - * @return string[] |
|
| 104 | - */ |
|
| 105 | - public function completeArgumentValues($argumentName, CompletionContext $context) { |
|
| 106 | - if ($argumentName === 'user') { |
|
| 107 | - return array_map(static fn (IUser $user) => $user->getUID(), $this->userManager->search($context->getCurrentWord())); |
|
| 108 | - } |
|
| 109 | - return []; |
|
| 110 | - } |
|
| 100 | + /** |
|
| 101 | + * @param string $argumentName |
|
| 102 | + * @param CompletionContext $context |
|
| 103 | + * @return string[] |
|
| 104 | + */ |
|
| 105 | + public function completeArgumentValues($argumentName, CompletionContext $context) { |
|
| 106 | + if ($argumentName === 'user') { |
|
| 107 | + return array_map(static fn (IUser $user) => $user->getUID(), $this->userManager->search($context->getCurrentWord())); |
|
| 108 | + } |
|
| 109 | + return []; |
|
| 110 | + } |
|
| 111 | 111 | } |
@@ -60,7 +60,7 @@ |
||
| 60 | 60 | 'notnull' => true, |
| 61 | 61 | ]); |
| 62 | 62 | $table->setPrimaryKey(['id']); |
| 63 | - $table->addUniqueIndex(['user_id'], self::TABLE_NAME . '_user_id_idx'); |
|
| 63 | + $table->addUniqueIndex(['user_id'], self::TABLE_NAME.'_user_id_idx'); |
|
| 64 | 64 | return $schema; |
| 65 | 65 | } |
| 66 | 66 | |
@@ -16,37 +16,37 @@ |
||
| 16 | 16 | use OCP\Migration\SimpleMigrationStep; |
| 17 | 17 | |
| 18 | 18 | class Version23000Date20210930122352 extends SimpleMigrationStep { |
| 19 | - private const TABLE_NAME = 'profile_config'; |
|
| 20 | - |
|
| 21 | - /** |
|
| 22 | - * @param IOutput $output |
|
| 23 | - * @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper` |
|
| 24 | - * @param array $options |
|
| 25 | - * @return null|ISchemaWrapper |
|
| 26 | - */ |
|
| 27 | - public function changeSchema(IOutput $output, Closure $schemaClosure, array $options): ?ISchemaWrapper { |
|
| 28 | - /** @var ISchemaWrapper $schema */ |
|
| 29 | - $schema = $schemaClosure(); |
|
| 30 | - |
|
| 31 | - $hasTable = $schema->hasTable(self::TABLE_NAME); |
|
| 32 | - if (!$hasTable) { |
|
| 33 | - $table = $schema->createTable(self::TABLE_NAME); |
|
| 34 | - $table->addColumn('id', Types::BIGINT, [ |
|
| 35 | - 'autoincrement' => true, |
|
| 36 | - 'notnull' => true, |
|
| 37 | - ]); |
|
| 38 | - $table->addColumn('user_id', Types::STRING, [ |
|
| 39 | - 'notnull' => true, |
|
| 40 | - 'length' => 64, |
|
| 41 | - ]); |
|
| 42 | - $table->addColumn('config', Types::TEXT, [ |
|
| 43 | - 'notnull' => true, |
|
| 44 | - ]); |
|
| 45 | - $table->setPrimaryKey(['id']); |
|
| 46 | - $table->addUniqueIndex(['user_id'], self::TABLE_NAME . '_user_id_idx'); |
|
| 47 | - return $schema; |
|
| 48 | - } |
|
| 49 | - |
|
| 50 | - return null; |
|
| 51 | - } |
|
| 19 | + private const TABLE_NAME = 'profile_config'; |
|
| 20 | + |
|
| 21 | + /** |
|
| 22 | + * @param IOutput $output |
|
| 23 | + * @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper` |
|
| 24 | + * @param array $options |
|
| 25 | + * @return null|ISchemaWrapper |
|
| 26 | + */ |
|
| 27 | + public function changeSchema(IOutput $output, Closure $schemaClosure, array $options): ?ISchemaWrapper { |
|
| 28 | + /** @var ISchemaWrapper $schema */ |
|
| 29 | + $schema = $schemaClosure(); |
|
| 30 | + |
|
| 31 | + $hasTable = $schema->hasTable(self::TABLE_NAME); |
|
| 32 | + if (!$hasTable) { |
|
| 33 | + $table = $schema->createTable(self::TABLE_NAME); |
|
| 34 | + $table->addColumn('id', Types::BIGINT, [ |
|
| 35 | + 'autoincrement' => true, |
|
| 36 | + 'notnull' => true, |
|
| 37 | + ]); |
|
| 38 | + $table->addColumn('user_id', Types::STRING, [ |
|
| 39 | + 'notnull' => true, |
|
| 40 | + 'length' => 64, |
|
| 41 | + ]); |
|
| 42 | + $table->addColumn('config', Types::TEXT, [ |
|
| 43 | + 'notnull' => true, |
|
| 44 | + ]); |
|
| 45 | + $table->setPrimaryKey(['id']); |
|
| 46 | + $table->addUniqueIndex(['user_id'], self::TABLE_NAME . '_user_id_idx'); |
|
| 47 | + return $schema; |
|
| 48 | + } |
|
| 49 | + |
|
| 50 | + return null; |
|
| 51 | + } |
|
| 52 | 52 | } |
@@ -32,23 +32,23 @@ |
||
| 32 | 32 | use OCP\Migration\SimpleMigrationStep; |
| 33 | 33 | |
| 34 | 34 | class Version23000Date20211203110726 extends SimpleMigrationStep { |
| 35 | - private const TABLE_NAME = 'profile_config'; |
|
| 35 | + private const TABLE_NAME = 'profile_config'; |
|
| 36 | 36 | |
| 37 | - /** |
|
| 38 | - * @param IOutput $output |
|
| 39 | - * @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper` |
|
| 40 | - * @param array $options |
|
| 41 | - * @return null|ISchemaWrapper |
|
| 42 | - */ |
|
| 43 | - public function changeSchema(IOutput $output, Closure $schemaClosure, array $options): ?ISchemaWrapper { |
|
| 44 | - /** @var ISchemaWrapper $schema */ |
|
| 45 | - $schema = $schemaClosure(); |
|
| 37 | + /** |
|
| 38 | + * @param IOutput $output |
|
| 39 | + * @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper` |
|
| 40 | + * @param array $options |
|
| 41 | + * @return null|ISchemaWrapper |
|
| 42 | + */ |
|
| 43 | + public function changeSchema(IOutput $output, Closure $schemaClosure, array $options): ?ISchemaWrapper { |
|
| 44 | + /** @var ISchemaWrapper $schema */ |
|
| 45 | + $schema = $schemaClosure(); |
|
| 46 | 46 | |
| 47 | - $table = $schema->getTable(self::TABLE_NAME); |
|
| 48 | - if ($table->hasIndex('user_id')) { |
|
| 49 | - $table->renameIndex('user_id', self::TABLE_NAME . '_user_id_idx'); |
|
| 50 | - return $schema; |
|
| 51 | - } |
|
| 52 | - return null; |
|
| 53 | - } |
|
| 47 | + $table = $schema->getTable(self::TABLE_NAME); |
|
| 48 | + if ($table->hasIndex('user_id')) { |
|
| 49 | + $table->renameIndex('user_id', self::TABLE_NAME . '_user_id_idx'); |
|
| 50 | + return $schema; |
|
| 51 | + } |
|
| 52 | + return null; |
|
| 53 | + } |
|
| 54 | 54 | } |
@@ -46,7 +46,7 @@ |
||
| 46 | 46 | |
| 47 | 47 | $table = $schema->getTable(self::TABLE_NAME); |
| 48 | 48 | if ($table->hasIndex('user_id')) { |
| 49 | - $table->renameIndex('user_id', self::TABLE_NAME . '_user_id_idx'); |
|
| 49 | + $table->renameIndex('user_id', self::TABLE_NAME.'_user_id_idx'); |
|
| 50 | 50 | return $schema; |
| 51 | 51 | } |
| 52 | 52 | return null; |
@@ -31,7 +31,7 @@ |
||
| 31 | 31 | * Defines the public facing principal option |
| 32 | 32 | */ |
| 33 | 33 | class PublicPrincipalPlugin extends Plugin { |
| 34 | - public function getCurrentPrincipal(): ?string { |
|
| 35 | - return 'principals/system/public'; |
|
| 36 | - } |
|
| 34 | + public function getCurrentPrincipal(): ?string { |
|
| 35 | + return 'principals/system/public'; |
|
| 36 | + } |
|
| 37 | 37 | } |
@@ -32,7 +32,7 @@ |
||
| 32 | 32 | * Set a custom principal uri to allow public requests to its calendar |
| 33 | 33 | */ |
| 34 | 34 | class CustomPrincipalPlugin extends Plugin { |
| 35 | - public function setCurrentPrincipal(?string $currentPrincipal): void { |
|
| 36 | - $this->currentPrincipal = $currentPrincipal; |
|
| 37 | - } |
|
| 35 | + public function setCurrentPrincipal(?string $currentPrincipal): void { |
|
| 36 | + $this->currentPrincipal = $currentPrincipal; |
|
| 37 | + } |
|
| 38 | 38 | } |
@@ -73,11 +73,11 @@ discard block |
||
| 73 | 73 | $this->loadContext('assembly'); |
| 74 | 74 | |
| 75 | 75 | $nodes = $this->nodes; |
| 76 | - usort($nodes, function (IFile $a, IFile $b) { |
|
| 76 | + usort($nodes, function(IFile $a, IFile $b) { |
|
| 77 | 77 | return strnatcmp($a->getName(), $b->getName()); |
| 78 | 78 | }); |
| 79 | 79 | $this->nodes = array_values($nodes); |
| 80 | - $this->size = array_reduce($this->nodes, function ($size, IFile $file) { |
|
| 80 | + $this->size = array_reduce($this->nodes, function($size, IFile $file) { |
|
| 81 | 81 | return $size + $file->getSize(); |
| 82 | 82 | }, 0); |
| 83 | 83 | |
@@ -156,7 +156,7 @@ discard block |
||
| 156 | 156 | fclose($this->currentStream); |
| 157 | 157 | $currentNodeSize = $this->nodes[$this->currentNode]->getSize(); |
| 158 | 158 | if ($this->currentNodeRead < $currentNodeSize) { |
| 159 | - throw new \Exception('Stream from assembly node shorter than expected, got ' . $this->currentNodeRead . ' bytes, expected ' . $currentNodeSize); |
|
| 159 | + throw new \Exception('Stream from assembly node shorter than expected, got '.$this->currentNodeRead.' bytes, expected '.$currentNodeSize); |
|
| 160 | 160 | } |
| 161 | 161 | $this->currentNode++; |
| 162 | 162 | $this->currentNodeRead = 0; |
@@ -253,7 +253,7 @@ discard block |
||
| 253 | 253 | if (isset($context[$name])) { |
| 254 | 254 | $context = $context[$name]; |
| 255 | 255 | } else { |
| 256 | - throw new \BadMethodCallException('Invalid context, "' . $name . '" options not set'); |
|
| 256 | + throw new \BadMethodCallException('Invalid context, "'.$name.'" options not set'); |
|
| 257 | 257 | } |
| 258 | 258 | if (isset($context['nodes']) and is_array($context['nodes'])) { |
| 259 | 259 | $this->nodes = $context['nodes']; |
@@ -20,270 +20,270 @@ |
||
| 20 | 20 | */ |
| 21 | 21 | class AssemblyStream implements \Icewind\Streams\File { |
| 22 | 22 | |
| 23 | - /** @var resource */ |
|
| 24 | - private $context; |
|
| 25 | - |
|
| 26 | - /** @var IFile[] */ |
|
| 27 | - private $nodes; |
|
| 28 | - |
|
| 29 | - /** @var int */ |
|
| 30 | - private $pos = 0; |
|
| 31 | - |
|
| 32 | - /** @var int */ |
|
| 33 | - private $size = 0; |
|
| 34 | - |
|
| 35 | - /** @var resource */ |
|
| 36 | - private $currentStream = null; |
|
| 37 | - |
|
| 38 | - /** @var int */ |
|
| 39 | - private $currentNode = 0; |
|
| 40 | - |
|
| 41 | - /** @var int */ |
|
| 42 | - private $currentNodeRead = 0; |
|
| 43 | - |
|
| 44 | - /** |
|
| 45 | - * @param string $path |
|
| 46 | - * @param string $mode |
|
| 47 | - * @param int $options |
|
| 48 | - * @param string &$opened_path |
|
| 49 | - * @return bool |
|
| 50 | - */ |
|
| 51 | - public function stream_open($path, $mode, $options, &$opened_path) { |
|
| 52 | - $this->loadContext('assembly'); |
|
| 53 | - |
|
| 54 | - $nodes = $this->nodes; |
|
| 55 | - usort($nodes, function (IFile $a, IFile $b) { |
|
| 56 | - return strnatcmp($a->getName(), $b->getName()); |
|
| 57 | - }); |
|
| 58 | - $this->nodes = array_values($nodes); |
|
| 59 | - $this->size = array_reduce($this->nodes, function ($size, IFile $file) { |
|
| 60 | - return $size + $file->getSize(); |
|
| 61 | - }, 0); |
|
| 62 | - |
|
| 63 | - return true; |
|
| 64 | - } |
|
| 65 | - |
|
| 66 | - /** |
|
| 67 | - * @param int $offset |
|
| 68 | - * @param int $whence |
|
| 69 | - * @return bool |
|
| 70 | - */ |
|
| 71 | - public function stream_seek($offset, $whence = SEEK_SET) { |
|
| 72 | - if ($whence === SEEK_CUR) { |
|
| 73 | - $offset = $this->stream_tell() + $offset; |
|
| 74 | - } elseif ($whence === SEEK_END) { |
|
| 75 | - $offset = $this->size + $offset; |
|
| 76 | - } |
|
| 77 | - |
|
| 78 | - if ($offset === $this->pos) { |
|
| 79 | - return true; |
|
| 80 | - } |
|
| 81 | - |
|
| 82 | - if ($offset > $this->size) { |
|
| 83 | - return false; |
|
| 84 | - } |
|
| 85 | - |
|
| 86 | - $nodeIndex = 0; |
|
| 87 | - $nodeStart = 0; |
|
| 88 | - while (true) { |
|
| 89 | - if (!isset($this->nodes[$nodeIndex + 1])) { |
|
| 90 | - break; |
|
| 91 | - } |
|
| 92 | - $node = $this->nodes[$nodeIndex]; |
|
| 93 | - if ($nodeStart + $node->getSize() > $offset) { |
|
| 94 | - break; |
|
| 95 | - } |
|
| 96 | - $nodeIndex++; |
|
| 97 | - $nodeStart += $node->getSize(); |
|
| 98 | - } |
|
| 99 | - |
|
| 100 | - $stream = $this->getStream($this->nodes[$nodeIndex]); |
|
| 101 | - $nodeOffset = $offset - $nodeStart; |
|
| 102 | - if ($nodeOffset > 0 && fseek($stream, $nodeOffset) === -1) { |
|
| 103 | - return false; |
|
| 104 | - } |
|
| 105 | - $this->currentNode = $nodeIndex; |
|
| 106 | - $this->currentNodeRead = $nodeOffset; |
|
| 107 | - $this->currentStream = $stream; |
|
| 108 | - $this->pos = $offset; |
|
| 109 | - |
|
| 110 | - return true; |
|
| 111 | - } |
|
| 112 | - |
|
| 113 | - /** |
|
| 114 | - * @return int |
|
| 115 | - */ |
|
| 116 | - public function stream_tell() { |
|
| 117 | - return $this->pos; |
|
| 118 | - } |
|
| 119 | - |
|
| 120 | - /** |
|
| 121 | - * @param int $count |
|
| 122 | - * @return string |
|
| 123 | - */ |
|
| 124 | - public function stream_read($count) { |
|
| 125 | - if (is_null($this->currentStream)) { |
|
| 126 | - if ($this->currentNode < count($this->nodes)) { |
|
| 127 | - $this->currentStream = $this->getStream($this->nodes[$this->currentNode]); |
|
| 128 | - } else { |
|
| 129 | - return ''; |
|
| 130 | - } |
|
| 131 | - } |
|
| 132 | - |
|
| 133 | - $collectedData = ''; |
|
| 134 | - // read data until we either got all the data requested or there is no more stream left |
|
| 135 | - while ($count > 0 && !is_null($this->currentStream)) { |
|
| 136 | - $data = fread($this->currentStream, $count); |
|
| 137 | - $read = strlen($data); |
|
| 138 | - |
|
| 139 | - $count -= $read; |
|
| 140 | - $collectedData .= $data; |
|
| 141 | - $this->currentNodeRead += $read; |
|
| 142 | - |
|
| 143 | - if (feof($this->currentStream)) { |
|
| 144 | - fclose($this->currentStream); |
|
| 145 | - $currentNodeSize = $this->nodes[$this->currentNode]->getSize(); |
|
| 146 | - if ($this->currentNodeRead < $currentNodeSize) { |
|
| 147 | - throw new \Exception('Stream from assembly node shorter than expected, got ' . $this->currentNodeRead . ' bytes, expected ' . $currentNodeSize); |
|
| 148 | - } |
|
| 149 | - $this->currentNode++; |
|
| 150 | - $this->currentNodeRead = 0; |
|
| 151 | - if ($this->currentNode < count($this->nodes)) { |
|
| 152 | - $this->currentStream = $this->getStream($this->nodes[$this->currentNode]); |
|
| 153 | - } else { |
|
| 154 | - $this->currentStream = null; |
|
| 155 | - } |
|
| 156 | - } |
|
| 157 | - } |
|
| 158 | - |
|
| 159 | - // update position |
|
| 160 | - $this->pos += strlen($collectedData); |
|
| 161 | - return $collectedData; |
|
| 162 | - } |
|
| 163 | - |
|
| 164 | - /** |
|
| 165 | - * @param string $data |
|
| 166 | - * @return int |
|
| 167 | - */ |
|
| 168 | - public function stream_write($data) { |
|
| 169 | - return false; |
|
| 170 | - } |
|
| 171 | - |
|
| 172 | - /** |
|
| 173 | - * @param int $option |
|
| 174 | - * @param int $arg1 |
|
| 175 | - * @param int $arg2 |
|
| 176 | - * @return bool |
|
| 177 | - */ |
|
| 178 | - public function stream_set_option($option, $arg1, $arg2) { |
|
| 179 | - return false; |
|
| 180 | - } |
|
| 181 | - |
|
| 182 | - /** |
|
| 183 | - * @param int $size |
|
| 184 | - * @return bool |
|
| 185 | - */ |
|
| 186 | - public function stream_truncate($size) { |
|
| 187 | - return false; |
|
| 188 | - } |
|
| 189 | - |
|
| 190 | - /** |
|
| 191 | - * @return array |
|
| 192 | - */ |
|
| 193 | - public function stream_stat() { |
|
| 194 | - return [ |
|
| 195 | - 'size' => $this->size, |
|
| 196 | - ]; |
|
| 197 | - } |
|
| 198 | - |
|
| 199 | - /** |
|
| 200 | - * @param int $operation |
|
| 201 | - * @return bool |
|
| 202 | - */ |
|
| 203 | - public function stream_lock($operation) { |
|
| 204 | - return false; |
|
| 205 | - } |
|
| 206 | - |
|
| 207 | - /** |
|
| 208 | - * @return bool |
|
| 209 | - */ |
|
| 210 | - public function stream_flush() { |
|
| 211 | - return false; |
|
| 212 | - } |
|
| 213 | - |
|
| 214 | - /** |
|
| 215 | - * @return bool |
|
| 216 | - */ |
|
| 217 | - public function stream_eof() { |
|
| 218 | - return $this->pos >= $this->size || ($this->currentNode >= count($this->nodes) && $this->currentNode === null); |
|
| 219 | - } |
|
| 220 | - |
|
| 221 | - /** |
|
| 222 | - * @return bool |
|
| 223 | - */ |
|
| 224 | - public function stream_close() { |
|
| 225 | - return true; |
|
| 226 | - } |
|
| 227 | - |
|
| 228 | - |
|
| 229 | - /** |
|
| 230 | - * Load the source from the stream context and return the context options |
|
| 231 | - * |
|
| 232 | - * @param string $name |
|
| 233 | - * @return array |
|
| 234 | - * @throws \BadMethodCallException |
|
| 235 | - */ |
|
| 236 | - protected function loadContext($name) { |
|
| 237 | - $context = stream_context_get_options($this->context); |
|
| 238 | - if (isset($context[$name])) { |
|
| 239 | - $context = $context[$name]; |
|
| 240 | - } else { |
|
| 241 | - throw new \BadMethodCallException('Invalid context, "' . $name . '" options not set'); |
|
| 242 | - } |
|
| 243 | - if (isset($context['nodes']) and is_array($context['nodes'])) { |
|
| 244 | - $this->nodes = $context['nodes']; |
|
| 245 | - } else { |
|
| 246 | - throw new \BadMethodCallException('Invalid context, nodes not set'); |
|
| 247 | - } |
|
| 248 | - return $context; |
|
| 249 | - } |
|
| 250 | - |
|
| 251 | - /** |
|
| 252 | - * @param IFile[] $nodes |
|
| 253 | - * @return resource |
|
| 254 | - * |
|
| 255 | - * @throws \BadMethodCallException |
|
| 256 | - */ |
|
| 257 | - public static function wrap(array $nodes) { |
|
| 258 | - $context = stream_context_create([ |
|
| 259 | - 'assembly' => [ |
|
| 260 | - 'nodes' => $nodes |
|
| 261 | - ] |
|
| 262 | - ]); |
|
| 263 | - stream_wrapper_register('assembly', self::class); |
|
| 264 | - try { |
|
| 265 | - $wrapped = fopen('assembly://', 'r', false, $context); |
|
| 266 | - } catch (\BadMethodCallException $e) { |
|
| 267 | - stream_wrapper_unregister('assembly'); |
|
| 268 | - throw $e; |
|
| 269 | - } |
|
| 270 | - stream_wrapper_unregister('assembly'); |
|
| 271 | - return $wrapped; |
|
| 272 | - } |
|
| 273 | - |
|
| 274 | - /** |
|
| 275 | - * @param IFile $node |
|
| 276 | - * @return resource |
|
| 277 | - */ |
|
| 278 | - private function getStream(IFile $node) { |
|
| 279 | - $data = $node->get(); |
|
| 280 | - if (is_resource($data)) { |
|
| 281 | - return $data; |
|
| 282 | - } else { |
|
| 283 | - $tmp = fopen('php://temp', 'w+'); |
|
| 284 | - fwrite($tmp, $data); |
|
| 285 | - rewind($tmp); |
|
| 286 | - return $tmp; |
|
| 287 | - } |
|
| 288 | - } |
|
| 23 | + /** @var resource */ |
|
| 24 | + private $context; |
|
| 25 | + |
|
| 26 | + /** @var IFile[] */ |
|
| 27 | + private $nodes; |
|
| 28 | + |
|
| 29 | + /** @var int */ |
|
| 30 | + private $pos = 0; |
|
| 31 | + |
|
| 32 | + /** @var int */ |
|
| 33 | + private $size = 0; |
|
| 34 | + |
|
| 35 | + /** @var resource */ |
|
| 36 | + private $currentStream = null; |
|
| 37 | + |
|
| 38 | + /** @var int */ |
|
| 39 | + private $currentNode = 0; |
|
| 40 | + |
|
| 41 | + /** @var int */ |
|
| 42 | + private $currentNodeRead = 0; |
|
| 43 | + |
|
| 44 | + /** |
|
| 45 | + * @param string $path |
|
| 46 | + * @param string $mode |
|
| 47 | + * @param int $options |
|
| 48 | + * @param string &$opened_path |
|
| 49 | + * @return bool |
|
| 50 | + */ |
|
| 51 | + public function stream_open($path, $mode, $options, &$opened_path) { |
|
| 52 | + $this->loadContext('assembly'); |
|
| 53 | + |
|
| 54 | + $nodes = $this->nodes; |
|
| 55 | + usort($nodes, function (IFile $a, IFile $b) { |
|
| 56 | + return strnatcmp($a->getName(), $b->getName()); |
|
| 57 | + }); |
|
| 58 | + $this->nodes = array_values($nodes); |
|
| 59 | + $this->size = array_reduce($this->nodes, function ($size, IFile $file) { |
|
| 60 | + return $size + $file->getSize(); |
|
| 61 | + }, 0); |
|
| 62 | + |
|
| 63 | + return true; |
|
| 64 | + } |
|
| 65 | + |
|
| 66 | + /** |
|
| 67 | + * @param int $offset |
|
| 68 | + * @param int $whence |
|
| 69 | + * @return bool |
|
| 70 | + */ |
|
| 71 | + public function stream_seek($offset, $whence = SEEK_SET) { |
|
| 72 | + if ($whence === SEEK_CUR) { |
|
| 73 | + $offset = $this->stream_tell() + $offset; |
|
| 74 | + } elseif ($whence === SEEK_END) { |
|
| 75 | + $offset = $this->size + $offset; |
|
| 76 | + } |
|
| 77 | + |
|
| 78 | + if ($offset === $this->pos) { |
|
| 79 | + return true; |
|
| 80 | + } |
|
| 81 | + |
|
| 82 | + if ($offset > $this->size) { |
|
| 83 | + return false; |
|
| 84 | + } |
|
| 85 | + |
|
| 86 | + $nodeIndex = 0; |
|
| 87 | + $nodeStart = 0; |
|
| 88 | + while (true) { |
|
| 89 | + if (!isset($this->nodes[$nodeIndex + 1])) { |
|
| 90 | + break; |
|
| 91 | + } |
|
| 92 | + $node = $this->nodes[$nodeIndex]; |
|
| 93 | + if ($nodeStart + $node->getSize() > $offset) { |
|
| 94 | + break; |
|
| 95 | + } |
|
| 96 | + $nodeIndex++; |
|
| 97 | + $nodeStart += $node->getSize(); |
|
| 98 | + } |
|
| 99 | + |
|
| 100 | + $stream = $this->getStream($this->nodes[$nodeIndex]); |
|
| 101 | + $nodeOffset = $offset - $nodeStart; |
|
| 102 | + if ($nodeOffset > 0 && fseek($stream, $nodeOffset) === -1) { |
|
| 103 | + return false; |
|
| 104 | + } |
|
| 105 | + $this->currentNode = $nodeIndex; |
|
| 106 | + $this->currentNodeRead = $nodeOffset; |
|
| 107 | + $this->currentStream = $stream; |
|
| 108 | + $this->pos = $offset; |
|
| 109 | + |
|
| 110 | + return true; |
|
| 111 | + } |
|
| 112 | + |
|
| 113 | + /** |
|
| 114 | + * @return int |
|
| 115 | + */ |
|
| 116 | + public function stream_tell() { |
|
| 117 | + return $this->pos; |
|
| 118 | + } |
|
| 119 | + |
|
| 120 | + /** |
|
| 121 | + * @param int $count |
|
| 122 | + * @return string |
|
| 123 | + */ |
|
| 124 | + public function stream_read($count) { |
|
| 125 | + if (is_null($this->currentStream)) { |
|
| 126 | + if ($this->currentNode < count($this->nodes)) { |
|
| 127 | + $this->currentStream = $this->getStream($this->nodes[$this->currentNode]); |
|
| 128 | + } else { |
|
| 129 | + return ''; |
|
| 130 | + } |
|
| 131 | + } |
|
| 132 | + |
|
| 133 | + $collectedData = ''; |
|
| 134 | + // read data until we either got all the data requested or there is no more stream left |
|
| 135 | + while ($count > 0 && !is_null($this->currentStream)) { |
|
| 136 | + $data = fread($this->currentStream, $count); |
|
| 137 | + $read = strlen($data); |
|
| 138 | + |
|
| 139 | + $count -= $read; |
|
| 140 | + $collectedData .= $data; |
|
| 141 | + $this->currentNodeRead += $read; |
|
| 142 | + |
|
| 143 | + if (feof($this->currentStream)) { |
|
| 144 | + fclose($this->currentStream); |
|
| 145 | + $currentNodeSize = $this->nodes[$this->currentNode]->getSize(); |
|
| 146 | + if ($this->currentNodeRead < $currentNodeSize) { |
|
| 147 | + throw new \Exception('Stream from assembly node shorter than expected, got ' . $this->currentNodeRead . ' bytes, expected ' . $currentNodeSize); |
|
| 148 | + } |
|
| 149 | + $this->currentNode++; |
|
| 150 | + $this->currentNodeRead = 0; |
|
| 151 | + if ($this->currentNode < count($this->nodes)) { |
|
| 152 | + $this->currentStream = $this->getStream($this->nodes[$this->currentNode]); |
|
| 153 | + } else { |
|
| 154 | + $this->currentStream = null; |
|
| 155 | + } |
|
| 156 | + } |
|
| 157 | + } |
|
| 158 | + |
|
| 159 | + // update position |
|
| 160 | + $this->pos += strlen($collectedData); |
|
| 161 | + return $collectedData; |
|
| 162 | + } |
|
| 163 | + |
|
| 164 | + /** |
|
| 165 | + * @param string $data |
|
| 166 | + * @return int |
|
| 167 | + */ |
|
| 168 | + public function stream_write($data) { |
|
| 169 | + return false; |
|
| 170 | + } |
|
| 171 | + |
|
| 172 | + /** |
|
| 173 | + * @param int $option |
|
| 174 | + * @param int $arg1 |
|
| 175 | + * @param int $arg2 |
|
| 176 | + * @return bool |
|
| 177 | + */ |
|
| 178 | + public function stream_set_option($option, $arg1, $arg2) { |
|
| 179 | + return false; |
|
| 180 | + } |
|
| 181 | + |
|
| 182 | + /** |
|
| 183 | + * @param int $size |
|
| 184 | + * @return bool |
|
| 185 | + */ |
|
| 186 | + public function stream_truncate($size) { |
|
| 187 | + return false; |
|
| 188 | + } |
|
| 189 | + |
|
| 190 | + /** |
|
| 191 | + * @return array |
|
| 192 | + */ |
|
| 193 | + public function stream_stat() { |
|
| 194 | + return [ |
|
| 195 | + 'size' => $this->size, |
|
| 196 | + ]; |
|
| 197 | + } |
|
| 198 | + |
|
| 199 | + /** |
|
| 200 | + * @param int $operation |
|
| 201 | + * @return bool |
|
| 202 | + */ |
|
| 203 | + public function stream_lock($operation) { |
|
| 204 | + return false; |
|
| 205 | + } |
|
| 206 | + |
|
| 207 | + /** |
|
| 208 | + * @return bool |
|
| 209 | + */ |
|
| 210 | + public function stream_flush() { |
|
| 211 | + return false; |
|
| 212 | + } |
|
| 213 | + |
|
| 214 | + /** |
|
| 215 | + * @return bool |
|
| 216 | + */ |
|
| 217 | + public function stream_eof() { |
|
| 218 | + return $this->pos >= $this->size || ($this->currentNode >= count($this->nodes) && $this->currentNode === null); |
|
| 219 | + } |
|
| 220 | + |
|
| 221 | + /** |
|
| 222 | + * @return bool |
|
| 223 | + */ |
|
| 224 | + public function stream_close() { |
|
| 225 | + return true; |
|
| 226 | + } |
|
| 227 | + |
|
| 228 | + |
|
| 229 | + /** |
|
| 230 | + * Load the source from the stream context and return the context options |
|
| 231 | + * |
|
| 232 | + * @param string $name |
|
| 233 | + * @return array |
|
| 234 | + * @throws \BadMethodCallException |
|
| 235 | + */ |
|
| 236 | + protected function loadContext($name) { |
|
| 237 | + $context = stream_context_get_options($this->context); |
|
| 238 | + if (isset($context[$name])) { |
|
| 239 | + $context = $context[$name]; |
|
| 240 | + } else { |
|
| 241 | + throw new \BadMethodCallException('Invalid context, "' . $name . '" options not set'); |
|
| 242 | + } |
|
| 243 | + if (isset($context['nodes']) and is_array($context['nodes'])) { |
|
| 244 | + $this->nodes = $context['nodes']; |
|
| 245 | + } else { |
|
| 246 | + throw new \BadMethodCallException('Invalid context, nodes not set'); |
|
| 247 | + } |
|
| 248 | + return $context; |
|
| 249 | + } |
|
| 250 | + |
|
| 251 | + /** |
|
| 252 | + * @param IFile[] $nodes |
|
| 253 | + * @return resource |
|
| 254 | + * |
|
| 255 | + * @throws \BadMethodCallException |
|
| 256 | + */ |
|
| 257 | + public static function wrap(array $nodes) { |
|
| 258 | + $context = stream_context_create([ |
|
| 259 | + 'assembly' => [ |
|
| 260 | + 'nodes' => $nodes |
|
| 261 | + ] |
|
| 262 | + ]); |
|
| 263 | + stream_wrapper_register('assembly', self::class); |
|
| 264 | + try { |
|
| 265 | + $wrapped = fopen('assembly://', 'r', false, $context); |
|
| 266 | + } catch (\BadMethodCallException $e) { |
|
| 267 | + stream_wrapper_unregister('assembly'); |
|
| 268 | + throw $e; |
|
| 269 | + } |
|
| 270 | + stream_wrapper_unregister('assembly'); |
|
| 271 | + return $wrapped; |
|
| 272 | + } |
|
| 273 | + |
|
| 274 | + /** |
|
| 275 | + * @param IFile $node |
|
| 276 | + * @return resource |
|
| 277 | + */ |
|
| 278 | + private function getStream(IFile $node) { |
|
| 279 | + $data = $node->get(); |
|
| 280 | + if (is_resource($data)) { |
|
| 281 | + return $data; |
|
| 282 | + } else { |
|
| 283 | + $tmp = fopen('php://temp', 'w+'); |
|
| 284 | + fwrite($tmp, $data); |
|
| 285 | + rewind($tmp); |
|
| 286 | + return $tmp; |
|
| 287 | + } |
|
| 288 | + } |
|
| 289 | 289 | } |
@@ -85,7 +85,7 @@ |
||
| 85 | 85 | |
| 86 | 86 | public function getAuthorizedAppConfig(): array { |
| 87 | 87 | return [ |
| 88 | - 'dav' => ['/(' . implode('|', array_keys(self::defaults)) . ')/'] |
|
| 88 | + 'dav' => ['/('.implode('|', array_keys(self::defaults)).')/'] |
|
| 89 | 89 | ]; |
| 90 | 90 | } |
| 91 | 91 | } |
@@ -15,59 +15,59 @@ |
||
| 15 | 15 | |
| 16 | 16 | class CalDAVSettings implements IDelegatedSettings { |
| 17 | 17 | |
| 18 | - private const defaults = [ |
|
| 19 | - 'sendInvitations' => 'yes', |
|
| 20 | - 'generateBirthdayCalendar' => 'yes', |
|
| 21 | - 'sendEventReminders' => 'yes', |
|
| 22 | - 'sendEventRemindersToSharedUsers' => 'yes', |
|
| 23 | - 'sendEventRemindersPush' => 'yes', |
|
| 24 | - ]; |
|
| 18 | + private const defaults = [ |
|
| 19 | + 'sendInvitations' => 'yes', |
|
| 20 | + 'generateBirthdayCalendar' => 'yes', |
|
| 21 | + 'sendEventReminders' => 'yes', |
|
| 22 | + 'sendEventRemindersToSharedUsers' => 'yes', |
|
| 23 | + 'sendEventRemindersPush' => 'yes', |
|
| 24 | + ]; |
|
| 25 | 25 | |
| 26 | - /** |
|
| 27 | - * CalDAVSettings constructor. |
|
| 28 | - * |
|
| 29 | - * @param IConfig $config |
|
| 30 | - * @param IInitialState $initialState |
|
| 31 | - */ |
|
| 32 | - public function __construct( |
|
| 33 | - private IConfig $config, |
|
| 34 | - private IInitialState $initialState, |
|
| 35 | - private IURLGenerator $urlGenerator, |
|
| 36 | - private IAppManager $appManager, |
|
| 37 | - ) { |
|
| 38 | - } |
|
| 26 | + /** |
|
| 27 | + * CalDAVSettings constructor. |
|
| 28 | + * |
|
| 29 | + * @param IConfig $config |
|
| 30 | + * @param IInitialState $initialState |
|
| 31 | + */ |
|
| 32 | + public function __construct( |
|
| 33 | + private IConfig $config, |
|
| 34 | + private IInitialState $initialState, |
|
| 35 | + private IURLGenerator $urlGenerator, |
|
| 36 | + private IAppManager $appManager, |
|
| 37 | + ) { |
|
| 38 | + } |
|
| 39 | 39 | |
| 40 | - public function getForm(): TemplateResponse { |
|
| 41 | - $this->initialState->provideInitialState('userSyncCalendarsDocUrl', $this->urlGenerator->linkToDocs('user-sync-calendars')); |
|
| 42 | - foreach (self::defaults as $key => $default) { |
|
| 43 | - $value = $this->config->getAppValue(Application::APP_ID, $key, $default); |
|
| 44 | - $this->initialState->provideInitialState($key, $value === 'yes'); |
|
| 45 | - } |
|
| 46 | - return new TemplateResponse(Application::APP_ID, 'settings-admin-caldav'); |
|
| 47 | - } |
|
| 40 | + public function getForm(): TemplateResponse { |
|
| 41 | + $this->initialState->provideInitialState('userSyncCalendarsDocUrl', $this->urlGenerator->linkToDocs('user-sync-calendars')); |
|
| 42 | + foreach (self::defaults as $key => $default) { |
|
| 43 | + $value = $this->config->getAppValue(Application::APP_ID, $key, $default); |
|
| 44 | + $this->initialState->provideInitialState($key, $value === 'yes'); |
|
| 45 | + } |
|
| 46 | + return new TemplateResponse(Application::APP_ID, 'settings-admin-caldav'); |
|
| 47 | + } |
|
| 48 | 48 | |
| 49 | - public function getSection(): ?string { |
|
| 50 | - if (!$this->appManager->isBackendRequired(IAppManager::BACKEND_CALDAV)) { |
|
| 51 | - return null; |
|
| 52 | - } |
|
| 49 | + public function getSection(): ?string { |
|
| 50 | + if (!$this->appManager->isBackendRequired(IAppManager::BACKEND_CALDAV)) { |
|
| 51 | + return null; |
|
| 52 | + } |
|
| 53 | 53 | |
| 54 | - return 'groupware'; |
|
| 55 | - } |
|
| 54 | + return 'groupware'; |
|
| 55 | + } |
|
| 56 | 56 | |
| 57 | - /** |
|
| 58 | - * @return int |
|
| 59 | - */ |
|
| 60 | - public function getPriority() { |
|
| 61 | - return 10; |
|
| 62 | - } |
|
| 57 | + /** |
|
| 58 | + * @return int |
|
| 59 | + */ |
|
| 60 | + public function getPriority() { |
|
| 61 | + return 10; |
|
| 62 | + } |
|
| 63 | 63 | |
| 64 | - public function getName(): ?string { |
|
| 65 | - return null; // Only setting in this section |
|
| 66 | - } |
|
| 64 | + public function getName(): ?string { |
|
| 65 | + return null; // Only setting in this section |
|
| 66 | + } |
|
| 67 | 67 | |
| 68 | - public function getAuthorizedAppConfig(): array { |
|
| 69 | - return [ |
|
| 70 | - 'dav' => ['/(' . implode('|', array_keys(self::defaults)) . ')/'] |
|
| 71 | - ]; |
|
| 72 | - } |
|
| 68 | + public function getAuthorizedAppConfig(): array { |
|
| 69 | + return [ |
|
| 70 | + 'dav' => ['/(' . implode('|', array_keys(self::defaults)) . ')/'] |
|
| 71 | + ]; |
|
| 72 | + } |
|
| 73 | 73 | } |
@@ -27,18 +27,18 @@ |
||
| 27 | 27 | namespace OCA\User_LDAP\PagedResults; |
| 28 | 28 | |
| 29 | 29 | trait TLinkId { |
| 30 | - public function getLinkId($link) { |
|
| 31 | - if (is_object($link)) { |
|
| 32 | - return spl_object_id($link); |
|
| 33 | - } elseif (is_resource($link)) { |
|
| 34 | - return (int)$link; |
|
| 35 | - } elseif (is_array($link) && isset($link[0])) { |
|
| 36 | - if (is_object($link[0])) { |
|
| 37 | - return spl_object_id($link[0]); |
|
| 38 | - } elseif (is_resource($link[0])) { |
|
| 39 | - return (int)$link[0]; |
|
| 40 | - } |
|
| 41 | - } |
|
| 42 | - throw new \RuntimeException('No resource provided'); |
|
| 43 | - } |
|
| 30 | + public function getLinkId($link) { |
|
| 31 | + if (is_object($link)) { |
|
| 32 | + return spl_object_id($link); |
|
| 33 | + } elseif (is_resource($link)) { |
|
| 34 | + return (int)$link; |
|
| 35 | + } elseif (is_array($link) && isset($link[0])) { |
|
| 36 | + if (is_object($link[0])) { |
|
| 37 | + return spl_object_id($link[0]); |
|
| 38 | + } elseif (is_resource($link[0])) { |
|
| 39 | + return (int)$link[0]; |
|
| 40 | + } |
|
| 41 | + } |
|
| 42 | + throw new \RuntimeException('No resource provided'); |
|
| 43 | + } |
|
| 44 | 44 | } |
@@ -31,12 +31,12 @@ |
||
| 31 | 31 | if (is_object($link)) { |
| 32 | 32 | return spl_object_id($link); |
| 33 | 33 | } elseif (is_resource($link)) { |
| 34 | - return (int)$link; |
|
| 34 | + return (int) $link; |
|
| 35 | 35 | } elseif (is_array($link) && isset($link[0])) { |
| 36 | 36 | if (is_object($link[0])) { |
| 37 | 37 | return spl_object_id($link[0]); |
| 38 | 38 | } elseif (is_resource($link[0])) { |
| 39 | - return (int)$link[0]; |
|
| 39 | + return (int) $link[0]; |
|
| 40 | 40 | } |
| 41 | 41 | } |
| 42 | 42 | throw new \RuntimeException('No resource provided'); |
@@ -149,7 +149,7 @@ discard block |
||
| 149 | 149 | } catch (\DomainException $e) { |
| 150 | 150 | throw new OCSForbiddenException($e->getMessage(), $e); |
| 151 | 151 | } catch (Exception $e) { |
| 152 | - $this->logger->error('Error when updating flow with id ' . $id, ['exception' => $e]); |
|
| 152 | + $this->logger->error('Error when updating flow with id '.$id, ['exception' => $e]); |
|
| 153 | 153 | throw new OCSException('An internal error occurred', $e->getCode(), $e); |
| 154 | 154 | } |
| 155 | 155 | } |
@@ -168,7 +168,7 @@ discard block |
||
| 168 | 168 | } catch (\DomainException $e) { |
| 169 | 169 | throw new OCSForbiddenException($e->getMessage(), $e); |
| 170 | 170 | } catch (Exception $e) { |
| 171 | - $this->logger->error('Error when deleting flow with id ' . $id, ['exception' => $e]); |
|
| 171 | + $this->logger->error('Error when deleting flow with id '.$id, ['exception' => $e]); |
|
| 172 | 172 | throw new OCSException('An internal error occurred', $e->getCode(), $e); |
| 173 | 173 | } |
| 174 | 174 | } |
@@ -22,130 +22,130 @@ |
||
| 22 | 22 | |
| 23 | 23 | abstract class AWorkflowController extends OCSController { |
| 24 | 24 | |
| 25 | - public function __construct( |
|
| 26 | - $appName, |
|
| 27 | - IRequest $request, |
|
| 28 | - protected Manager $manager, |
|
| 29 | - private LoggerInterface $logger, |
|
| 30 | - ) { |
|
| 31 | - parent::__construct($appName, $request); |
|
| 32 | - } |
|
| 33 | - |
|
| 34 | - /** |
|
| 35 | - * @throws OCSForbiddenException |
|
| 36 | - */ |
|
| 37 | - abstract protected function getScopeContext(): ScopeContext; |
|
| 38 | - |
|
| 39 | - /** |
|
| 40 | - * Example: curl -u joann -H "OCS-APIREQUEST: true" "http://my.nc.srvr/ocs/v2.php/apps/workflowengine/api/v1/workflows/global?format=json" |
|
| 41 | - * |
|
| 42 | - * @throws OCSForbiddenException |
|
| 43 | - */ |
|
| 44 | - public function index(): DataResponse { |
|
| 45 | - $operationsByClass = $this->manager->getAllOperations($this->getScopeContext()); |
|
| 46 | - |
|
| 47 | - foreach ($operationsByClass as &$operations) { |
|
| 48 | - foreach ($operations as &$operation) { |
|
| 49 | - $operation = $this->manager->formatOperation($operation); |
|
| 50 | - } |
|
| 51 | - } |
|
| 52 | - |
|
| 53 | - return new DataResponse($operationsByClass); |
|
| 54 | - } |
|
| 55 | - |
|
| 56 | - /** |
|
| 57 | - * Example: curl -u joann -H "OCS-APIREQUEST: true" "http://my.nc.srvr/ocs/v2.php/apps/workflowengine/api/v1/workflows/global/OCA\\Workflow_DocToPdf\\Operation?format=json" |
|
| 58 | - * |
|
| 59 | - * @throws OCSForbiddenException |
|
| 60 | - */ |
|
| 61 | - public function show(string $id): DataResponse { |
|
| 62 | - $context = $this->getScopeContext(); |
|
| 63 | - |
|
| 64 | - // The ID corresponds to a class name |
|
| 65 | - $operations = $this->manager->getOperations($id, $context); |
|
| 66 | - |
|
| 67 | - foreach ($operations as &$operation) { |
|
| 68 | - $operation = $this->manager->formatOperation($operation); |
|
| 69 | - } |
|
| 70 | - |
|
| 71 | - return new DataResponse($operations); |
|
| 72 | - } |
|
| 73 | - |
|
| 74 | - /** |
|
| 75 | - * @throws OCSBadRequestException |
|
| 76 | - * @throws OCSForbiddenException |
|
| 77 | - * @throws OCSException |
|
| 78 | - */ |
|
| 79 | - #[PasswordConfirmationRequired] |
|
| 80 | - public function create( |
|
| 81 | - string $class, |
|
| 82 | - string $name, |
|
| 83 | - array $checks, |
|
| 84 | - string $operation, |
|
| 85 | - string $entity, |
|
| 86 | - array $events, |
|
| 87 | - ): DataResponse { |
|
| 88 | - $context = $this->getScopeContext(); |
|
| 89 | - try { |
|
| 90 | - $operation = $this->manager->addOperation($class, $name, $checks, $operation, $context, $entity, $events); |
|
| 91 | - $operation = $this->manager->formatOperation($operation); |
|
| 92 | - return new DataResponse($operation); |
|
| 93 | - } catch (\UnexpectedValueException $e) { |
|
| 94 | - throw new OCSBadRequestException($e->getMessage(), $e); |
|
| 95 | - } catch (\DomainException $e) { |
|
| 96 | - throw new OCSForbiddenException($e->getMessage(), $e); |
|
| 97 | - } catch (Exception $e) { |
|
| 98 | - $this->logger->error('Error when inserting flow', ['exception' => $e]); |
|
| 99 | - throw new OCSException('An internal error occurred', $e->getCode(), $e); |
|
| 100 | - } |
|
| 101 | - } |
|
| 102 | - |
|
| 103 | - /** |
|
| 104 | - * @throws OCSBadRequestException |
|
| 105 | - * @throws OCSForbiddenException |
|
| 106 | - * @throws OCSException |
|
| 107 | - */ |
|
| 108 | - #[PasswordConfirmationRequired] |
|
| 109 | - public function update( |
|
| 110 | - int $id, |
|
| 111 | - string $name, |
|
| 112 | - array $checks, |
|
| 113 | - string $operation, |
|
| 114 | - string $entity, |
|
| 115 | - array $events, |
|
| 116 | - ): DataResponse { |
|
| 117 | - try { |
|
| 118 | - $context = $this->getScopeContext(); |
|
| 119 | - $operation = $this->manager->updateOperation($id, $name, $checks, $operation, $context, $entity, $events); |
|
| 120 | - $operation = $this->manager->formatOperation($operation); |
|
| 121 | - return new DataResponse($operation); |
|
| 122 | - } catch (\UnexpectedValueException $e) { |
|
| 123 | - throw new OCSBadRequestException($e->getMessage(), $e); |
|
| 124 | - } catch (\DomainException $e) { |
|
| 125 | - throw new OCSForbiddenException($e->getMessage(), $e); |
|
| 126 | - } catch (Exception $e) { |
|
| 127 | - $this->logger->error('Error when updating flow with id ' . $id, ['exception' => $e]); |
|
| 128 | - throw new OCSException('An internal error occurred', $e->getCode(), $e); |
|
| 129 | - } |
|
| 130 | - } |
|
| 131 | - |
|
| 132 | - /** |
|
| 133 | - * @throws OCSBadRequestException |
|
| 134 | - * @throws OCSForbiddenException |
|
| 135 | - * @throws OCSException |
|
| 136 | - */ |
|
| 137 | - #[PasswordConfirmationRequired] |
|
| 138 | - public function destroy(int $id): DataResponse { |
|
| 139 | - try { |
|
| 140 | - $deleted = $this->manager->deleteOperation($id, $this->getScopeContext()); |
|
| 141 | - return new DataResponse($deleted); |
|
| 142 | - } catch (\UnexpectedValueException $e) { |
|
| 143 | - throw new OCSBadRequestException($e->getMessage(), $e); |
|
| 144 | - } catch (\DomainException $e) { |
|
| 145 | - throw new OCSForbiddenException($e->getMessage(), $e); |
|
| 146 | - } catch (Exception $e) { |
|
| 147 | - $this->logger->error('Error when deleting flow with id ' . $id, ['exception' => $e]); |
|
| 148 | - throw new OCSException('An internal error occurred', $e->getCode(), $e); |
|
| 149 | - } |
|
| 150 | - } |
|
| 25 | + public function __construct( |
|
| 26 | + $appName, |
|
| 27 | + IRequest $request, |
|
| 28 | + protected Manager $manager, |
|
| 29 | + private LoggerInterface $logger, |
|
| 30 | + ) { |
|
| 31 | + parent::__construct($appName, $request); |
|
| 32 | + } |
|
| 33 | + |
|
| 34 | + /** |
|
| 35 | + * @throws OCSForbiddenException |
|
| 36 | + */ |
|
| 37 | + abstract protected function getScopeContext(): ScopeContext; |
|
| 38 | + |
|
| 39 | + /** |
|
| 40 | + * Example: curl -u joann -H "OCS-APIREQUEST: true" "http://my.nc.srvr/ocs/v2.php/apps/workflowengine/api/v1/workflows/global?format=json" |
|
| 41 | + * |
|
| 42 | + * @throws OCSForbiddenException |
|
| 43 | + */ |
|
| 44 | + public function index(): DataResponse { |
|
| 45 | + $operationsByClass = $this->manager->getAllOperations($this->getScopeContext()); |
|
| 46 | + |
|
| 47 | + foreach ($operationsByClass as &$operations) { |
|
| 48 | + foreach ($operations as &$operation) { |
|
| 49 | + $operation = $this->manager->formatOperation($operation); |
|
| 50 | + } |
|
| 51 | + } |
|
| 52 | + |
|
| 53 | + return new DataResponse($operationsByClass); |
|
| 54 | + } |
|
| 55 | + |
|
| 56 | + /** |
|
| 57 | + * Example: curl -u joann -H "OCS-APIREQUEST: true" "http://my.nc.srvr/ocs/v2.php/apps/workflowengine/api/v1/workflows/global/OCA\\Workflow_DocToPdf\\Operation?format=json" |
|
| 58 | + * |
|
| 59 | + * @throws OCSForbiddenException |
|
| 60 | + */ |
|
| 61 | + public function show(string $id): DataResponse { |
|
| 62 | + $context = $this->getScopeContext(); |
|
| 63 | + |
|
| 64 | + // The ID corresponds to a class name |
|
| 65 | + $operations = $this->manager->getOperations($id, $context); |
|
| 66 | + |
|
| 67 | + foreach ($operations as &$operation) { |
|
| 68 | + $operation = $this->manager->formatOperation($operation); |
|
| 69 | + } |
|
| 70 | + |
|
| 71 | + return new DataResponse($operations); |
|
| 72 | + } |
|
| 73 | + |
|
| 74 | + /** |
|
| 75 | + * @throws OCSBadRequestException |
|
| 76 | + * @throws OCSForbiddenException |
|
| 77 | + * @throws OCSException |
|
| 78 | + */ |
|
| 79 | + #[PasswordConfirmationRequired] |
|
| 80 | + public function create( |
|
| 81 | + string $class, |
|
| 82 | + string $name, |
|
| 83 | + array $checks, |
|
| 84 | + string $operation, |
|
| 85 | + string $entity, |
|
| 86 | + array $events, |
|
| 87 | + ): DataResponse { |
|
| 88 | + $context = $this->getScopeContext(); |
|
| 89 | + try { |
|
| 90 | + $operation = $this->manager->addOperation($class, $name, $checks, $operation, $context, $entity, $events); |
|
| 91 | + $operation = $this->manager->formatOperation($operation); |
|
| 92 | + return new DataResponse($operation); |
|
| 93 | + } catch (\UnexpectedValueException $e) { |
|
| 94 | + throw new OCSBadRequestException($e->getMessage(), $e); |
|
| 95 | + } catch (\DomainException $e) { |
|
| 96 | + throw new OCSForbiddenException($e->getMessage(), $e); |
|
| 97 | + } catch (Exception $e) { |
|
| 98 | + $this->logger->error('Error when inserting flow', ['exception' => $e]); |
|
| 99 | + throw new OCSException('An internal error occurred', $e->getCode(), $e); |
|
| 100 | + } |
|
| 101 | + } |
|
| 102 | + |
|
| 103 | + /** |
|
| 104 | + * @throws OCSBadRequestException |
|
| 105 | + * @throws OCSForbiddenException |
|
| 106 | + * @throws OCSException |
|
| 107 | + */ |
|
| 108 | + #[PasswordConfirmationRequired] |
|
| 109 | + public function update( |
|
| 110 | + int $id, |
|
| 111 | + string $name, |
|
| 112 | + array $checks, |
|
| 113 | + string $operation, |
|
| 114 | + string $entity, |
|
| 115 | + array $events, |
|
| 116 | + ): DataResponse { |
|
| 117 | + try { |
|
| 118 | + $context = $this->getScopeContext(); |
|
| 119 | + $operation = $this->manager->updateOperation($id, $name, $checks, $operation, $context, $entity, $events); |
|
| 120 | + $operation = $this->manager->formatOperation($operation); |
|
| 121 | + return new DataResponse($operation); |
|
| 122 | + } catch (\UnexpectedValueException $e) { |
|
| 123 | + throw new OCSBadRequestException($e->getMessage(), $e); |
|
| 124 | + } catch (\DomainException $e) { |
|
| 125 | + throw new OCSForbiddenException($e->getMessage(), $e); |
|
| 126 | + } catch (Exception $e) { |
|
| 127 | + $this->logger->error('Error when updating flow with id ' . $id, ['exception' => $e]); |
|
| 128 | + throw new OCSException('An internal error occurred', $e->getCode(), $e); |
|
| 129 | + } |
|
| 130 | + } |
|
| 131 | + |
|
| 132 | + /** |
|
| 133 | + * @throws OCSBadRequestException |
|
| 134 | + * @throws OCSForbiddenException |
|
| 135 | + * @throws OCSException |
|
| 136 | + */ |
|
| 137 | + #[PasswordConfirmationRequired] |
|
| 138 | + public function destroy(int $id): DataResponse { |
|
| 139 | + try { |
|
| 140 | + $deleted = $this->manager->deleteOperation($id, $this->getScopeContext()); |
|
| 141 | + return new DataResponse($deleted); |
|
| 142 | + } catch (\UnexpectedValueException $e) { |
|
| 143 | + throw new OCSBadRequestException($e->getMessage(), $e); |
|
| 144 | + } catch (\DomainException $e) { |
|
| 145 | + throw new OCSForbiddenException($e->getMessage(), $e); |
|
| 146 | + } catch (Exception $e) { |
|
| 147 | + $this->logger->error('Error when deleting flow with id ' . $id, ['exception' => $e]); |
|
| 148 | + throw new OCSException('An internal error occurred', $e->getCode(), $e); |
|
| 149 | + } |
|
| 150 | + } |
|
| 151 | 151 | } |