aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2013-11-21 12:17:47 +0100
committerVincent Petry <pvince81@owncloud.com>2013-11-21 12:17:47 +0100
commit69e8e7dbd5039652cceb078025248c308ffd0d55 (patch)
tree754057f2db112e38f98c0b601be776d28a9564fb
parent356eef07398f8829a2558eee809599be60441b59 (diff)
downloadnextcloud-server-69e8e7dbd5039652cceb078025248c308ffd0d55.tar.gz
nextcloud-server-69e8e7dbd5039652cceb078025248c308ffd0d55.zip
Now using the "Home" storage detection approach for quota
To find out whether to apply a quota, we now try and detect whether the storage to wrap is a "Home" storage.
-rw-r--r--lib/private/files/storage/home.php17
-rwxr-xr-xlib/private/util.php20
2 files changed, 22 insertions, 15 deletions
diff --git a/lib/private/files/storage/home.php b/lib/private/files/storage/home.php
index b4ceb8f4f9b..1c2a682f197 100644
--- a/lib/private/files/storage/home.php
+++ b/lib/private/files/storage/home.php
@@ -22,6 +22,12 @@ class Home extends Local {
*/
protected $user;
+ /**
+ * @brief Construct a Home storage instance
+ * @param array $arguments array with "user" containing the
+ * storage owner and "legacy" containing "true" if the storage is
+ * a legacy storage with "local::" URL instead of the new "home::" one.
+ */
public function __construct($arguments) {
$this->user = $arguments['user'];
$datadir = $this->user->getHome();
@@ -40,10 +46,21 @@ class Home extends Local {
return $this->id;
}
+ /**
+ * @return \OC\Files\Cache\HomeCache
+ */
public function getCache($path = '') {
if (!isset($this->cache)) {
$this->cache = new \OC\Files\Cache\HomeCache($this);
}
return $this->cache;
}
+
+ /**
+ * @brief Returns the owner of this home storage
+ * @return \OC\User\User owner of this home storage
+ */
+ public function getUser() {
+ return $this->user;
+ }
}
diff --git a/lib/private/util.php b/lib/private/util.php
index 88f1f197b5d..959d36a89e9 100755
--- a/lib/private/util.php
+++ b/lib/private/util.php
@@ -57,21 +57,11 @@ class OC_Util {
// set up quota for home storages, even for other users
// which can happen when using sharing
- if (strlen($mountPoint) > 1) {
- // the user name will be extracted from the mountpoint
- // with the format '/username/' (no suffix)
- $user = null;
- // find second separator
- $nextSepPos = strpos($mountPoint, '/', 1);
- // next separator is the last one, format matches
- if ($nextSepPos === strlen($mountPoint) - 1) {
- $user = substr($mountPoint, 1, $nextSepPos - 1);
- }
- if ($user) {
- $quota = OC_Util::getUserQuota($user);
- if ($quota !== \OC\Files\SPACE_UNLIMITED) {
- return new \OC\Files\Storage\Wrapper\Quota(array('storage' => $storage, 'quota' => $quota));
- }
+ if ($storage instanceof \OC\Files\Storage\Home) {
+ $user = $storage->getUser()->getUID();
+ $quota = OC_Util::getUserQuota($user);
+ if ($quota !== \OC\Files\SPACE_UNLIMITED) {
+ return new \OC\Files\Storage\Wrapper\Quota(array('storage' => $storage, 'quota' => $quota));
}
}