diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2017-07-12 12:14:51 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-12 12:14:51 +0200 |
commit | 08d3cb9107ef800112cc131dfd41b0dd6c43f1f7 (patch) | |
tree | 2f018b0196ad7fbe0e4af452a441d83f650aa412 /lib | |
parent | 13295c2d1ddf3e4daf491a6c41303dbd1dc40b68 (diff) | |
parent | dfe662ad4222ea6eed2bce4b18aaa4e343fd4af1 (diff) | |
download | nextcloud-server-08d3cb9107ef800112cc131dfd41b0dd6c43f1f7.tar.gz nextcloud-server-08d3cb9107ef800112cc131dfd41b0dd6c43f1f7.zip |
Merge pull request #5685 from nextcloud/jail-propagator
Fix propagating changes within jail wrapper
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/Files/Cache/Wrapper/JailPropagator.php | 44 | ||||
-rw-r--r-- | lib/private/Files/Storage/Wrapper/Jail.php | 13 |
2 files changed, 57 insertions, 0 deletions
diff --git a/lib/private/Files/Cache/Wrapper/JailPropagator.php b/lib/private/Files/Cache/Wrapper/JailPropagator.php new file mode 100644 index 00000000000..297dfce6332 --- /dev/null +++ b/lib/private/Files/Cache/Wrapper/JailPropagator.php @@ -0,0 +1,44 @@ +<?php +/** + * @copyright Copyright (c) 2017 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\Cache\Wrapper; + + +use OC\Files\Cache\Propagator; +use OC\Files\Storage\Wrapper\Jail; + +class JailPropagator extends Propagator { + /** + * @var Jail + */ + protected $storage; + + /** + * @param string $internalPath + * @param int $time + * @param int $sizeDifference + */ + public function propagateChange($internalPath, $time, $sizeDifference = 0) { + /** @var \OC\Files\Storage\Storage $storage */ + list($storage, $sourceInternalPath) = $this->storage->resolvePath($internalPath); + $storage->getPropagator()->propagateChange($sourceInternalPath, $time, $sizeDifference); + } +} diff --git a/lib/private/Files/Storage/Wrapper/Jail.php b/lib/private/Files/Storage/Wrapper/Jail.php index 91e8e5ed3c9..4fa2428c968 100644 --- a/lib/private/Files/Storage/Wrapper/Jail.php +++ b/lib/private/Files/Storage/Wrapper/Jail.php @@ -25,6 +25,7 @@ namespace OC\Files\Storage\Wrapper; use OC\Files\Cache\Wrapper\CacheJail; +use OC\Files\Cache\Wrapper\JailPropagator; use OCP\Lock\ILockingProvider; /** @@ -488,4 +489,16 @@ class Jail extends Wrapper { } return $this->getWrapperStorage()->moveFromStorage($sourceStorage, $sourceInternalPath, $this->getUnjailedPath($targetInternalPath)); } + + public function getPropagator($storage = null) { + if (isset($this->propagator)) { + return $this->propagator; + } + + if (!$storage) { + $storage = $this; + } + $this->propagator = new JailPropagator($storage, \OC::$server->getDatabaseConnection()); + return $this->propagator; + } } |