aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2022-03-09 17:23:33 +0100
committerRobin Appelman <robin@icewind.nl>2022-03-24 17:01:49 +0100
commit79f67424108ca0bb159f05370822c0d934dac3b2 (patch)
tree0838647ec1472b078d099b90a9f33c7a9426e4af /lib/private
parent19c64cf8b6782cf69b8e7330f27580451a8965e7 (diff)
downloadnextcloud-server-79f67424108ca0bb159f05370822c0d934dac3b2.tar.gz
nextcloud-server-79f67424108ca0bb159f05370822c0d934dac3b2.zip
improve lazy UserFolder
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib/private')
-rw-r--r--lib/private/Files/Node/LazyUserFolder.php59
-rw-r--r--lib/private/Files/Node/Root.php16
-rw-r--r--lib/private/Files/SetupManager.php2
3 files changed, 70 insertions, 7 deletions
diff --git a/lib/private/Files/Node/LazyUserFolder.php b/lib/private/Files/Node/LazyUserFolder.php
new file mode 100644
index 00000000000..e4f45ad2962
--- /dev/null
+++ b/lib/private/Files/Node/LazyUserFolder.php
@@ -0,0 +1,59 @@
+<?php
+
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2022 Robin Appelman <robin@icewind.nl>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OC\Files\Node;
+
+
+use OCP\Constants;
+use OCP\Files\IRootFolder;
+use OCP\Files\NotFoundException;
+use OCP\IUser;
+
+class LazyUserFolder extends LazyFolder {
+ private IRootFolder $rootFolder;
+ private IUser $user;
+
+ public function __construct(IRootFolder $rootFolder, IUser $user) {
+ $this->rootFolder = $rootFolder;
+ $this->user = $user;
+ parent::__construct(function() use ($user) {
+ try {
+ return $this->rootFolder->get('/' . $user->getUID() . '/files');
+ } catch (NotFoundException $e) {
+ if (!$this->rootFolder->nodeExists('/' . $user->getUID())) {
+ $this->rootFolder->newFolder('/' . $user->getUID());
+ }
+ return $this->rootFolder->newFolder('/' . $user->getUID() . '/files');
+ }
+ }, [
+ 'path' => '/' . $user->getUID() . '/files',
+ 'permissions' => Constants::PERMISSION_ALL,
+ ]);
+ }
+
+ public function get($path) {
+ return $this->rootFolder->get('/' . $this->user->getUID() . '/files/' . rtrim($path, '/'));
+ }
+
+
+}
diff --git a/lib/private/Files/Node/Root.php b/lib/private/Files/Node/Root.php
index e8159b23fec..6cb763e2bbf 100644
--- a/lib/private/Files/Node/Root.php
+++ b/lib/private/Files/Node/Root.php
@@ -381,19 +381,23 @@ class Root extends Folder implements IRootFolder {
$userId = $userObject->getUID();
if (!$this->userFolderCache->hasKey($userId)) {
- $folder = new LazyFolder(function () use ($userId) {
+ if ($this->mountManager->getSetupManager()->isSetupComplete($userObject)) {
try {
- return $this->get('/' . $userId . '/files');
+ $folder = $this->get('/' . $userId . '/files');
+ if ($folder instanceof \OCP\Files\Folder) {
+ return $folder;
+ } else {
+ throw new \Exception("User folder for $userId exists as a file");
+ }
} catch (NotFoundException $e) {
if (!$this->nodeExists('/' . $userId)) {
$this->newFolder('/' . $userId);
}
return $this->newFolder('/' . $userId . '/files');
}
- }, [
- 'path' => '/' . $userId . '/files',
- 'permissions' => Constants::PERMISSION_ALL,
- ]);
+ } else {
+ $folder = new LazyUserFolder($this, $userObject);
+ }
$this->userFolderCache->set($userId, $folder);
}
diff --git a/lib/private/Files/SetupManager.php b/lib/private/Files/SetupManager.php
index 6e246aeb821..7336e40af8a 100644
--- a/lib/private/Files/SetupManager.php
+++ b/lib/private/Files/SetupManager.php
@@ -95,7 +95,7 @@ class SetupManager {
return in_array($user->getUID(), $this->setupUsers, true);
}
- private function isSetupComplete(IUser $user): bool {
+ public function isSetupComplete(IUser $user): bool {
return in_array($user->getUID(), $this->setupUsersComplete, true);
}