diff options
Diffstat (limited to 'lib/private/search')
-rw-r--r-- | lib/private/search/result/file.php | 42 |
1 files changed, 15 insertions, 27 deletions
diff --git a/lib/private/search/result/file.php b/lib/private/search/result/file.php index 82c425adb15..38acac48ed7 100644 --- a/lib/private/search/result/file.php +++ b/lib/private/search/result/file.php @@ -65,10 +65,13 @@ class File extends \OCP\Search\Result { /** * Create a new file search result - * @param array $data file data given by provider + * @param FileInfo $data file data given by provider */ public function __construct(FileInfo $data) { - $info = pathinfo($data->getPath()); + + $path = $this->getRelativePath($data->getPath()); + + $info = pathinfo($path); $this->id = $data->getId(); $this->name = $info['basename']; $this->link = \OCP\Util::linkTo( @@ -76,38 +79,23 @@ class File extends \OCP\Search\Result { 'index.php', array('dir' => $info['dirname'], 'file' => $info['basename']) ); - $this->permissions = self::get_permissions($data->getPath()); - $this->path = (strpos($data->getPath(), 'files') === 0) ? substr($data->getPath(), 5) : $data->getPath(); + $this->permissions = $data->getPermissions(); + $this->path = $path; $this->size = $data->getSize(); $this->modified = $data->getMtime(); $this->mime_type = $data->getMimetype(); } /** - * Determine permissions for a given file path + * converts a path relative to the users files folder + * eg /user/files/foo.txt -> /foo.txt * @param string $path - * @return int + * @return string relative path */ - function get_permissions($path) { - // add read permissions - $permissions = \OCP\PERMISSION_READ; - // get directory - $fileinfo = pathinfo($path); - $dir = $fileinfo['dirname'] . '/'; - // add update permissions - if (Filesystem::isUpdatable($dir)) { - $permissions |= \OCP\PERMISSION_UPDATE; - } - // add delete permissions - if (Filesystem::isDeletable($dir)) { - $permissions |= \OCP\PERMISSION_DELETE; - } - // add share permissions - if (Filesystem::isSharable($dir)) { - $permissions |= \OCP\PERMISSION_SHARE; - } - // return - return $permissions; + function getRelativePath ($path) { + $root = \OC::$server->getUserFolder(); + return $root->getRelativePath($path); + } - + } |