1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- namespace OCA\Files_External\Command;
- use OC\Core\Command\Base;
- use OCA\Files_External\Lib\StorageConfig;
- use OCA\Files_External\NotFoundException;
- use OCA\Files_External\Service\GlobalStoragesService;
- use OCP\AppFramework\Http;
- use Symfony\Component\Console\Input\InputArgument;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- class Config extends Base {
- public function __construct(
- protected GlobalStoragesService $globalService,
- ) {
- parent::__construct();
- }
- protected function configure(): void {
- $this
- ->setName('files_external:config')
- ->setDescription('Manage backend configuration for a mount')
- ->addArgument(
- 'mount_id',
- InputArgument::REQUIRED,
- 'The id of the mount to edit'
- )->addArgument(
- 'key',
- InputArgument::REQUIRED,
- 'key of the config option to set/get'
- )->addArgument(
- 'value',
- InputArgument::OPTIONAL,
- 'value to set the config option to, when no value is provided the existing value will be printed'
- );
- parent::configure();
- }
- protected function execute(InputInterface $input, OutputInterface $output): int {
- $mountId = $input->getArgument('mount_id');
- $key = $input->getArgument('key');
- 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 Http::STATUS_NOT_FOUND;
- }
- $value = $input->getArgument('value');
- if ($value !== null) {
- $this->setOption($mount, $key, $value, $output);
- } else {
- $this->getOption($mount, $key, $output);
- }
- return self::SUCCESS;
- }
- /**
- * @param string $key
- */
- protected function getOption(StorageConfig $mount, $key, OutputInterface $output): void {
- if ($key === 'mountpoint' || $key === 'mount_point') {
- $value = $mount->getMountPoint();
- } else {
- $value = $mount->getBackendOption($key);
- }
- if (!is_string($value) && json_decode(json_encode($value)) === $value) { // show bools and objects correctly
- $value = json_encode($value);
- }
- $output->writeln((string)$value);
- }
- /**
- * @param string $key
- * @param string $value
- */
- protected function setOption(StorageConfig $mount, $key, $value, OutputInterface $output): void {
- $decoded = json_decode($value, true);
- if (!is_null($decoded) && json_encode($decoded) === $value) {
- $value = $decoded;
- }
- if ($key === 'mountpoint' || $key === 'mount_point') {
- $mount->setMountPoint($value);
- } else {
- $mount->setBackendOption($key, $value);
- }
- $this->globalService->updateStorage($mount);
- }
- }
|