summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLukas Reschke <lukas@owncloud.com>2015-02-18 16:01:24 +0100
committerLukas Reschke <lukas@owncloud.com>2015-02-18 18:17:33 +0100
commit41e5850450d962deff277cb713b8d057e9749dbf (patch)
treef1fa93e285337ea596d10a3f695a634124d3ccac
parent8d09cc3b91a9689a6c95e06c8002288bdd8d5bbf (diff)
downloadnextcloud-server-41e5850450d962deff277cb713b8d057e9749dbf.tar.gz
nextcloud-server-41e5850450d962deff277cb713b8d057e9749dbf.zip
Prevent directory traversals in ctr of \OC\Files\View
This prevents a misusage of \OC\Files\View by calling it with user-supplied input. In such cases an exception is now thrown.
-rw-r--r--lib/private/files/view.php8
-rw-r--r--tests/lib/files/view.php17
2 files changed, 25 insertions, 0 deletions
diff --git a/lib/private/files/view.php b/lib/private/files/view.php
index 3bc9fdff1ee..3dfd4d0c105 100644
--- a/lib/private/files/view.php
+++ b/lib/private/files/view.php
@@ -36,7 +36,15 @@ class View {
*/
protected $updater;
+ /**
+ * @param string $root
+ * @throws \Exception If $root contains an invalid path
+ */
public function __construct($root = '') {
+ if(!Filesystem::isValidPath($root)) {
+ throw new \Exception();
+ }
+
$this->fakeRoot = $root;
$this->updater = new Updater($this);
}
diff --git a/tests/lib/files/view.php b/tests/lib/files/view.php
index f6af59d52be..b4b6d0deb2e 100644
--- a/tests/lib/files/view.php
+++ b/tests/lib/files/view.php
@@ -894,4 +894,21 @@ class View extends \Test\TestCase {
$this->assertFalse($view->unlink('foo.txt'));
$this->assertTrue($cache->inCache('foo.txt'));
}
+
+ function directoryTraversalProvider() {
+ return [
+ ['../test/'],
+ ['..\\test\\my/../folder'],
+ ['/test/my/../foo\\'],
+ ];
+ }
+
+ /**
+ * @dataProvider directoryTraversalProvider
+ * @expectedException \Exception
+ * @param string $root
+ */
+ public function testConstructDirectoryTraversalException($root) {
+ new \OC\Files\View($root);
+ }
}