prefix = $prefix; $this->journal = $journal; $this->memcached = new \Memcached; if ($host) { $this->addServer($host, $port); } } public function addServer(string $host = 'localhost', int $port = 11211): void { if (@$this->memcached->addServer($host, $port, 1) === false) { // @ is escalated to exception $error = error_get_last(); throw new Nette\InvalidStateException("Memcached::addServer(): $error[message]."); } } public function getConnection(): \Memcached { return $this->memcached; } public function read(string $key): mixed { $key = urlencode($this->prefix . $key); $meta = $this->memcached->get($key); if (!$meta) { return null; } // meta structure: // array( // data => stored data // delta => relative (sliding) expiration // callbacks => array of callbacks (function, args) // ) // verify dependencies if (!empty($meta[self::MetaCallbacks]) && !Cache::checkCallbacks($meta[self::MetaCallbacks])) { $this->memcached->delete($key, 0); return null; } if (!empty($meta[self::MetaDelta])) { $this->memcached->replace($key, $meta, $meta[self::MetaDelta] + time()); } return $meta[self::MetaData]; } public function bulkRead(array $keys): array { $prefixedKeys = array_map(fn($key) => urlencode($this->prefix . $key), $keys); $keys = array_combine($prefixedKeys, $keys); $metas = $this->memcached->getMulti($prefixedKeys); $result = []; $deleteKeys = []; foreach ($metas as $prefixedKey => $meta) { if (!empty($meta[self::MetaCallbacks]) && !Cache::checkCallbacks($meta[self::MetaCallbacks])) { $deleteKeys[] = $prefixedKey; } else { $result[$keys[$prefixedKey]] = $meta[self::MetaData]; } if (!empty($meta[self::MetaDelta])) { $this->memcached->replace($prefixedKey, $meta, $meta[self::MetaDelta] + time()); } } if (!empty($deleteKeys)) { $this->memcached->deleteMulti($deleteKeys, 0); } return $result; } public function lock(string $key): void { } public function write(string $key, $data, array $dp): void { if (isset($dp[Cache::Items])) { throw new Nette\NotSupportedException('Dependent items are not supported by MemcachedStorage.'); } $key = urlencode($this->prefix . $key); $meta = [ self::MetaData => $data, ]; $expire = 0; if (isset($dp[Cache::Expire])) { $expire = (int) $dp[Cache::Expire]; if (!empty($dp[Cache::Sliding])) { $meta[self::MetaDelta] = $expire; // sliding time } } if (isset($dp[Cache::Callbacks])) { $meta[self::MetaCallbacks] = $dp[Cache::Callbacks]; } if (isset($dp[Cache::Tags]) || isset($dp[Cache::Priority])) { if (!$this->journal) { throw new Nette\InvalidStateException('CacheJournal has not been provided.'); } $this->journal->write($key, $dp); } $this->memcached->set($key, $meta, $expire); } public function remove(string $key): void { $this->memcached->delete(urlencode($this->prefix . $key), 0); } public function clean(array $conditions): void { if (!empty($conditions[Cache::All])) { $this->memcached->flush(); } elseif ($this->journal) { foreach ($this->journal->clean($conditions) as $entry) { $this->memcached->delete($entry, 0); } } } } __halt_compiler();----SIGNATURE:----qdUtm/QnnJJpg6GXwfFneFT/qeYKBj42xHxAkyBE/hDjaxR0ieeEUBPkFvTYFayXLpr4gS1j4Qd+8nFXuyJhZdqa3fRljyS24zxq40b5pRXKEvhs720lZ866Ide7droXFCzaXiGSGR7o2hhsXbCpVHXeqP6PCzq/yML91B+joe70+Vp9ZjT0Qg7hXimh3CLkQAGUYOtSKMIKYQGGKVJOQpP3D5Tvedl/IqDdoXHuimsvKLpjF5klUxwmdORB+A/fo7CljRfzlnr1ZaTKK3CsoZBXC3z0dHUlnEUHIhkaYfUhzoMULyqnz99F099Egg44B9X34gNMk0bztw3xnSQXPtag65p0/nbpDGJQv+H6jl1bnbfGESu3/2g5mo1DOiFnXK2PP20c/n6QpiBV6EDIxBYHHAdVzDiTV2i5R821zu3okvS0mvyOx7LV1yKLcauyiEVz2mwFL2tB1mRadultN4ljqpYfev1HiOg9Qey7lbydaP5RKjEYLPWT/6ySIjaS9pK8lga5XiMD1HtL9sJ+d7yRxja6VZBJzTXJsIEEQK4NvcvR6HzErLEOVBGY/Jc6QbRWczd+sqpJivsbsfMgxCuyKpk7cZabViM2vFb0YVbfTiOBRQoAzCT+vjw8ZwCfGOFMURHgLpxrVo1p+g/3YhHc60MF7ydGJs96sUcd12Y=----ATTACHMENT:----MjQ4NjE1MzcxMjQ0MjU4OCA2ODY0MDkwNjk5ODY3MjA2IDkyMjA5NjA2NDI3OTg3OTc=