[files_external] OCS endpoint to proper OCSController

Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
This commit is contained in:
Roeland Jago Douma 2018-01-17 20:00:09 +01:00
parent 6e29b8731e
commit 05f75f803a
No known key found for this signature in database
GPG Key ID: F941078878347C0C
2 changed files with 50 additions and 31 deletions

View File

@ -31,26 +31,33 @@
**/ **/
\OC_Mount_Config::$app->registerRoutes( \OC_Mount_Config::$app->registerRoutes(
$this, $this,
array( [
'resources' => array( 'resources' => [
'global_storages' => array('url' => '/globalstorages'), 'global_storages' => ['url' => '/globalstorages'],
'user_storages' => array('url' => '/userstorages'), 'user_storages' => ['url' => '/userstorages'],
'user_global_storages' => array('url' => '/userglobalstorages'), 'user_global_storages' => ['url' => '/userglobalstorages'],
), ],
'routes' => array( 'routes' => [
array( [
'name' => 'Ajax#getSshKeys', 'name' => 'Ajax#getSshKeys',
'url' => '/ajax/public_key.php', 'url' => '/ajax/public_key.php',
'verb' => 'POST', 'verb' => 'POST',
'requirements' => array() 'requirements' => [],
), ],
[ [
'name' => 'Ajax#saveGlobalCredentials', 'name' => 'Ajax#saveGlobalCredentials',
'url' => '/globalcredentials', 'url' => '/globalcredentials',
'verb' => 'POST', 'verb' => 'POST',
], ],
) ],
) 'ocs' => [
[
'name' => 'Api#getUserMounts',
'url' => '/api/v1/mounts',
'verb' => 'GET',
],
],
]
); );
$this->create('files_external_oauth1', 'ajax/oauth1.php') $this->create('files_external_oauth1', 'ajax/oauth1.php')
@ -61,9 +68,3 @@ $this->create('files_external_oauth2', 'ajax/oauth2.php')
$this->create('files_external_list_applicable', '/applicable') $this->create('files_external_list_applicable', '/applicable')
->actionInclude('files_external/ajax/applicable.php'); ->actionInclude('files_external/ajax/applicable.php');
\OCP\API::register('get',
'/apps/files_external/api/v1/mounts',
array('\OCA\Files_External\Lib\Api', 'getUserMounts'),
'files_external');

View File

@ -1,4 +1,5 @@
<?php <?php
declare(strict_types=1);
/** /**
* @copyright Copyright (c) 2016, ownCloud, Inc. * @copyright Copyright (c) 2016, ownCloud, Inc.
* *
@ -26,9 +27,25 @@
* *
*/ */
namespace OCA\Files_External\Lib; namespace OCA\Files_External\Controller;
class Api { use OCP\AppFramework\Http\DataResponse;
use OCP\AppFramework\OCSController;
use OCP\IRequest;
use OCP\IUserSession;
class ApiController extends OCSController {
/** @var IUserSession */
private $userSession;
public function __construct(string $appName,
IRequest $request,
IUserSession $userSession) {
parent::__construct($appName, $request);
$this->userSession = $userSession;
}
/** /**
* Formats the given mount config to a mount entry. * Formats the given mount config to a mount entry.
@ -38,13 +55,13 @@ class Api {
* *
* @return array entry * @return array entry
*/ */
private static function formatMount($mountPoint, $mountConfig) { private function formatMount(string $mountPoint, array $mountConfig): array {
// strip "/$user/files" from mount point // strip "/$user/files" from mount point
$mountPoint = explode('/', trim($mountPoint, '/'), 3); $mountPoint = explode('/', trim($mountPoint, '/'), 3);
$mountPoint = isset($mountPoint[2]) ? $mountPoint[2] : ''; $mountPoint = $mountPoint[2] ?? '';
// split path from mount point // split path from mount point
$path = dirname($mountPoint); $path = \dirname($mountPoint);
if ($path === '.') { if ($path === '.') {
$path = ''; $path = '';
} }
@ -62,7 +79,7 @@ class Api {
'path' => $path, 'path' => $path,
'type' => 'dir', 'type' => 'dir',
'backend' => $mountConfig['backend'], 'backend' => $mountConfig['backend'],
'scope' => ( $isSystemMount ? 'system' : 'personal' ), 'scope' => $isSystemMount ? 'system' : 'personal',
'permissions' => $permissions, 'permissions' => $permissions,
'id' => $mountConfig['id'], 'id' => $mountConfig['id'],
'class' => $mountConfig['class'] 'class' => $mountConfig['class']
@ -71,20 +88,21 @@ class Api {
} }
/** /**
* @NoAdminRequired
*
* Returns the mount points visible for this user. * Returns the mount points visible for this user.
* *
* @param array $params * @return DataResponse share information
* @return \OC\OCS\Result share information
*/ */
public static function getUserMounts($params) { public function getUserMounts(): DataResponse {
$entries = array(); $entries = [];
$user = \OC::$server->getUserSession()->getUser()->getUID(); $user = $this->userSession->getUser()->getUID();
$mounts = \OC_Mount_Config::getAbsoluteMountPoints($user); $mounts = \OC_Mount_Config::getAbsoluteMountPoints($user);
foreach($mounts as $mountPoint => $mount) { foreach($mounts as $mountPoint => $mount) {
$entries[] = self::formatMount($mountPoint, $mount); $entries[] = $this->formatMount($mountPoint, $mount);
} }
return new \OC\OCS\Result($entries); return new DataResponse($entries);
} }
} }