summaryrefslogtreecommitdiffstats
path: root/lib/private/Files/AppData/AppData.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/private/Files/AppData/AppData.php')
-rw-r--r--lib/private/Files/AppData/AppData.php88
1 files changed, 63 insertions, 25 deletions
diff --git a/lib/private/Files/AppData/AppData.php b/lib/private/Files/AppData/AppData.php
index e25bf450446..3d098ad98ca 100644
--- a/lib/private/Files/AppData/AppData.php
+++ b/lib/private/Files/AppData/AppData.php
@@ -24,6 +24,7 @@ declare(strict_types=1);
namespace OC\Files\AppData;
+use OC\Cache\CappedMemoryCache;
use OC\Files\SimpleFS\SimpleFolder;
use OCP\Files\IAppData;
use OCP\Files\IRootFolder;
@@ -48,6 +49,9 @@ class AppData implements IAppData {
/** @var Folder */
private $folder;
+ /** @var (ISimpleFolder|NotFoundException)[]|CappedMemoryCache */
+ private $folders;
+
/**
* AppData constructor.
*
@@ -62,6 +66,32 @@ class AppData implements IAppData {
$this->rootFolder = $rootFolder;
$this->config = $systemConfig;
$this->appId = $appId;
+ $this->folders = new CappedMemoryCache();
+ }
+
+ private function getAppDataFolderName() {
+ $instanceId = $this->config->getValue('instanceid', null);
+ if ($instanceId === null) {
+ throw new \RuntimeException('no instance id!');
+ }
+
+ return 'appdata_' . $instanceId;
+ }
+
+ private function getAppDataRootFolder(): Folder {
+ $name = $this->getAppDataFolderName();
+
+ try {
+ /** @var Folder $node */
+ $node = $this->rootFolder->get($name);
+ return $node;
+ } catch (NotFoundException $e) {
+ try {
+ return $this->rootFolder->newFolder($name);
+ } catch (NotPermittedException $e) {
+ throw new \RuntimeException('Could not get appdata folder');
+ }
+ }
}
/**
@@ -70,56 +100,64 @@ class AppData implements IAppData {
*/
private function getAppDataFolder(): Folder {
if ($this->folder === null) {
- $instanceId = $this->config->getValue('instanceid', null);
- if ($instanceId === null) {
- throw new \RuntimeException('no instance id!');
- }
-
- $name = 'appdata_' . $instanceId;
+ $name = $this->getAppDataFolderName();
try {
- $appDataFolder = $this->rootFolder->get($name);
+ $this->folder = $this->rootFolder->get($name . '/' . $this->appId);
} catch (NotFoundException $e) {
- try {
- $appDataFolder = $this->rootFolder->newFolder($name);
- } catch (NotPermittedException $e) {
- throw new \RuntimeException('Could not get appdata folder');
- }
- }
+ $appDataRootFolder = $this->getAppDataRootFolder();
- try {
- $appDataFolder = $appDataFolder->get($this->appId);
- } catch (NotFoundException $e) {
try {
- $appDataFolder = $appDataFolder->newFolder($this->appId);
- } catch (NotPermittedException $e) {
- throw new \RuntimeException('Could not get appdata folder for ' . $this->appId);
+ $this->folder = $appDataRootFolder->get($this->appId);
+ } catch (NotFoundException $e) {
+ try {
+ $this->folder = $appDataRootFolder->newFolder($this->appId);
+ } catch (NotPermittedException $e) {
+ throw new \RuntimeException('Could not get appdata folder for ' . $this->appId);
+ }
}
}
-
- $this->folder = $appDataFolder;
}
return $this->folder;
}
public function getFolder(string $name): ISimpleFolder {
- $node = $this->getAppDataFolder()->get($name);
+ $key = $this->appId . '/' . $name;
+ if ($cachedFolder = $this->folders->get($key)) {
+ if ($cachedFolder instanceof \Exception) {
+ throw $cachedFolder;
+ } else {
+ return $cachedFolder;
+ }
+ }
+ try {
+ $path = $this->getAppDataFolderName() . '/' . $this->appId . '/' . $name;
+ $node = $this->rootFolder->get($path);
+ } catch (NotFoundException $e) {
+ $this->folders->set($key, $e);
+ throw $e;
+ }
/** @var Folder $node */
- return new SimpleFolder($node);
+ $folder = new SimpleFolder($node);
+ $this->folders->set($key, $folder);
+ return $folder;
}
public function newFolder(string $name): ISimpleFolder {
+ $key = $this->appId . '/' . $name;
$folder = $this->getAppDataFolder()->newFolder($name);
- return new SimpleFolder($folder);
+ $simpleFolder = new SimpleFolder($folder);
+ $this->folders->set($key, $simpleFolder);
+ return $simpleFolder;
}
public function getDirectoryListing(): array {
$listing = $this->getAppDataFolder()->getDirectoryListing();
- $fileListing = array_map(function(Node $folder) {
+ $fileListing = array_map(function (Node $folder) {
if ($folder instanceof Folder) {
return new SimpleFolder($folder);
}