From a7808f0115ca2f3c10f839c2967fea105030bd11 Mon Sep 17 00:00:00 2001 From: jld3103 Date: Fri, 4 Aug 2023 16:31:37 +0200 Subject: files_external: Fix OpenAPI Signed-off-by: jld3103 --- .../lib/Controller/ApiController.php | 4 +- apps/files_external/lib/Lib/StorageConfig.php | 10 ++- apps/files_external/lib/ResponseDefinitions.php | 18 ++++- apps/files_external/openapi.json | 77 +++++++++++++++++++++- 4 files changed, 103 insertions(+), 6 deletions(-) (limited to 'apps/files_external') diff --git a/apps/files_external/lib/Controller/ApiController.php b/apps/files_external/lib/Controller/ApiController.php index 1276dde91c6..fbab967e786 100644 --- a/apps/files_external/lib/Controller/ApiController.php +++ b/apps/files_external/lib/Controller/ApiController.php @@ -34,6 +34,7 @@ use OCA\Files_External\ResponseDefinitions; use OCA\Files_External\Service\UserGlobalStoragesService; use OCA\Files_External\Service\UserStoragesService; use OCP\AppFramework\Http; +use OCP\AppFramework\Http\Attribute\IgnoreOpenAPI; use OCP\AppFramework\Http\DataResponse; use OCP\AppFramework\OCSController; use OCP\IRequest; @@ -127,6 +128,7 @@ class ApiController extends OCSController { * Ask for credentials using a browser's native basic auth prompt * Then returns it if provided */ + #[IgnoreOpenAPI] public function askNativeAuth(): DataResponse { if (!isset($_SERVER['PHP_AUTH_USER']) || !isset($_SERVER['PHP_AUTH_PW'])) { $response = new DataResponse([], Http::STATUS_UNAUTHORIZED); @@ -137,7 +139,7 @@ class ApiController extends OCSController { $user = $_SERVER['PHP_AUTH_USER']; $password = $_SERVER['PHP_AUTH_PW']; - // Reset auth + // Reset auth unset($_SERVER['PHP_AUTH_USER']); unset($_SERVER['PHP_AUTH_PW']); diff --git a/apps/files_external/lib/Lib/StorageConfig.php b/apps/files_external/lib/Lib/StorageConfig.php index 8cb59f70892..25205a24321 100644 --- a/apps/files_external/lib/Lib/StorageConfig.php +++ b/apps/files_external/lib/Lib/StorageConfig.php @@ -31,9 +31,12 @@ namespace OCA\Files_External\Lib; use OCA\Files_External\Lib\Auth\AuthMechanism; use OCA\Files_External\Lib\Auth\IUserProvided; use OCA\Files_External\Lib\Backend\Backend; +use OCA\Files_External\ResponseDefinitions; /** * External storage configuration + * + * @psalm-import-type FilesExternalStorageConfig from ResponseDefinitions */ class StorageConfig implements \JsonSerializable { public const MOUNT_TYPE_ADMIN = 1; @@ -63,7 +66,7 @@ class StorageConfig implements \JsonSerializable { /** * Backend options * - * @var array + * @var array */ private $backendOptions = []; @@ -112,7 +115,7 @@ class StorageConfig implements \JsonSerializable { /** * Mount-specific options * - * @var array + * @var array */ private $mountOptions = []; @@ -396,6 +399,7 @@ class StorageConfig implements \JsonSerializable { /** * Serialize config to JSON + * @return FilesExternalStorageConfig */ public function jsonSerialize(bool $obfuscate = false): array { $result = []; @@ -407,7 +411,7 @@ class StorageConfig implements \JsonSerializable { if ($obfuscate) { $this->formatStorageForUI(); } - + $result['mountPoint'] = $this->mountPoint; $result['backend'] = $this->backend->getIdentifier(); $result['authMechanism'] = $this->authMechanism->getIdentifier(); diff --git a/apps/files_external/lib/ResponseDefinitions.php b/apps/files_external/lib/ResponseDefinitions.php index bae29085361..cb501ed1bce 100644 --- a/apps/files_external/lib/ResponseDefinitions.php +++ b/apps/files_external/lib/ResponseDefinitions.php @@ -26,6 +26,22 @@ declare(strict_types=1); namespace OCA\Files_External; /** + * @psalm-type FilesExternalStorageConfig = array{ + * applicableGroups?: string[], + * applicableUsers?: string[], + * authMechanism: string, + * backend: string, + * backendOptions: array, + * id?: int, + * mountOptions?: array, + * mountPoint: string, + * priority?: int, + * status?: int, + * statusMessage?: string, + * type: 'personal'|'system', + * userProvided: bool, + * } + * * @psalm-type FilesExternalMount = array{ * name: string, * path: string, @@ -35,7 +51,7 @@ namespace OCA\Files_External; * permissions: int, * id: int, * class: string, - * config: array, + * config: FilesExternalStorageConfig, * } */ class ResponseDefinitions { diff --git a/apps/files_external/openapi.json b/apps/files_external/openapi.json index a95ab67697a..f6ab4bc2a80 100644 --- a/apps/files_external/openapi.json +++ b/apps/files_external/openapi.json @@ -30,7 +30,8 @@ "scope", "permissions", "id", - "class" + "class", + "config" ], "properties": { "name": { @@ -65,6 +66,9 @@ }, "class": { "type": "string" + }, + "config": { + "$ref": "#/components/schemas/StorageConfig" } } }, @@ -91,6 +95,77 @@ "type": "string" } } + }, + "StorageConfig": { + "type": "object", + "required": [ + "authMechanism", + "backend", + "backendOptions", + "mountPoint", + "type", + "userProvided" + ], + "properties": { + "applicableGroups": { + "type": "array", + "items": { + "type": "string" + } + }, + "applicableUsers": { + "type": "array", + "items": { + "type": "string" + } + }, + "authMechanism": { + "type": "string" + }, + "backend": { + "type": "string" + }, + "backendOptions": { + "type": "object", + "additionalProperties": { + "type": "object" + } + }, + "id": { + "type": "integer", + "format": "int64" + }, + "mountOptions": { + "type": "object", + "additionalProperties": { + "type": "object" + } + }, + "mountPoint": { + "type": "string" + }, + "priority": { + "type": "integer", + "format": "int64" + }, + "status": { + "type": "integer", + "format": "int64" + }, + "statusMessage": { + "type": "string" + }, + "type": { + "type": "string", + "enum": [ + "personal", + "system" + ] + }, + "userProvided": { + "type": "boolean" + } + } } } }, -- cgit v1.2.3