_createRow: function(fileData) {
// TODO: hook earlier and render the whole row here
var $tr = OCA.Files.FileList.prototype._createRow.apply(this, arguments);
+ var $scopeColumn = $('<td></td>');
+ var $backendColumn = $('<td></td>');
+ var scopeText = t('files_external', 'Personal');
+ if (fileData.scope === 'system') {
+ scopeText = t('files_external', 'System');
+ }
$tr.find('.filesize,.date').remove();
- $tr.find('td.filename').after('<td></td>');
+ $scopeColumn.text(scopeText);
+ $backendColumn.text(fileData.backend);
+ $tr.find('td.filename').after($scopeColumn).after($backendColumn);
$tr.find('td.filename input:checkbox').remove();
return $tr;
},
class Api {
+ /**
+ * Formats the given mount config to a mount entry.
+ *
+ * @param bool $isSystemMount true for system mount, false
+ * for personal mount
+ *
+ * @return array entry
+ */
+ private static function formatMount($mountConfig, $isSystemMount = false) {
+ // split user name from mount point
+ $path = dirname($mountConfig['mountpoint']);
+ if ($path === '.') {
+ $path = '';
+ }
+
+ $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']),
+ 'path' => $path,
+ 'type' => 'dir',
+ 'backend' => $mountConfig['backend'],
+ 'scope' => ( $isSystemMount ? 'system' : 'personal' ),
+ 'permissions' => $permissions
+ );
+ return $entry;
+ }
+
/**
* Returns the mount points visible for this user.
*
public static function getUserMounts($params) {
$entries = array();
$user = \OC_User::getUser();
- $mounts = \OC_Mount_Config::getAbsoluteMountPoints($user);
- foreach ($mounts as $mountPoint => $config) {
- // split user name from mount point
- $parts = explode('/', ltrim($mountPoint, '/'));
- array_shift($parts); // use name
- array_shift($parts); // files
- $mountPoint = implode('/', $parts);
+ $personalMounts = \OC_Mount_Config::getPersonalMountPoints();
+ $systemMounts = \OC_Mount_Config::getSystemMountPoints();
- $path = dirname($mountPoint);
- if ($path === '.') {
- $path = '';
- }
-
- // TODO: give delete permissions if mount type is personal
- $permissions = \OCP\PERMISSION_READ;
+ foreach ($systemMounts as $mountConfig) {
+ $entries[] = self::formatMount($mountConfig, true);
+ }
- // TODO: add storageType, might need to use another OC_Mount_Config method
- $entries[] = array(
- 'name' => basename($mountPoint),
- 'path' => $path,
- 'type' => 'dir',
- 'permissions' => $permissions
- );
+ foreach ($personalMounts as $mountConfig) {
+ $entries[] = self::formatMount($mountConfig, false);
}
return new \OC_OCS_Result($entries);