From 05cecb101d7aef2414c9ba52a69e0c457dd5e803 Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Thu, 11 Jun 2015 17:10:11 +0200 Subject: verify path when getting a node for sabredav --- lib/private/connector/sabre/objecttree.php | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/lib/private/connector/sabre/objecttree.php b/lib/private/connector/sabre/objecttree.php index c56fd7ee4db..a73c9a860b0 100644 --- a/lib/private/connector/sabre/objecttree.php +++ b/lib/private/connector/sabre/objecttree.php @@ -105,6 +105,10 @@ class ObjectTree extends \Sabre\DAV\Tree { } $path = trim($path, '/'); + if ($path) { + $this->fileView->verifyPath($path, basename($path)); + } + if (isset($this->cache[$path])) { return $this->cache[$path]; } -- cgit v1.2.3 From 5a5639ab763662d8105bc61c5f124fcc99a7a813 Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Thu, 11 Jun 2015 17:25:06 +0200 Subject: tests for getNodeForPath with invalid path --- tests/lib/connector/sabre/objecttree.php | 62 ++++++++++++++++++++++++++++---- 1 file changed, 56 insertions(+), 6 deletions(-) diff --git a/tests/lib/connector/sabre/objecttree.php b/tests/lib/connector/sabre/objecttree.php index 53e53f1e07b..b9f8591b10a 100644 --- a/tests/lib/connector/sabre/objecttree.php +++ b/tests/lib/connector/sabre/objecttree.php @@ -11,6 +11,7 @@ namespace Test\OC\Connector\Sabre; use OC\Files\FileInfo; use OC\Connector\Sabre\Directory; +use OC\Files\Storage\Temporary; class TestDoubleFileView extends \OC\Files\View { @@ -36,7 +37,7 @@ class TestDoubleFileView extends \OC\Files\View { return $this->canRename; } - public function getRelativePath($path){ + public function getRelativePath($path) { return $path; } } @@ -122,11 +123,11 @@ class ObjectTree extends \Test\TestCase { * @dataProvider nodeForPathProvider */ public function testGetNodeForPath( - $inputFileName, - $fileInfoQueryPath, - $outputFileName, - $type, - $enableChunkingHeader + $inputFileName, + $fileInfoQueryPath, + $outputFileName, + $type, + $enableChunkingHeader ) { if ($enableChunkingHeader) { @@ -237,4 +238,53 @@ class ObjectTree extends \Test\TestCase { ); } + /** + * @expectedException \OCP\Files\InvalidPathException + */ + public function testGetNodeForPathInvalidPath() { + $path = '/foo\bar'; + + + $storage = new Temporary([]); + + $view = $this->getMock('\OC\Files\View', ['resolvePath']); + $view->expects($this->once()) + ->method('resolvePath') + ->will($this->returnCallback(function($path) use ($storage){ + return [$storage, ltrim($path, '/')]; + })); + + $rootNode = $this->getMockBuilder('\OC\Connector\Sabre\Directory') + ->disableOriginalConstructor() + ->getMock(); + $mountManager = $this->getMock('\OC\Files\Mount\Manager'); + + $tree = new \OC\Connector\Sabre\ObjectTree(); + $tree->init($rootNode, $view, $mountManager); + + $tree->getNodeForPath($path); + } + public function testGetNodeForPathRoot() { + $path = '/'; + + + $storage = new Temporary([]); + + $view = $this->getMock('\OC\Files\View', ['resolvePath']); + $view->expects($this->any()) + ->method('resolvePath') + ->will($this->returnCallback(function ($path) use ($storage) { + return [$storage, ltrim($path, '/')]; + })); + + $rootNode = $this->getMockBuilder('\OC\Connector\Sabre\Directory') + ->disableOriginalConstructor() + ->getMock(); + $mountManager = $this->getMock('\OC\Files\Mount\Manager'); + + $tree = new \OC\Connector\Sabre\ObjectTree(); + $tree->init($rootNode, $view, $mountManager); + + $tree->getNodeForPath($path); + } } -- cgit v1.2.3