From 33c0d2f743c82facc7847b62497913952baef296 Mon Sep 17 00:00:00 2001 From: Lukas Reschke Date: Wed, 17 Sep 2014 11:36:08 +0200 Subject: [PATCH] Fix mapping of relative paths --- lib/private/files/mapper.php | 44 +++++++++++++++++++--------- lib/private/files/storage/common.php | 2 +- 2 files changed, 31 insertions(+), 15 deletions(-) diff --git a/lib/private/files/mapper.php b/lib/private/files/mapper.php index 94dda807c2..5e78ef03dd 100644 --- a/lib/private/files/mapper.php +++ b/lib/private/files/mapper.php @@ -66,8 +66,8 @@ class Mapper */ public function copy($path1, $path2) { - $path1 = $this->stripLast($path1); - $path2 = $this->stripLast($path2); + $path1 = $this->resolveRelativePath($path1); + $path2 = $this->resolveRelativePath($path2); $physicPath1 = $this->logicToPhysical($path1, true); $physicPath2 = $this->logicToPhysical($path2, true); @@ -113,18 +113,11 @@ class Mapper return ''; } - private function stripLast($path) { - if (substr($path, -1) == '/') { - $path = substr_replace($path, '', -1); - } - return $path; - } - /** * @param string $logicPath */ private function resolveLogicPath($logicPath) { - $logicPath = $this->stripLast($logicPath); + $logicPath = $this->resolveRelativePath($logicPath); $sql = 'SELECT * FROM `*PREFIX*file_map` WHERE `logic_path_hash` = ?'; $result = \OC_DB::executeAudited($sql, array(md5($logicPath))); $result = $result->fetchRow(); @@ -136,7 +129,7 @@ class Mapper } private function resolvePhysicalPath($physicalPath) { - $physicalPath = $this->stripLast($physicalPath); + $physicalPath = $this->resolveRelativePath($physicalPath); $sql = \OC_DB::prepare('SELECT * FROM `*PREFIX*file_map` WHERE `physic_path_hash` = ?'); $result = \OC_DB::executeAudited($sql, array(md5($physicalPath))); $result = $result->fetchRow(); @@ -144,12 +137,35 @@ class Mapper return $result['logic_path']; } + private function resolveRelativePath($path) { + $explodedPath = explode('/', $path); + $pathArray = array(); + foreach ($explodedPath as $pathElement) { + if (empty($pathElement) || ($pathElement == '.')) { + continue; + } elseif ($pathElement == '..') { + if (count($pathArray) == 0) { + return false; + } + array_pop($pathArray); + } else { + array_push($pathArray, $pathElement); + } + } + if (substr($path, 0, 1) == '/') { + $path = '/'; + } else { + $path = ''; + } + return $path.implode('/', $pathArray); + } + /** * @param string $logicPath * @param boolean $store */ private function create($logicPath, $store) { - $logicPath = $this->stripLast($logicPath); + $logicPath = $this->resolveRelativePath($logicPath); $index = 0; // create the slugified path @@ -205,8 +221,8 @@ class Mapper } } - $sluggedPath = $this->unchangedPhysicalRoot . implode('/', $sluggedElements); - return $this->stripLast($sluggedPath); + $sluggedPath = $this->unchangedPhysicalRoot.implode('/', $sluggedElements); + return $this->resolveRelativePath($sluggedPath); } /** diff --git a/lib/private/files/storage/common.php b/lib/private/files/storage/common.php index 483a9ac666..975f44df54 100644 --- a/lib/private/files/storage/common.php +++ b/lib/private/files/storage/common.php @@ -99,7 +99,7 @@ abstract class Common implements \OC\Files\Storage\Storage { return false; } $parent = dirname($path); - return $this->isUpdatable($parent) and $this->isUpdatable($path); + return $this->isUpdatable($parent) && $this->isUpdatable($path); } public function isSharable($path) {