aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--apps/files_sharing/lib/SharedStorage.php10
-rw-r--r--lib/private/Files/Cache/Updater.php3
-rw-r--r--lib/private/Files/Mount/MountPoint.php2
-rw-r--r--lib/private/Files/Node/Node.php4
-rw-r--r--lib/private/Files/Storage/Wrapper/Jail.php20
-rw-r--r--lib/private/Files/View.php2
-rw-r--r--lib/private/legacy/OC_Helper.php2
7 files changed, 27 insertions, 16 deletions
diff --git a/apps/files_sharing/lib/SharedStorage.php b/apps/files_sharing/lib/SharedStorage.php
index c56bcaebb12..6d9b9a62e4a 100644
--- a/apps/files_sharing/lib/SharedStorage.php
+++ b/apps/files_sharing/lib/SharedStorage.php
@@ -112,7 +112,7 @@ class SharedStorage extends \OC\Files\Storage\Wrapper\Jail implements ISharedSto
parent::__construct([
'storage' => null,
- 'root' => null,
+ 'root' => '',
]);
}
@@ -292,12 +292,16 @@ class SharedStorage extends \OC\Files\Storage\Wrapper\Jail implements ISharedSto
case 'xb':
case 'a':
case 'ab':
- $creatable = $this->isCreatable(dirname($path));
+ $parent = dirname($path);
+ if ($parent === '.') {
+ $parent = '';
+ }
+ $creatable = $this->isCreatable($parent);
$updatable = $this->isUpdatable($path);
// if neither permissions given, no need to continue
if (!$creatable && !$updatable) {
if (pathinfo($path, PATHINFO_EXTENSION) === 'part') {
- $updatable = $this->isUpdatable(dirname($path));
+ $updatable = $this->isUpdatable($parent);
}
if (!$updatable) {
diff --git a/lib/private/Files/Cache/Updater.php b/lib/private/Files/Cache/Updater.php
index 457dd207e9d..1a9a0f0b68e 100644
--- a/lib/private/Files/Cache/Updater.php
+++ b/lib/private/Files/Cache/Updater.php
@@ -255,6 +255,9 @@ class Updater implements IUpdater {
private function correctParentStorageMtime($internalPath) {
$parentId = $this->cache->getParentId($internalPath);
$parent = dirname($internalPath);
+ if ($parent === '.') {
+ $parent = '';
+ }
if ($parentId != -1) {
$mtime = $this->storage->filemtime($parent);
if ($mtime !== false) {
diff --git a/lib/private/Files/Mount/MountPoint.php b/lib/private/Files/Mount/MountPoint.php
index fe6358b32f1..10711154f14 100644
--- a/lib/private/Files/Mount/MountPoint.php
+++ b/lib/private/Files/Mount/MountPoint.php
@@ -246,7 +246,7 @@ class MountPoint implements IMountPoint {
* @return string
*/
private function formatPath($path) {
- $path = Filesystem::normalizePath($path);
+ $path = '/' . trim($path, '/');
if (strlen($path) > 1) {
$path .= '/';
}
diff --git a/lib/private/Files/Node/Node.php b/lib/private/Files/Node/Node.php
index 385d45f1e3e..082851a2888 100644
--- a/lib/private/Files/Node/Node.php
+++ b/lib/private/Files/Node/Node.php
@@ -70,8 +70,8 @@ class Node implements INode {
* @param FileInfo $fileInfo
*/
public function __construct(IRootFolder $root, $view, $path, $fileInfo = null, ?INode $parent = null, bool $infoHasSubMountsIncluded = true) {
- if (Filesystem::normalizePath($view->getRoot()) !== '/') {
- throw new PreConditionNotMetException('The view passed to the node should not have any fake root set');
+ if ($view->getRoot() !== '') {
+ throw new PreConditionNotMetException('The view passed to the node should not have any fake root set: ' . $view->getRoot());
}
$this->view = $view;
$this->root = $root;
diff --git a/lib/private/Files/Storage/Wrapper/Jail.php b/lib/private/Files/Storage/Wrapper/Jail.php
index 1921ac27848..b66d7d8e0fc 100644
--- a/lib/private/Files/Storage/Wrapper/Jail.php
+++ b/lib/private/Files/Storage/Wrapper/Jail.php
@@ -30,7 +30,6 @@ namespace OC\Files\Storage\Wrapper;
use OC\Files\Cache\Wrapper\CacheJail;
use OC\Files\Cache\Wrapper\JailPropagator;
-use OC\Files\Filesystem;
use OCP\Files\Storage\IStorage;
use OCP\Files\Storage\IWriteStreamStorage;
use OCP\Lock\ILockingProvider;
@@ -42,9 +41,9 @@ use OCP\Lock\ILockingProvider;
*/
class Jail extends Wrapper {
/**
- * @var string
+ * Root of the jail, without trailing slash
*/
- protected $rootPath;
+ protected string $rootPath;
/**
* @param array $arguments ['storage' => $storage, 'root' => $root]
@@ -54,11 +53,18 @@ class Jail extends Wrapper {
*/
public function __construct($arguments) {
parent::__construct($arguments);
- $this->rootPath = $arguments['root'];
+ $this->rootPath = trim($arguments['root'], '/');
}
public function getUnjailedPath($path) {
- return trim(Filesystem::normalizePath($this->rootPath . '/' . $path), '/');
+ $path = trim($path, '/');
+ if ($this->rootPath === '') {
+ return $path;
+ } elseif ($path === '') {
+ return $this->rootPath;
+ } else {
+ return $this->rootPath . '/' . $path;
+ }
}
/**
@@ -70,9 +76,7 @@ class Jail extends Wrapper {
public function getJailedPath($path) {
- $root = rtrim($this->rootPath, '/') . '/';
-
- if ($path !== $this->rootPath && !str_starts_with($path, $root)) {
+ if ($path !== $this->rootPath && !str_starts_with($path, $this->rootPath . '/')) {
return null;
} else {
$path = substr($path, strlen($this->rootPath));
diff --git a/lib/private/Files/View.php b/lib/private/Files/View.php
index 86651ab3e1a..fef6a192906 100644
--- a/lib/private/Files/View.php
+++ b/lib/private/Files/View.php
@@ -1522,7 +1522,7 @@ class View {
$rootEntry['permissions'] = $permissions & (\OCP\Constants::PERMISSION_ALL - (\OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE));
}
- $rootEntry['path'] = substr(Filesystem::normalizePath($path . '/' . $rootEntry['name']), strlen($user) + 2); // full path without /$user/
+ $rootEntry['path'] = substr($path . '/' . $rootEntry['name'], strlen($user) + 2); // full path without /$user/
// if sharing was disabled for the user we remove the share permissions
if (\OCP\Util::isSharingDisabledForUser()) {
diff --git a/lib/private/legacy/OC_Helper.php b/lib/private/legacy/OC_Helper.php
index cf39d045ae9..4bf1cc81f1e 100644
--- a/lib/private/legacy/OC_Helper.php
+++ b/lib/private/legacy/OC_Helper.php
@@ -491,7 +491,7 @@ class OC_Helper {
if (!$view) {
throw new \OCP\Files\NotFoundException();
}
- $fullPath = Filesystem::normalizePath($view->getAbsolutePath($path));
+ $fullPath = rtrim($view->getAbsolutePath($path), '/');
$cacheKey = $fullPath. '::' . ($includeMountPoints ? 'include' : 'exclude');
if ($useCache) {