[files_external] OCS endpoint to proper OCSController
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
This commit is contained in:
parent
6e29b8731e
commit
05f75f803a
|
@ -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');
|
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue