aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files_external/lib/api.php
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2014-07-01 09:56:47 +0200
committerVincent Petry <pvince81@owncloud.com>2014-07-01 09:56:47 +0200
commit19ab6165e7552c20f14d7aa2bb1e15f9a888231a (patch)
treedab83e1a9ff49691548149b28c33081c6c163b25 /apps/files_external/lib/api.php
parent88e6f5c318d1fcd08ac2182bbfbdf9b15ae34d17 (diff)
parent8977a68548aef5728cd36a0959fb3a938741c505 (diff)
downloadnextcloud-server-19ab6165e7552c20f14d7aa2bb1e15f9a888231a.tar.gz
nextcloud-server-19ab6165e7552c20f14d7aa2bb1e15f9a888231a.zip
Merge pull request #9300 from owncloud/extstorage-listfilterfix
Use filtered list for ext storage list mounts API
Diffstat (limited to 'apps/files_external/lib/api.php')
-rw-r--r--apps/files_external/lib/api.php31
1 files changed, 15 insertions, 16 deletions
diff --git a/apps/files_external/lib/api.php b/apps/files_external/lib/api.php
index 51c48427aa3..81ebd4e886a 100644
--- a/apps/files_external/lib/api.php
+++ b/apps/files_external/lib/api.php
@@ -27,27 +27,32 @@ class Api {
/**
* Formats the given mount config to a mount entry.
*
- * @param bool $isSystemMount true for system mount, false
- * for personal mount
+ * @param string $mountPoint mount point name, relative to the data dir
+ * @param array $mountConfig mount config to format
*
* @return array entry
*/
- private static function formatMount($mountConfig, $isSystemMount = false) {
- // split user name from mount point
- $path = dirname($mountConfig['mountpoint']);
+ private static function formatMount($mountPoint, $mountConfig) {
+ // strip "/$user/files" from mount point
+ $mountPoint = explode('/', trim($mountPoint, '/'), 3);
+ $mountPoint = $mountPoint[2];
+
+ // split path from mount point
+ $path = dirname($mountPoint);
if ($path === '.') {
$path = '';
}
+ $isSystemMount = !$mountConfig['personal'];
+
$permissions = \OCP\PERMISSION_READ;
// personal mounts can be deleted
if (!$isSystemMount) {
$permissions |= \OCP\PERMISSION_DELETE;
}
- // TODO: add storageType, might need to use another OC_Mount_Config method
$entry = array(
- 'name' => basename($mountConfig['mountpoint']),
+ 'name' => basename($mountPoint),
'path' => $path,
'type' => 'dir',
'backend' => $mountConfig['backend'],
@@ -67,15 +72,9 @@ class Api {
$entries = array();
$user = \OC_User::getUser();
- $personalMounts = \OC_Mount_Config::getPersonalMountPoints();
- $systemMounts = \OC_Mount_Config::getSystemMountPoints();
-
- foreach ($systemMounts as $mountConfig) {
- $entries[] = self::formatMount($mountConfig, true);
- }
-
- foreach ($personalMounts as $mountConfig) {
- $entries[] = self::formatMount($mountConfig, false);
+ $mounts = \OC_Mount_Config::getAbsoluteMountPoints($user);
+ foreach($mounts as $mountPoint => $mount) {
+ $entries[] = self::formatMount($mountPoint, $mount);
}
return new \OC_OCS_Result($entries);