|
|
@@ -20,6 +20,7 @@ |
|
|
|
*/ |
|
|
|
|
|
|
|
namespace OC\Files\Cache; |
|
|
|
|
|
|
|
use OCP\Share_Backend_Collection; |
|
|
|
|
|
|
|
/** |
|
|
@@ -50,7 +51,7 @@ class Shared_Cache extends Cache { |
|
|
|
\OC\Files\Filesystem::initMountPoints($source['fileOwner']); |
|
|
|
$mount = \OC\Files\Filesystem::getMountByNumericId($source['storage']); |
|
|
|
if (is_array($mount)) { |
|
|
|
$fullPath = $mount[key($mount)]->getMountPoint().$source['path']; |
|
|
|
$fullPath = $mount[key($mount)]->getMountPoint() . $source['path']; |
|
|
|
list($storage, $internalPath) = \OC\Files\Filesystem::resolvePath($fullPath); |
|
|
|
if ($storage) { |
|
|
|
$this->files[$target] = $internalPath; |
|
|
@@ -75,7 +76,7 @@ class Shared_Cache extends Cache { |
|
|
|
/** |
|
|
|
* get the stored metadata of a file or folder |
|
|
|
* |
|
|
|
* @param string/int $file |
|
|
|
* @param string /int $file |
|
|
|
* @return array |
|
|
|
*/ |
|
|
|
public function get($file) { |
|
|
@@ -95,8 +96,8 @@ class Shared_Cache extends Cache { |
|
|
|
} else { |
|
|
|
$query = \OC_DB::prepare( |
|
|
|
'SELECT `fileid`, `storage`, `path`, `parent`, `name`, `mimetype`, `mimepart`,' |
|
|
|
.' `size`, `mtime`, `encrypted`, `unencrypted_size`' |
|
|
|
.' FROM `*PREFIX*filecache` WHERE `fileid` = ?'); |
|
|
|
. ' `size`, `mtime`, `encrypted`, `unencrypted_size`' |
|
|
|
. ' FROM `*PREFIX*filecache` WHERE `fileid` = ?'); |
|
|
|
$result = $query->execute(array($file)); |
|
|
|
$data = $result->fetchRow(); |
|
|
|
$data['fileid'] = (int)$data['fileid']; |
|
|
@@ -288,8 +289,7 @@ class Shared_Cache extends Cache { |
|
|
|
foreach ($files as $file) { |
|
|
|
if ($file['mimetype'] === 'httpd/unix-directory') { |
|
|
|
$exploreDirs[] = ltrim($dir . '/' . $file['name'], '/'); |
|
|
|
} |
|
|
|
else if (($mimepart && $file['mimepart'] === $mimepart) || ($mimetype && $file['mimetype'] === $mimetype)) { |
|
|
|
} else if (($mimepart && $file['mimepart'] === $mimepart) || ($mimetype && $file['mimetype'] === $mimetype)) { |
|
|
|
// usersPath not reliable |
|
|
|
//$file['path'] = $file['usersPath']; |
|
|
|
$file['path'] = ltrim($dir . '/' . $file['name'], '/'); |
|
|
@@ -344,8 +344,6 @@ class Shared_Cache extends Cache { |
|
|
|
if ($row['encrypted'] or ($row['unencrypted_size'] > 0 and $row['mimetype'] === 'httpd/unix-directory')) { |
|
|
|
$row['encrypted_size'] = $row['size']; |
|
|
|
$row['size'] = $row['unencrypted_size']; |
|
|
|
} else { |
|
|
|
$row['size'] = $row['size']; |
|
|
|
} |
|
|
|
$files[] = $row; |
|
|
|
} |
|
|
@@ -402,4 +400,41 @@ class Shared_Cache extends Cache { |
|
|
|
return false; |
|
|
|
} |
|
|
|
|
|
|
|
public function getPathById($id, $pathEnd = '') { |
|
|
|
// direct shares are easy |
|
|
|
if ($path = $this->getShareById($id)) { |
|
|
|
return $path . $pathEnd; |
|
|
|
} else { |
|
|
|
// if the item is a direct share we try and get the path of the parent and append the name of the item to it |
|
|
|
list($parent, $name) = $this->getParentInfo($id); |
|
|
|
if ($parent > 0) { |
|
|
|
return $this->getPathById($parent, '/' . $name . $pathEnd); |
|
|
|
} else { |
|
|
|
return null; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
private function getShareById($id) { |
|
|
|
$item = \OCP\Share::getItemSharedWithBySource('file', $id); |
|
|
|
if ($item) { |
|
|
|
return trim($item['file_target'], '/'); |
|
|
|
} |
|
|
|
$item = \OCP\Share::getItemSharedWithBySource('folder', $id); |
|
|
|
if ($item) { |
|
|
|
return trim($item['file_target'], '/'); |
|
|
|
} |
|
|
|
return null; |
|
|
|
} |
|
|
|
|
|
|
|
private function getParentInfo($id) { |
|
|
|
$sql = 'SELECT `parent`, `name` FROM `*PREFIX*filecache` WHERE `fileid` = ?'; |
|
|
|
$query = \OC_DB::prepare($sql); |
|
|
|
$result = $query->execute(array($id)); |
|
|
|
if ($row = $result->fetchRow()) { |
|
|
|
return array($row['parent'], $row['name']); |
|
|
|
} else { |
|
|
|
return array(-1, ''); |
|
|
|
} |
|
|
|
} |
|
|
|
} |