X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FCore%2FCache%2FMemcachedCache.php;h=d8fcbc770d428e1e68126f11e3493d9b82c2d23a;hb=ee8689cc899beecaf0943ac175550a7fb49cf199;hp=f841cae2cee94a70d52254d2fb0bd3f70f418369;hpb=86bf2ee45a7c7409dbc470b5b1706b19e7e40507;p=friendica.git diff --git a/src/Core/Cache/MemcachedCache.php b/src/Core/Cache/MemcachedCache.php index f841cae2ce..d8fcbc770d 100644 --- a/src/Core/Cache/MemcachedCache.php +++ b/src/Core/Cache/MemcachedCache.php @@ -1,22 +1,40 @@ . + * + */ namespace Friendica\Core\Cache; use Exception; -use Friendica\Core\Cache; -use Friendica\Core\Config\Configuration; +use Friendica\Core\BaseCache; +use Friendica\Core\Config\IConfig; use Memcached; use Psr\Log\LoggerInterface; /** * Memcached Cache - * - * @author Hypolite Petovan */ -class MemcachedCache extends AbstractCache implements IMemoryCache +class MemcachedCache extends BaseCache implements IMemoryCache { use TraitCompareSet; use TraitCompareDelete; + use TraitMemcacheCommand; /** * @var \Memcached @@ -36,9 +54,10 @@ class MemcachedCache extends AbstractCache implements IMemoryCache * } * * @param array $memcached_hosts + * * @throws \Exception */ - public function __construct(string $hostname, Configuration $config, LoggerInterface $logger) + public function __construct(string $hostname, IConfig $config, LoggerInterface $logger) { if (!class_exists('Memcached', false)) { throw new Exception('Memcached class isn\'t available'); @@ -58,6 +77,9 @@ class MemcachedCache extends AbstractCache implements IMemoryCache } }); + $this->server = $memcached_hosts[0][0] ?? 'localhost'; + $this->port = $memcached_hosts[0][1] ?? 11211; + $this->memcached->addServers($memcached_hosts); if (count($this->memcached->getServerList()) == 0) { @@ -70,14 +92,9 @@ class MemcachedCache extends AbstractCache implements IMemoryCache */ public function getAllKeys($prefix = null) { - $keys = $this->getOriginalKeys($this->memcached->getAllKeys()); + $keys = $this->getOriginalKeys($this->getMemcacheKeys()); - if ($this->memcached->getResultCode() == Memcached::RES_SUCCESS) { - return $this->filterArrayKeysByPrefix($keys, $prefix); - } else { - $this->logger->debug('Memcached \'getAllKeys\' failed', ['result' => $this->memcached->getResultMessage()]); - return []; - } + return $this->filterArrayKeysByPrefix($keys, $prefix); } /** @@ -85,7 +102,7 @@ class MemcachedCache extends AbstractCache implements IMemoryCache */ public function get($key) { - $return = null; + $return = null; $cachekey = $this->getCacheKey($key); // We fetch with the hostname as key to avoid problems with other applications @@ -94,7 +111,7 @@ class MemcachedCache extends AbstractCache implements IMemoryCache if ($this->memcached->getResultCode() === Memcached::RES_SUCCESS) { $return = $value; } else { - $this->logger->debug('Memcached \'get\' failed', ['result' => $this->memcached->getResultMessage()]); + $this->logger->debug('Memcached \'get\' failed', ['result' => $this->memcached->getResultMessage()]); } return $return; @@ -103,7 +120,7 @@ class MemcachedCache extends AbstractCache implements IMemoryCache /** * (@inheritdoc) */ - public function set($key, $value, $ttl = Cache::FIVE_MINUTES) + public function set($key, $value, $ttl = Duration::FIVE_MINUTES) { $cachekey = $this->getCacheKey($key); @@ -146,9 +163,17 @@ class MemcachedCache extends AbstractCache implements IMemoryCache /** * (@inheritdoc) */ - public function add($key, $value, $ttl = Cache::FIVE_MINUTES) + public function add($key, $value, $ttl = Duration::FIVE_MINUTES) { $cachekey = $this->getCacheKey($key); return $this->memcached->add($cachekey, $value, $ttl); } + + /** + * {@inheritDoc} + */ + public function getName() + { + return Type::MEMCACHED; + } }