summaryrefslogtreecommitdiffstats
path: root/lib/private/files/storage/wrapper/lockingwrapper.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/private/files/storage/wrapper/lockingwrapper.php')
-rw-r--r--lib/private/files/storage/wrapper/lockingwrapper.php182
1 files changed, 0 insertions, 182 deletions
diff --git a/lib/private/files/storage/wrapper/lockingwrapper.php b/lib/private/files/storage/wrapper/lockingwrapper.php
deleted file mode 100644
index b785046bc3c..00000000000
--- a/lib/private/files/storage/wrapper/lockingwrapper.php
+++ /dev/null
@@ -1,182 +0,0 @@
-<?php
-
-/**
- * Copyright (c) 2013 ownCloud, Inc.
- * This file is licensed under the Affero General Public License version 3 or
- * later.
- * See the COPYING-README file.
- */
-
-namespace OC\Files\Storage\Wrapper;
-
-use OC\Files\Filesystem;
-use OC\Files\Lock;
-
-/**
- * Class LockingWrapper
- * A Storage Wrapper used to lock files at the system level
- * @package OC\Files\Storage\Wrapper
- *
- * Notes: Does the $locks array need to be global to all LockingWrapper instances, such as in the case of two paths
- * that point to the same physical file? Otherwise accessing the file from a different path the second time would show
- * the file as locked, even though this process is the one locking it.
- */
-class LockingWrapper extends Wrapper {
-
- /** @var \OCP\Files\Lock[] $locks Holds an array of lock instances indexed by path for this storage */
- protected $locks = array();
-
- /**
- * Acquire a lock on a file
- * @param string $path Path to file, relative to this storage
- * @param integer $lockType A Lock class constant, Lock::READ/Lock::WRITE
- * @param null|resource $existingHandle An existing file handle from an fopen()
- * @return bool|\OCP\Files\Lock Lock instance on success, false on failure
- */
- protected function getLock($path, $lockType, $existingHandle = null){
- $path = Filesystem::normalizePath($this->storage->getLocalFile($path));
- if(!isset($this->locks[$path])) {
- $this->locks[$path] = new Lock($path);
- }
- $this->locks[$path]->addLock($lockType, $existingHandle);
- return $this->locks[$path];
- }
-
- /**
- * Release an existing lock
- * @param string $path Path to file, relative to this storage
- * @param integer $lockType The type of lock to release
- * @param bool $releaseAll If true, release all outstanding locks
- * @return bool true on success, false on failure
- */
- protected function releaseLock($path, $lockType, $releaseAll = false){
- $path = Filesystem::normalizePath($this->storage->getLocalFile($path));
- if(isset($this->locks[$path])) {
- if($releaseAll) {
- return $this->locks[$path]->releaseAll();
- }
- else {
- return $this->locks[$path]->release($lockType);
- }
- }
- return true;
- }
-
- /**
- * see http://php.net/manual/en/function.file_get_contents.php
- * @param string $path
- * @return string
- * @throws \Exception
- */
- public function file_get_contents($path) {
- try {
- $this->getLock($path, Lock::READ);
- $result = $this->storage->file_get_contents($path);
- }
- catch(\Exception $originalException) {
- // Need to release the lock before more operations happen in upstream exception handlers
- $this->releaseLock($path, Lock::READ);
- throw $originalException;
- }
- $this->releaseLock($path, Lock::READ);
- return $result;
- }
-
- public function file_put_contents($path, $data) {
- try {
- $this->getLock($path, Lock::WRITE);
- $result = $this->storage->file_put_contents($path, $data);
- }
- catch(\Exception $originalException) {
- // Release lock, throw original exception
- $this->releaseLock($path, Lock::WRITE);
- throw $originalException;
- }
- $this->releaseLock($path, Lock::WRITE);
- return $result;
- }
-
-
- public function copy($path1, $path2) {
- try {
- $this->getLock($path1, Lock::READ);
- $this->getLock($path2, Lock::WRITE);
- $result = $this->storage->copy($path1, $path2);
- }
- catch(\Exception $originalException) {
- // Release locks, throw original exception
- $this->releaseLock($path1, Lock::READ);
- $this->releaseLock($path2, Lock::WRITE);
- throw $originalException;
- }
- $this->releaseLock($path1, Lock::READ);
- $this->releaseLock($path2, Lock::WRITE);
- return $result;
- }
-
- public function rename($path1, $path2) {
- try {
- $this->getLock($path1, Lock::READ);
- $this->getLock($path2, Lock::WRITE);
- $result = $this->storage->rename($path1, $path2);
- }
- catch(\Exception $originalException) {
- // Release locks, throw original exception
- $this->releaseLock($path1, Lock::READ);
- $this->releaseLock($path2, Lock::WRITE);
- throw $originalException;
- }
- $this->releaseLock($path1, Lock::READ);
- $this->releaseLock($path2, Lock::WRITE);
- return $result;
- }
-
- public function fopen($path, $mode) {
- $lockType = Lock::READ;
- switch ($mode) {
- case 'r+':
- case 'rb+':
- case 'w+':
- case 'wb+':
- case 'x+':
- case 'xb+':
- case 'a+':
- case 'ab+':
- case 'c+':
- case 'w':
- case 'wb':
- case 'x':
- case 'xb':
- case 'a':
- case 'ab':
- case 'c':
- $lockType = Lock::WRITE;
- break;
- }
- // The handle for $this->fopen() is used outside of this class, so the handle/lock can't be closed
- // Instead, it will be closed when the request goes out of scope
- // Storage doesn't have an fclose()
- if($result = $this->storage->fopen($path, $mode)) {
- $this->getLock($path, $lockType, $result);
- }
- return $result;
- }
-
- public function unlink($path) {
- try {
- if (\OC\Files\Filesystem::is_file($path)) {
- $this->getLock($path, Lock::WRITE);
- }
- $result = $this->storage->unlink($path);
- }
- catch(\Exception $originalException) {
- // Need to release the lock before more operations happen in upstream exception handlers
- $this->releaseLock($path, Lock::WRITE);
- throw $originalException;
- }
- $this->releaseLock($path, Lock::WRITE);
- return $result;
- }
-
-
-} \ No newline at end of file