Skip to content

Commit

Permalink
Make it easier to debug issue #32304
Browse files Browse the repository at this point in the history
Signed-off-by: Carl Schwan <carl@carlschwan.eu>
  • Loading branch information
CarlSchwan committed Jun 21, 2022
1 parent dbc2c23 commit 9b6aa4d
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 7 deletions.
7 changes: 4 additions & 3 deletions lib/private/Files/Node/LazyFolder.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
namespace OC\Files\Node;

use OC\Files\Utils\PathHelper;
use OCP\Files\Folder;
use OCP\Constants;

/**
Expand All @@ -37,8 +38,8 @@
*
* @package OC\Files\Node
*/
class LazyFolder implements \OCP\Files\Folder {
/** @var \Closure */
class LazyFolder implements Folder {
/** @var \Closure(): Folder */
private $folderClosure;

/** @var LazyFolder | null */
Expand All @@ -49,7 +50,7 @@ class LazyFolder implements \OCP\Files\Folder {
/**
* LazyFolder constructor.
*
* @param \Closure $folderClosure
* @param \Closure(): Folder $folderClosure
*/
public function __construct(\Closure $folderClosure, array $data = []) {
$this->folderClosure = $folderClosure;
Expand Down
19 changes: 15 additions & 4 deletions lib/private/Files/Node/LazyUserFolder.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,10 @@
use OCP\Constants;
use OCP\Files\IRootFolder;
use OCP\Files\NotFoundException;
use OCP\Files\Folder;
use OCP\Files\File;
use OCP\IUser;
use Psr\Log\LoggerInterface;

class LazyUserFolder extends LazyFolder {
private IRootFolder $root;
Expand All @@ -38,14 +41,22 @@ public function __construct(IRootFolder $rootFolder, IUser $user) {
$this->root = $rootFolder;
$this->user = $user;
$this->path = '/' . $user->getUID() . '/files';
parent::__construct(function () use ($user) {
parent::__construct(function () use ($user): Folder {
try {
return $this->root->get('/' . $user->getUID() . '/files');
$node = $this->root->get($this->path);
if ($node instanceof File) {
$e = new \RuntimeException();
\OCP\Server::get(LoggerInterface::class)->error('User root storage is not a folder: ' . $this->path, [
'exception' => $e,
]);
throw $e;
}
return $node;
} catch (NotFoundException $e) {
if (!$this->root->nodeExists('/' . $user->getUID())) {
$this->root->newFolder('/' . $user->getUID());
}
return $this->root->newFolder('/' . $user->getUID() . '/files');
return $this->root->newFolder($this->path);
}
}, [
'path' => $this->path,
Expand All @@ -56,7 +67,7 @@ public function __construct(IRootFolder $rootFolder, IUser $user) {
}

public function get($path) {
return $this->root->get('/' . $this->user->getUID() . '/files/' . ltrim($path, '/'));
return $this->root->get('/' . $this->user->getUID() . '/files' . ltrim($path, '/'));
}

/**
Expand Down

0 comments on commit 9b6aa4d

Please sign in to comment.