summaryrefslogtreecommitdiffstats
path: root/apps
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
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')
-rw-r--r--apps/files_external/lib/api.php31
-rwxr-xr-xapps/files_external/lib/config.php5
2 files changed, 20 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);
diff --git a/apps/files_external/lib/config.php b/apps/files_external/lib/config.php
index ec908fb068d..f860d5e705f 100755
--- a/apps/files_external/lib/config.php
+++ b/apps/files_external/lib/config.php
@@ -156,6 +156,7 @@ class OC_Mount_Config {
if ( (!isset($mountPoints[$mountPoint]))
|| ($options['priority'] >= $mountPoints[$mountPoint]['priority']) ) {
$options['priority_type'] = self::MOUNT_TYPE_GLOBAL;
+ $options['backend'] = $backends[$options['class']]['backend'];
$mountPoints[$mountPoint] = $options;
}
}
@@ -177,6 +178,7 @@ class OC_Mount_Config {
if ( (!isset($mountPoints[$mountPoint]))
|| ($options['priority'] >= $mountPoints[$mountPoint]['priority']) ) {
$options['priority_type'] = self::MOUNT_TYPE_GLOBAL;
+ $options['backend'] = $backends[$options['class']]['backend'];
$mountPoints[$mountPoint] = $options;
}
}
@@ -201,6 +203,7 @@ class OC_Mount_Config {
|| ($options['priority'] >= $mountPoints[$mountPoint]['priority'])
|| ($mountPoints[$mountPoint]['priority_type'] !== self::MOUNT_TYPE_GROUP) ) {
$options['priority_type'] = self::MOUNT_TYPE_GROUP;
+ $options['backend'] = $backends[$options['class']]['backend'];
$mountPoints[$mountPoint] = $options;
}
}
@@ -227,6 +230,7 @@ class OC_Mount_Config {
|| ($options['priority'] >= $mountPoints[$mountPoint]['priority'])
|| ($mountPoints[$mountPoint]['priority_type'] !== self::MOUNT_TYPE_USER) ) {
$options['priority_type'] = self::MOUNT_TYPE_USER;
+ $options['backend'] = $backends[$options['class']]['backend'];
$mountPoints[$mountPoint] = $options;
}
}
@@ -243,6 +247,7 @@ class OC_Mount_Config {
// Always override previous config
$options['priority_type'] = self::MOUNT_TYPE_PERSONAL;
+ $options['backend'] = $backends[$options['class']]['backend'];
$mountPoints[$mountPoint] = $options;
}
}