summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRobin Appelman <icewind@owncloud.com>2016-04-21 14:48:08 +0200
committerThomas Müller <thomas.mueller@tmit.eu>2016-04-29 17:41:09 +0200
commite51467689d29ad68b7562d4b729ad5435f2ba54b (patch)
tree8a6fbd34c8a923fc87173957cd2b178ccda89c0d
parentf79a81258e5a1ecc5563b6d7bcf0a161de7ec44f (diff)
downloadnextcloud-server-e51467689d29ad68b7562d4b729ad5435f2ba54b.tar.gz
nextcloud-server-e51467689d29ad68b7562d4b729ad5435f2ba54b.zip
mount custom cache folder using mount providers
-rw-r--r--lib/private/Files/Filesystem.php19
-rw-r--r--lib/private/Server.php10
-rw-r--r--lib/private/files/mount/cachemountprovider.php69
3 files changed, 78 insertions, 20 deletions
diff --git a/lib/private/Files/Filesystem.php b/lib/private/Files/Filesystem.php
index 7cd1f56071c..d1162324cbb 100644
--- a/lib/private/Files/Filesystem.php
+++ b/lib/private/Files/Filesystem.php
@@ -423,8 +423,6 @@ class Filesystem {
$home = \OC\Files\Filesystem::getStorage($user);
- self::mountCacheDir($user);
-
// Chance to mount for other storages
/** @var \OC\Files\Config\MountProviderCollection $mountConfigManager */
$mountConfigManager = \OC::$server->getMountProviderCollection();
@@ -461,23 +459,6 @@ class Filesystem {
}
/**
- * Mounts the cache directory
- *
- * @param string $user user name
- */
- private static function mountCacheDir($user) {
- $cacheBaseDir = \OC::$server->getConfig()->getSystemValue('cache_path', '');
- if ($cacheBaseDir !== '') {
- $cacheDir = rtrim($cacheBaseDir, '/') . '/' . $user;
- if (!file_exists($cacheDir)) {
- mkdir($cacheDir, 0770, true);
- }
- // mount external cache dir to "/$user/cache" mount point
- self::mount('\OC\Files\Storage\Local', array('datadir' => $cacheDir), '/' . $user . '/cache');
- }
- }
-
- /**
* get the default filesystem view
*
* @return View
diff --git a/lib/private/Server.php b/lib/private/Server.php
index d37edc4f45f..11cce494418 100644
--- a/lib/private/Server.php
+++ b/lib/private/Server.php
@@ -47,6 +47,7 @@ use OC\Diagnostics\NullQueryLogger;
use OC\Diagnostics\QueryLogger;
use OC\Files\Config\UserMountCache;
use OC\Files\Config\UserMountCacheListener;
+use OC\Files\Mount\CacheMountProvider;
use OC\Files\Node\HookConnector;
use OC\Files\Node\LazyRoot;
use OC\Files\Node\Root;
@@ -444,7 +445,14 @@ class Server extends ServerContainer implements IServerContainer {
$this->registerService('MountConfigManager', function (Server $c) {
$loader = \OC\Files\Filesystem::getLoader();
$mountCache = $c->query('UserMountCache');
- return new \OC\Files\Config\MountProviderCollection($loader, $mountCache);
+ $manager = new \OC\Files\Config\MountProviderCollection($loader, $mountCache);
+
+ // builtin providers
+
+ $config = $c->getConfig();
+ $manager->registerProvider(new CacheMountProvider($config));
+
+ return $manager;
});
$this->registerService('IniWrapper', function ($c) {
return new IniGetWrapper();
diff --git a/lib/private/files/mount/cachemountprovider.php b/lib/private/files/mount/cachemountprovider.php
new file mode 100644
index 00000000000..c8422c4a507
--- /dev/null
+++ b/lib/private/files/mount/cachemountprovider.php
@@ -0,0 +1,69 @@
+<?php
+/**
+ * @author Robin Appelman <icewind@owncloud.com>
+ *
+ * @copyright Copyright (c) 2016, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * 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, version 3,
+ * along with this program. If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+namespace OC\Files\Mount;
+
+use OCP\Files\Config\IMountProvider;
+use OCP\Files\Storage\IStorageFactory;
+use OCP\IConfig;
+use OCP\IUser;
+
+/**
+ * Mount provider for custom cache storages
+ */
+class CacheMountProvider implements IMountProvider {
+ /**
+ * @var IConfig
+ */
+ private $config;
+
+ /**
+ * ObjectStoreHomeMountProvider constructor.
+ *
+ * @param IConfig $config
+ */
+ public function __construct(IConfig $config) {
+ $this->config = $config;
+ }
+
+ /**
+ * Get the cache mount for a user
+ *
+ * @param IUser $user
+ * @param IStorageFactory $loader
+ * @return \OCP\Files\Mount\IMountPoint[]
+ */
+ public function getMountsForUser(IUser $user, IStorageFactory $loader) {
+ $cacheBaseDir = $this->config->getSystemValue('cache_path', '');
+ if ($cacheBaseDir !== '') {
+ $cacheDir = rtrim($cacheBaseDir, '/') . '/' . $user->getUID();
+ if (!file_exists($cacheDir)) {
+ mkdir($cacheDir, 0770, true);
+ }
+
+ return [
+ new MountPoint('\OC\Files\Storage\Local', '/' . $user->getUID() . '/cache', ['datadir' => $cacheDir, $loader])
+ ];
+ } else {
+ return [];
+ }
+ }
+}