2013-07-16 13:34:22 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2013 Robin Appelman <icewind@owncloud.com>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OC\Memcache;
|
|
|
|
|
2014-01-24 15:01:19 +00:00
|
|
|
use \OCP\ICacheFactory;
|
|
|
|
|
|
|
|
class Factory implements ICacheFactory {
|
2014-01-06 12:11:38 +00:00
|
|
|
/**
|
|
|
|
* @var string $globalPrefix
|
|
|
|
*/
|
|
|
|
private $globalPrefix;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $globalPrefix
|
|
|
|
*/
|
|
|
|
public function __construct($globalPrefix) {
|
|
|
|
$this->globalPrefix = $globalPrefix;
|
|
|
|
}
|
|
|
|
|
2013-07-16 13:34:22 +00:00
|
|
|
/**
|
|
|
|
* get a cache instance, will return null if no backend is available
|
|
|
|
*
|
2013-07-16 14:08:37 +00:00
|
|
|
* @param string $prefix
|
2013-07-16 13:34:22 +00:00
|
|
|
* @return \OC\Memcache\Cache
|
|
|
|
*/
|
2013-07-16 14:08:37 +00:00
|
|
|
function create($prefix = '') {
|
2014-01-06 12:11:38 +00:00
|
|
|
$prefix = $this->globalPrefix . '/' . $prefix;
|
2013-07-16 13:34:22 +00:00
|
|
|
if (XCache::isAvailable()) {
|
2013-07-16 14:08:37 +00:00
|
|
|
return new XCache($prefix);
|
2013-07-24 19:50:15 +00:00
|
|
|
} elseif (APCu::isAvailable()) {
|
|
|
|
return new APCu($prefix);
|
2013-07-16 13:34:22 +00:00
|
|
|
} elseif (APC::isAvailable()) {
|
2013-07-16 14:08:37 +00:00
|
|
|
return new APC($prefix);
|
2013-07-16 13:34:22 +00:00
|
|
|
} elseif (Memcached::isAvailable()) {
|
2013-07-16 14:08:37 +00:00
|
|
|
return new Memcached($prefix);
|
2013-07-16 13:34:22 +00:00
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* check if there is a memcache backend available
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isAvailable() {
|
2013-07-24 19:50:15 +00:00
|
|
|
return XCache::isAvailable() || APCu::isAvailable() || APC::isAvailable() || Memcached::isAvailable();
|
2013-07-16 13:34:22 +00:00
|
|
|
}
|
2013-08-17 14:01:37 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* get a in-server cache instance, will return null if no backend is available
|
|
|
|
*
|
|
|
|
* @param string $prefix
|
2014-02-06 15:30:58 +00:00
|
|
|
* @return null|Cache
|
2013-08-17 14:01:37 +00:00
|
|
|
*/
|
|
|
|
public static function createLowLatency($prefix = '') {
|
|
|
|
if (XCache::isAvailable()) {
|
|
|
|
return new XCache($prefix);
|
|
|
|
} elseif (APCu::isAvailable()) {
|
|
|
|
return new APCu($prefix);
|
|
|
|
} elseif (APC::isAvailable()) {
|
|
|
|
return new APC($prefix);
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* check if there is a in-server backend available
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function isAvailableLowLatency() {
|
|
|
|
return XCache::isAvailable() || APCu::isAvailable() || APC::isAvailable();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-07-16 13:34:22 +00:00
|
|
|
}
|