summaryrefslogtreecommitdiffstats
path: root/lib/private
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2017-04-12 11:44:26 -0500
committerGitHub <noreply@github.com>2017-04-12 11:44:26 -0500
commit31024b7700e025c78c1da94ab77564adeca54dee (patch)
tree9b3ee396c4947db249ff124157b385a4e90bb590 /lib/private
parentdccb8928a11fd572337d8b6ff5987cb411172276 (diff)
parent8500debe79545dfb6a982de1d492478f9db84370 (diff)
downloadnextcloud-server-31024b7700e025c78c1da94ab77564adeca54dee.tar.gz
nextcloud-server-31024b7700e025c78c1da94ab77564adeca54dee.zip
Merge pull request #4329 from nextcloud/move-out-shared-folder
Fix moving files out of a shared folder
Diffstat (limited to 'lib/private')
-rw-r--r--lib/private/Files/Node/Folder.php2
-rw-r--r--lib/private/Files/Storage/Local.php11
-rw-r--r--lib/private/Files/Storage/Wrapper/Jail.php80
3 files changed, 50 insertions, 43 deletions
diff --git a/lib/private/Files/Node/Folder.php b/lib/private/Files/Node/Folder.php
index 45372d0fedf..9809c6b7d11 100644
--- a/lib/private/Files/Node/Folder.php
+++ b/lib/private/Files/Node/Folder.php
@@ -413,7 +413,7 @@ class Folder extends Node implements \OCP\Files\Folder {
$storage = $mount->getStorage();
if ($storage->instanceOfStorage('\OC\Files\Storage\Wrapper\Jail')) {
/** @var \OC\Files\Storage\Wrapper\Jail $storage */
- $jailRoot = $storage->getSourcePath('');
+ $jailRoot = $storage->getUnjailedPath('');
$rootLength = strlen($jailRoot) + 1;
if ($path === $jailRoot) {
return $mount->getMountPoint();
diff --git a/lib/private/Files/Storage/Local.php b/lib/private/Files/Storage/Local.php
index 5597c0c64cc..4eb9fb13deb 100644
--- a/lib/private/Files/Storage/Local.php
+++ b/lib/private/Files/Storage/Local.php
@@ -35,6 +35,7 @@
namespace OC\Files\Storage;
+use OC\Files\Storage\Wrapper\Jail;
use OCP\Files\ForbiddenException;
/**
@@ -371,7 +372,7 @@ class Local extends \OC\Files\Storage\Common {
return $fullPath;
}
- \OCP\Util::writeLog('core', "Following symlinks is not allowed ('$fullPath' -> '$realPath' not inside '{$this->realDataDir}')", \OCP\Util::ERROR);
+ \OCP\Util::writeLog('core', "Following symlinks is not allowed ('$fullPath' -> '$realPath' not inside '{$this->realDataDir}')", \OCP\Util::ERROR);
throw new ForbiddenException('Following symlinks is not allowed', false);
}
@@ -427,7 +428,13 @@ class Local extends \OC\Files\Storage\Common {
* @return bool
*/
public function moveFromStorage(\OCP\Files\Storage $sourceStorage, $sourceInternalPath, $targetInternalPath) {
- if ($sourceStorage->instanceOfStorage('\OC\Files\Storage\Local')) {
+ if ($sourceStorage->instanceOfStorage(Local::class)) {
+ if ($sourceStorage->instanceOfStorage(Jail::class)) {
+ /**
+ * @var \OC\Files\Storage\Wrapper\Jail $sourceStorage
+ */
+ $sourceInternalPath = $sourceStorage->getUnjailedPath($sourceInternalPath);
+ }
/**
* @var \OC\Files\Storage\Local $sourceStorage
*/
diff --git a/lib/private/Files/Storage/Wrapper/Jail.php b/lib/private/Files/Storage/Wrapper/Jail.php
index 013f5ab2344..91e8e5ed3c9 100644
--- a/lib/private/Files/Storage/Wrapper/Jail.php
+++ b/lib/private/Files/Storage/Wrapper/Jail.php
@@ -49,7 +49,7 @@ class Jail extends Wrapper {
$this->rootPath = $arguments['root'];
}
- public function getSourcePath($path) {
+ public function getUnjailedPath($path) {
if ($path === '') {
return $this->rootPath;
} else {
@@ -68,7 +68,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function mkdir($path) {
- return $this->getWrapperStorage()->mkdir($this->getSourcePath($path));
+ return $this->getWrapperStorage()->mkdir($this->getUnjailedPath($path));
}
/**
@@ -78,7 +78,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function rmdir($path) {
- return $this->getWrapperStorage()->rmdir($this->getSourcePath($path));
+ return $this->getWrapperStorage()->rmdir($this->getUnjailedPath($path));
}
/**
@@ -88,7 +88,7 @@ class Jail extends Wrapper {
* @return resource
*/
public function opendir($path) {
- return $this->getWrapperStorage()->opendir($this->getSourcePath($path));
+ return $this->getWrapperStorage()->opendir($this->getUnjailedPath($path));
}
/**
@@ -98,7 +98,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function is_dir($path) {
- return $this->getWrapperStorage()->is_dir($this->getSourcePath($path));
+ return $this->getWrapperStorage()->is_dir($this->getUnjailedPath($path));
}
/**
@@ -108,7 +108,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function is_file($path) {
- return $this->getWrapperStorage()->is_file($this->getSourcePath($path));
+ return $this->getWrapperStorage()->is_file($this->getUnjailedPath($path));
}
/**
@@ -119,7 +119,7 @@ class Jail extends Wrapper {
* @return array
*/
public function stat($path) {
- return $this->getWrapperStorage()->stat($this->getSourcePath($path));
+ return $this->getWrapperStorage()->stat($this->getUnjailedPath($path));
}
/**
@@ -129,7 +129,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function filetype($path) {
- return $this->getWrapperStorage()->filetype($this->getSourcePath($path));
+ return $this->getWrapperStorage()->filetype($this->getUnjailedPath($path));
}
/**
@@ -140,7 +140,7 @@ class Jail extends Wrapper {
* @return int
*/
public function filesize($path) {
- return $this->getWrapperStorage()->filesize($this->getSourcePath($path));
+ return $this->getWrapperStorage()->filesize($this->getUnjailedPath($path));
}
/**
@@ -150,7 +150,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function isCreatable($path) {
- return $this->getWrapperStorage()->isCreatable($this->getSourcePath($path));
+ return $this->getWrapperStorage()->isCreatable($this->getUnjailedPath($path));
}
/**
@@ -160,7 +160,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function isReadable($path) {
- return $this->getWrapperStorage()->isReadable($this->getSourcePath($path));
+ return $this->getWrapperStorage()->isReadable($this->getUnjailedPath($path));
}
/**
@@ -170,7 +170,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function isUpdatable($path) {
- return $this->getWrapperStorage()->isUpdatable($this->getSourcePath($path));
+ return $this->getWrapperStorage()->isUpdatable($this->getUnjailedPath($path));
}
/**
@@ -180,7 +180,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function isDeletable($path) {
- return $this->getWrapperStorage()->isDeletable($this->getSourcePath($path));
+ return $this->getWrapperStorage()->isDeletable($this->getUnjailedPath($path));
}
/**
@@ -190,7 +190,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function isSharable($path) {
- return $this->getWrapperStorage()->isSharable($this->getSourcePath($path));
+ return $this->getWrapperStorage()->isSharable($this->getUnjailedPath($path));
}
/**
@@ -201,7 +201,7 @@ class Jail extends Wrapper {
* @return int
*/
public function getPermissions($path) {
- return $this->getWrapperStorage()->getPermissions($this->getSourcePath($path));
+ return $this->getWrapperStorage()->getPermissions($this->getUnjailedPath($path));
}
/**
@@ -211,7 +211,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function file_exists($path) {
- return $this->getWrapperStorage()->file_exists($this->getSourcePath($path));
+ return $this->getWrapperStorage()->file_exists($this->getUnjailedPath($path));
}
/**
@@ -221,7 +221,7 @@ class Jail extends Wrapper {
* @return int
*/
public function filemtime($path) {
- return $this->getWrapperStorage()->filemtime($this->getSourcePath($path));
+ return $this->getWrapperStorage()->filemtime($this->getUnjailedPath($path));
}
/**
@@ -231,7 +231,7 @@ class Jail extends Wrapper {
* @return string
*/
public function file_get_contents($path) {
- return $this->getWrapperStorage()->file_get_contents($this->getSourcePath($path));
+ return $this->getWrapperStorage()->file_get_contents($this->getUnjailedPath($path));
}
/**
@@ -242,7 +242,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function file_put_contents($path, $data) {
- return $this->getWrapperStorage()->file_put_contents($this->getSourcePath($path), $data);
+ return $this->getWrapperStorage()->file_put_contents($this->getUnjailedPath($path), $data);
}
/**
@@ -252,7 +252,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function unlink($path) {
- return $this->getWrapperStorage()->unlink($this->getSourcePath($path));
+ return $this->getWrapperStorage()->unlink($this->getUnjailedPath($path));
}
/**
@@ -263,7 +263,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function rename($path1, $path2) {
- return $this->getWrapperStorage()->rename($this->getSourcePath($path1), $this->getSourcePath($path2));
+ return $this->getWrapperStorage()->rename($this->getUnjailedPath($path1), $this->getUnjailedPath($path2));
}
/**
@@ -274,7 +274,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function copy($path1, $path2) {
- return $this->getWrapperStorage()->copy($this->getSourcePath($path1), $this->getSourcePath($path2));
+ return $this->getWrapperStorage()->copy($this->getUnjailedPath($path1), $this->getUnjailedPath($path2));
}
/**
@@ -285,7 +285,7 @@ class Jail extends Wrapper {
* @return resource
*/
public function fopen($path, $mode) {
- return $this->getWrapperStorage()->fopen($this->getSourcePath($path), $mode);
+ return $this->getWrapperStorage()->fopen($this->getUnjailedPath($path), $mode);
}
/**
@@ -296,7 +296,7 @@ class Jail extends Wrapper {
* @return string
*/
public function getMimeType($path) {
- return $this->getWrapperStorage()->getMimeType($this->getSourcePath($path));
+ return $this->getWrapperStorage()->getMimeType($this->getUnjailedPath($path));
}
/**
@@ -308,7 +308,7 @@ class Jail extends Wrapper {
* @return string
*/
public function hash($type, $path, $raw = false) {
- return $this->getWrapperStorage()->hash($type, $this->getSourcePath($path), $raw);
+ return $this->getWrapperStorage()->hash($type, $this->getUnjailedPath($path), $raw);
}
/**
@@ -318,7 +318,7 @@ class Jail extends Wrapper {
* @return int
*/
public function free_space($path) {
- return $this->getWrapperStorage()->free_space($this->getSourcePath($path));
+ return $this->getWrapperStorage()->free_space($this->getUnjailedPath($path));
}
/**
@@ -340,7 +340,7 @@ class Jail extends Wrapper {
* @return bool
*/
public function touch($path, $mtime = null) {
- return $this->getWrapperStorage()->touch($this->getSourcePath($path), $mtime);
+ return $this->getWrapperStorage()->touch($this->getUnjailedPath($path), $mtime);
}
/**
@@ -351,7 +351,7 @@ class Jail extends Wrapper {
* @return string
*/
public function getLocalFile($path) {
- return $this->getWrapperStorage()->getLocalFile($this->getSourcePath($path));
+ return $this->getWrapperStorage()->getLocalFile($this->getUnjailedPath($path));
}
/**
@@ -365,7 +365,7 @@ class Jail extends Wrapper {
* returning true for other changes in the folder is optional
*/
public function hasUpdated($path, $time) {
- return $this->getWrapperStorage()->hasUpdated($this->getSourcePath($path), $time);
+ return $this->getWrapperStorage()->hasUpdated($this->getUnjailedPath($path), $time);
}
/**
@@ -379,7 +379,7 @@ class Jail extends Wrapper {
if (!$storage) {
$storage = $this->getWrapperStorage();
}
- $sourceCache = $this->getWrapperStorage()->getCache($this->getSourcePath($path), $storage);
+ $sourceCache = $this->getWrapperStorage()->getCache($this->getUnjailedPath($path), $storage);
return new CacheJail($sourceCache, $this->rootPath);
}
@@ -390,7 +390,7 @@ class Jail extends Wrapper {
* @return string
*/
public function getOwner($path) {
- return $this->getWrapperStorage()->getOwner($this->getSourcePath($path));
+ return $this->getWrapperStorage()->getOwner($this->getUnjailedPath($path));
}
/**
@@ -404,7 +404,7 @@ class Jail extends Wrapper {
if (!$storage) {
$storage = $this;
}
- return $this->getWrapperStorage()->getWatcher($this->getSourcePath($path), $storage);
+ return $this->getWrapperStorage()->getWatcher($this->getUnjailedPath($path), $storage);
}
/**
@@ -414,7 +414,7 @@ class Jail extends Wrapper {
* @return string
*/
public function getETag($path) {
- return $this->getWrapperStorage()->getETag($this->getSourcePath($path));
+ return $this->getWrapperStorage()->getETag($this->getUnjailedPath($path));
}
/**
@@ -422,7 +422,7 @@ class Jail extends Wrapper {
* @return array
*/
public function getMetaData($path) {
- return $this->getWrapperStorage()->getMetaData($this->getSourcePath($path));
+ return $this->getWrapperStorage()->getMetaData($this->getUnjailedPath($path));
}
/**
@@ -432,7 +432,7 @@ class Jail extends Wrapper {
* @throws \OCP\Lock\LockedException
*/
public function acquireLock($path, $type, ILockingProvider $provider) {
- $this->getWrapperStorage()->acquireLock($this->getSourcePath($path), $type, $provider);
+ $this->getWrapperStorage()->acquireLock($this->getUnjailedPath($path), $type, $provider);
}
/**
@@ -441,7 +441,7 @@ class Jail extends Wrapper {
* @param \OCP\Lock\ILockingProvider $provider
*/
public function releaseLock($path, $type, ILockingProvider $provider) {
- $this->getWrapperStorage()->releaseLock($this->getSourcePath($path), $type, $provider);
+ $this->getWrapperStorage()->releaseLock($this->getUnjailedPath($path), $type, $provider);
}
/**
@@ -450,7 +450,7 @@ class Jail extends Wrapper {
* @param \OCP\Lock\ILockingProvider $provider
*/
public function changeLock($path, $type, ILockingProvider $provider) {
- $this->getWrapperStorage()->changeLock($this->getSourcePath($path), $type, $provider);
+ $this->getWrapperStorage()->changeLock($this->getUnjailedPath($path), $type, $provider);
}
/**
@@ -460,7 +460,7 @@ class Jail extends Wrapper {
* @return array
*/
public function resolvePath($path) {
- return [$this->getWrapperStorage(), $this->getSourcePath($path)];
+ return [$this->getWrapperStorage(), $this->getUnjailedPath($path)];
}
/**
@@ -473,7 +473,7 @@ class Jail extends Wrapper {
if ($sourceStorage === $this) {
return $this->copy($sourceInternalPath, $targetInternalPath);
}
- return $this->getWrapperStorage()->copyFromStorage($sourceStorage, $sourceInternalPath, $this->getSourcePath($targetInternalPath));
+ return $this->getWrapperStorage()->copyFromStorage($sourceStorage, $sourceInternalPath, $this->getUnjailedPath($targetInternalPath));
}
/**
@@ -486,6 +486,6 @@ class Jail extends Wrapper {
if ($sourceStorage === $this) {
return $this->rename($sourceInternalPath, $targetInternalPath);
}
- return $this->getWrapperStorage()->moveFromStorage($sourceStorage, $sourceInternalPath, $this->getSourcePath($targetInternalPath));
+ return $this->getWrapperStorage()->moveFromStorage($sourceStorage, $sourceInternalPath, $this->getUnjailedPath($targetInternalPath));
}
}