2013-01-26 20:42:59 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2012 Robin Appelman <icewind@owncloud.com>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
2013-04-25 22:01:36 +00:00
|
|
|
namespace OC\Files\Mount;
|
|
|
|
|
|
|
|
use \OC\Files\Filesystem;
|
2013-01-26 20:42:59 +00:00
|
|
|
|
|
|
|
class Mount {
|
2013-04-25 22:01:36 +00:00
|
|
|
|
2013-01-26 20:42:59 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \OC\Files\Storage\Storage $storage
|
|
|
|
*/
|
|
|
|
private $storage = null;
|
|
|
|
private $class;
|
|
|
|
private $storageId;
|
|
|
|
private $arguments = array();
|
|
|
|
private $mountPoint;
|
|
|
|
|
2013-05-08 20:35:10 +00:00
|
|
|
/**
|
|
|
|
* @var callable[] $storageWrappers
|
|
|
|
*/
|
|
|
|
private $storageWrappers = array();
|
|
|
|
|
2013-01-26 20:42:59 +00:00
|
|
|
/**
|
|
|
|
* @param string|\OC\Files\Storage\Storage $storage
|
|
|
|
* @param string $mountpoint
|
2013-01-26 22:49:05 +00:00
|
|
|
* @param array $arguments (optional)
|
2013-01-26 20:42:59 +00:00
|
|
|
*/
|
|
|
|
public function __construct($storage, $mountpoint, $arguments = null) {
|
|
|
|
if (is_null($arguments)) {
|
|
|
|
$arguments = array();
|
|
|
|
}
|
|
|
|
|
2013-04-25 22:01:36 +00:00
|
|
|
$mountpoint = $this->formatPath($mountpoint);
|
2013-01-26 20:42:59 +00:00
|
|
|
if ($storage instanceof \OC\Files\Storage\Storage) {
|
|
|
|
$this->class = get_class($storage);
|
|
|
|
$this->storage = $storage;
|
|
|
|
} else {
|
|
|
|
// Update old classes to new namespace
|
|
|
|
if (strpos($storage, 'OC_Filestorage_') !== false) {
|
|
|
|
$storage = '\OC\Files\Storage\\' . substr($storage, 15);
|
|
|
|
}
|
|
|
|
$this->class = $storage;
|
|
|
|
$this->arguments = $arguments;
|
|
|
|
}
|
|
|
|
$this->mountPoint = $mountpoint;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getMountPoint() {
|
|
|
|
return $this->mountPoint;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-04-25 22:01:36 +00:00
|
|
|
* create the storage that is mounted
|
|
|
|
*
|
2013-01-26 20:42:59 +00:00
|
|
|
* @return \OC\Files\Storage\Storage
|
|
|
|
*/
|
|
|
|
private function createStorage() {
|
|
|
|
if (class_exists($this->class)) {
|
|
|
|
try {
|
2013-05-08 20:35:10 +00:00
|
|
|
return $this->loadStorage($this->class, $this->arguments);
|
2013-01-26 20:42:59 +00:00
|
|
|
} catch (\Exception $exception) {
|
|
|
|
\OC_Log::write('core', $exception->getMessage(), \OC_Log::ERROR);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
\OC_Log::write('core', 'storage backend ' . $this->class . ' not found', \OC_Log::ERROR);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-08 20:35:10 +00:00
|
|
|
/**
|
|
|
|
* allow modifier storage behaviour by adding wrappers around storages
|
|
|
|
*
|
|
|
|
* $callback should be a function of type (string $mountPoint, Storage $storage) => Storage
|
|
|
|
*
|
|
|
|
* @param callable $callback
|
|
|
|
*/
|
|
|
|
public function addStorageWrapper($callback) {
|
|
|
|
$this->storageWrappers[] = $callback;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function loadStorage($class, $arguments) {
|
|
|
|
$storage = new $class($arguments);
|
|
|
|
foreach ($this->storageWrappers as $wrapper) {
|
|
|
|
$storage = $wrapper($this->mountPoint, $storage);
|
|
|
|
}
|
|
|
|
return $storage;
|
|
|
|
}
|
|
|
|
|
2013-01-26 20:42:59 +00:00
|
|
|
/**
|
|
|
|
* @return \OC\Files\Storage\Storage
|
|
|
|
*/
|
|
|
|
public function getStorage() {
|
|
|
|
if (is_null($this->storage)) {
|
|
|
|
$this->storage = $this->createStorage();
|
|
|
|
}
|
|
|
|
return $this->storage;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getStorageId() {
|
|
|
|
if (!$this->storageId) {
|
|
|
|
if (is_null($this->storage)) {
|
2013-03-19 14:02:29 +00:00
|
|
|
$storage = $this->createStorage(); //FIXME: start using exceptions
|
|
|
|
if (is_null($storage)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
$this->storage = $storage;
|
2013-01-26 20:42:59 +00:00
|
|
|
}
|
|
|
|
$this->storageId = $this->storage->getId();
|
2013-02-15 20:49:40 +00:00
|
|
|
if (strlen($this->storageId) > 64) {
|
|
|
|
$this->storageId = md5($this->storageId);
|
|
|
|
}
|
2013-01-26 20:42:59 +00:00
|
|
|
}
|
|
|
|
return $this->storageId;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $path
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getInternalPath($path) {
|
|
|
|
if ($this->mountPoint === $path or $this->mountPoint . '/' === $path) {
|
|
|
|
$internalPath = '';
|
|
|
|
} else {
|
|
|
|
$internalPath = substr($path, strlen($this->mountPoint));
|
|
|
|
}
|
|
|
|
return $internalPath;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $path
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-04-25 22:01:36 +00:00
|
|
|
private function formatPath($path) {
|
2013-01-26 20:42:59 +00:00
|
|
|
$path = Filesystem::normalizePath($path);
|
|
|
|
if (strlen($path) > 1) {
|
|
|
|
$path .= '/';
|
|
|
|
}
|
|
|
|
return $path;
|
|
|
|
}
|
|
|
|
}
|