userGlobalStoragesService = $userGlobalStorageService; $this->userStoragesService = $userStorageService; } /** * Formats the given mount config to a mount entry. * * @param string $mountPoint mount point name, relative to the data dir * @param StorageConfig $mountConfig mount config to format * * @return Files_ExternalMount */ private function formatMount(string $mountPoint, StorageConfig $mountConfig): array { // split path from mount point $path = \dirname($mountPoint); if ($path === '.' || $path === '/') { $path = ''; } $isSystemMount = $mountConfig->getType() === StorageConfig::MOUNT_TYPE_ADMIN; $permissions = \OCP\Constants::PERMISSION_READ; // personal mounts can be deleted if (!$isSystemMount) { $permissions |= \OCP\Constants::PERMISSION_DELETE; } $entry = [ 'id' => $mountConfig->getId(), 'type' => 'dir', 'name' => basename($mountPoint), 'path' => $path, 'permissions' => $permissions, 'scope' => $isSystemMount ? 'system' : 'personal', 'backend' => $mountConfig->getBackend()->getText(), 'class' => $mountConfig->getBackend()->getIdentifier(), 'config' => $mountConfig->jsonSerialize(true), ]; return $entry; } /** * @NoAdminRequired * * Get the mount points visible for this user * * @return DataResponse * * 200: User mounts returned */ public function getUserMounts(): DataResponse { $entries = []; $mountPoints = []; foreach ($this->userGlobalStoragesService->getStorages() as $storage) { $mountPoint = $storage->getMountPoint(); $mountPoints[$mountPoint] = $storage; } foreach ($this->userStoragesService->getStorages() as $storage) { $mountPoint = $storage->getMountPoint(); $mountPoints[$mountPoint] = $storage; } foreach ($mountPoints as $mountPoint => $mount) { $entries[] = $this->formatMount($mountPoint, $mount); } return new DataResponse($entries); } /** * @NoAdminRequired * @NoCSRFRequired * * Ask for credentials using a browser's native basic auth prompt * Then returns it if provided */ #[OpenAPI(scope: OpenAPI::SCOPE_IGNORE)] public function askNativeAuth(): DataResponse { if (!isset($_SERVER['PHP_AUTH_USER']) || !isset($_SERVER['PHP_AUTH_PW'])) { $response = new DataResponse([], Http::STATUS_UNAUTHORIZED); $response->addHeader('WWW-Authenticate', 'Basic realm="Storage authentification needed"'); return $response; } $user = $_SERVER['PHP_AUTH_USER']; $password = $_SERVER['PHP_AUTH_PW']; // Reset auth unset($_SERVER['PHP_AUTH_USER']); unset($_SERVER['PHP_AUTH_PW']); // Using 401 again to ensure we clear any cached Authorization return new DataResponse([ 'user' => $user, 'password' => $password, ], Http::STATUS_UNAUTHORIZED); } }