@@ -21,10 +21,10 @@ |
||
| 21 | 21 | |
| 22 | 22 | class Item implements ExtendedCacheItemInterface |
| 23 | 23 | { |
| 24 | - use TaggableCacheItemTrait; |
|
| 24 | + use TaggableCacheItemTrait; |
|
| 25 | 25 | |
| 26 | - protected function getDriverClass(): string |
|
| 27 | - { |
|
| 28 | - return Driver::class; |
|
| 29 | - } |
|
| 26 | + protected function getDriverClass(): string |
|
| 27 | + { |
|
| 28 | + return Driver::class; |
|
| 29 | + } |
|
| 30 | 30 | } |
@@ -21,10 +21,10 @@ |
||
| 21 | 21 | |
| 22 | 22 | class Item implements ExtendedCacheItemInterface |
| 23 | 23 | { |
| 24 | - use TaggableCacheItemTrait; |
|
| 24 | + use TaggableCacheItemTrait; |
|
| 25 | 25 | |
| 26 | - protected function getDriverClass(): string |
|
| 27 | - { |
|
| 28 | - return Driver::class; |
|
| 29 | - } |
|
| 26 | + protected function getDriverClass(): string |
|
| 27 | + { |
|
| 28 | + return Driver::class; |
|
| 29 | + } |
|
| 30 | 30 | } |
@@ -29,92 +29,92 @@ |
||
| 29 | 29 | */ |
| 30 | 30 | class Driver implements AggregatablePoolInterface |
| 31 | 31 | { |
| 32 | - use TaggableCacheItemPoolTrait; |
|
| 33 | - |
|
| 34 | - /** |
|
| 35 | - * @return bool |
|
| 36 | - */ |
|
| 37 | - public function driverCheck(): bool |
|
| 38 | - { |
|
| 39 | - return extension_loaded('Zend Data Cache') && function_exists('zend_disk_cache_store'); |
|
| 40 | - } |
|
| 41 | - |
|
| 42 | - /** |
|
| 43 | - * @return string |
|
| 44 | - */ |
|
| 45 | - public function getHelp(): string |
|
| 46 | - { |
|
| 47 | - return <<<HELP |
|
| 32 | + use TaggableCacheItemPoolTrait; |
|
| 33 | + |
|
| 34 | + /** |
|
| 35 | + * @return bool |
|
| 36 | + */ |
|
| 37 | + public function driverCheck(): bool |
|
| 38 | + { |
|
| 39 | + return extension_loaded('Zend Data Cache') && function_exists('zend_disk_cache_store'); |
|
| 40 | + } |
|
| 41 | + |
|
| 42 | + /** |
|
| 43 | + * @return string |
|
| 44 | + */ |
|
| 45 | + public function getHelp(): string |
|
| 46 | + { |
|
| 47 | + return <<<HELP |
|
| 48 | 48 | <p> |
| 49 | 49 | This driver rely on Zend Server 8.5+, see: https://www.zend.com/products/zend-server |
| 50 | 50 | </p> |
| 51 | 51 | HELP; |
| 52 | - } |
|
| 53 | - |
|
| 54 | - /** |
|
| 55 | - * @return DriverStatistic |
|
| 56 | - */ |
|
| 57 | - public function getStats(): DriverStatistic |
|
| 58 | - { |
|
| 59 | - $stat = new DriverStatistic(); |
|
| 60 | - $stat->setInfo('[ZendDisk] A void info string') |
|
| 61 | - ->setSize(0) |
|
| 62 | - ->setData(implode(', ', array_keys($this->itemInstances))) |
|
| 63 | - ->setRawData(false); |
|
| 64 | - |
|
| 65 | - return $stat; |
|
| 66 | - } |
|
| 67 | - |
|
| 68 | - /** |
|
| 69 | - * @return bool |
|
| 70 | - */ |
|
| 71 | - protected function driverConnect(): bool |
|
| 72 | - { |
|
| 73 | - return true; |
|
| 74 | - } |
|
| 75 | - |
|
| 76 | - /** |
|
| 77 | - * @param ExtendedCacheItemInterface $item |
|
| 78 | - * @return ?array<string, mixed> |
|
| 79 | - */ |
|
| 80 | - protected function driverRead(ExtendedCacheItemInterface $item): ?array |
|
| 81 | - { |
|
| 82 | - $data = zend_disk_cache_fetch($item->getKey()); |
|
| 83 | - |
|
| 84 | - if (empty($data) || !\is_array($data)) { |
|
| 85 | - return null; |
|
| 86 | - } |
|
| 87 | - |
|
| 88 | - return $data; |
|
| 89 | - } |
|
| 90 | - |
|
| 91 | - /** |
|
| 92 | - * @param ExtendedCacheItemInterface $item |
|
| 93 | - * @return mixed |
|
| 94 | - * @throws PhpfastcacheInvalidArgumentException |
|
| 95 | - */ |
|
| 96 | - protected function driverWrite(ExtendedCacheItemInterface $item): bool |
|
| 97 | - { |
|
| 98 | - |
|
| 99 | - $ttl = $item->getExpirationDate()->getTimestamp() - time(); |
|
| 100 | - |
|
| 101 | - return zend_disk_cache_store($item->getKey(), $this->driverPreWrap($item), ($ttl > 0 ? $ttl : 0)); |
|
| 102 | - } |
|
| 103 | - |
|
| 104 | - /** |
|
| 105 | - * @param string $key |
|
| 106 | - * @param string $encodedKey |
|
| 107 | - * @return bool |
|
| 108 | - */ |
|
| 109 | - protected function driverDelete(string $key, string $encodedKey): bool |
|
| 110 | - { |
|
| 111 | - |
|
| 112 | - return (bool)zend_disk_cache_delete($key); |
|
| 113 | - } |
|
| 114 | - |
|
| 115 | - |
|
| 116 | - protected function driverClear(): bool |
|
| 117 | - { |
|
| 118 | - return @zend_disk_cache_clear(); |
|
| 119 | - } |
|
| 52 | + } |
|
| 53 | + |
|
| 54 | + /** |
|
| 55 | + * @return DriverStatistic |
|
| 56 | + */ |
|
| 57 | + public function getStats(): DriverStatistic |
|
| 58 | + { |
|
| 59 | + $stat = new DriverStatistic(); |
|
| 60 | + $stat->setInfo('[ZendDisk] A void info string') |
|
| 61 | + ->setSize(0) |
|
| 62 | + ->setData(implode(', ', array_keys($this->itemInstances))) |
|
| 63 | + ->setRawData(false); |
|
| 64 | + |
|
| 65 | + return $stat; |
|
| 66 | + } |
|
| 67 | + |
|
| 68 | + /** |
|
| 69 | + * @return bool |
|
| 70 | + */ |
|
| 71 | + protected function driverConnect(): bool |
|
| 72 | + { |
|
| 73 | + return true; |
|
| 74 | + } |
|
| 75 | + |
|
| 76 | + /** |
|
| 77 | + * @param ExtendedCacheItemInterface $item |
|
| 78 | + * @return ?array<string, mixed> |
|
| 79 | + */ |
|
| 80 | + protected function driverRead(ExtendedCacheItemInterface $item): ?array |
|
| 81 | + { |
|
| 82 | + $data = zend_disk_cache_fetch($item->getKey()); |
|
| 83 | + |
|
| 84 | + if (empty($data) || !\is_array($data)) { |
|
| 85 | + return null; |
|
| 86 | + } |
|
| 87 | + |
|
| 88 | + return $data; |
|
| 89 | + } |
|
| 90 | + |
|
| 91 | + /** |
|
| 92 | + * @param ExtendedCacheItemInterface $item |
|
| 93 | + * @return mixed |
|
| 94 | + * @throws PhpfastcacheInvalidArgumentException |
|
| 95 | + */ |
|
| 96 | + protected function driverWrite(ExtendedCacheItemInterface $item): bool |
|
| 97 | + { |
|
| 98 | + |
|
| 99 | + $ttl = $item->getExpirationDate()->getTimestamp() - time(); |
|
| 100 | + |
|
| 101 | + return zend_disk_cache_store($item->getKey(), $this->driverPreWrap($item), ($ttl > 0 ? $ttl : 0)); |
|
| 102 | + } |
|
| 103 | + |
|
| 104 | + /** |
|
| 105 | + * @param string $key |
|
| 106 | + * @param string $encodedKey |
|
| 107 | + * @return bool |
|
| 108 | + */ |
|
| 109 | + protected function driverDelete(string $key, string $encodedKey): bool |
|
| 110 | + { |
|
| 111 | + |
|
| 112 | + return (bool)zend_disk_cache_delete($key); |
|
| 113 | + } |
|
| 114 | + |
|
| 115 | + |
|
| 116 | + protected function driverClear(): bool |
|
| 117 | + { |
|
| 118 | + return @zend_disk_cache_clear(); |
|
| 119 | + } |
|
| 120 | 120 | } |
@@ -109,7 +109,7 @@ |
||
| 109 | 109 | protected function driverDelete(string $key, string $encodedKey): bool |
| 110 | 110 | { |
| 111 | 111 | |
| 112 | - return (bool)zend_disk_cache_delete($key); |
|
| 112 | + return (bool) zend_disk_cache_delete($key); |
|
| 113 | 113 | } |
| 114 | 114 | |
| 115 | 115 | |
@@ -21,10 +21,10 @@ |
||
| 21 | 21 | |
| 22 | 22 | class Item implements ExtendedCacheItemInterface |
| 23 | 23 | { |
| 24 | - use TaggableCacheItemTrait; |
|
| 24 | + use TaggableCacheItemTrait; |
|
| 25 | 25 | |
| 26 | - protected function getDriverClass(): string |
|
| 27 | - { |
|
| 28 | - return Driver::class; |
|
| 29 | - } |
|
| 26 | + protected function getDriverClass(): string |
|
| 27 | + { |
|
| 28 | + return Driver::class; |
|
| 29 | + } |
|
| 30 | 30 | } |
@@ -25,9 +25,9 @@ |
||
| 25 | 25 | */ |
| 26 | 26 | class Item extends \Phpfastcache\Drivers\Memory\Item |
| 27 | 27 | { |
| 28 | - public function __construct(ExtendedCacheItemPoolInterface $driver, string $key, EventManagerInterface $em) |
|
| 29 | - { |
|
| 30 | - trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
|
| 31 | - parent::__construct($driver, $key, $em); |
|
| 32 | - } |
|
| 28 | + public function __construct(ExtendedCacheItemPoolInterface $driver, string $key, EventManagerInterface $em) |
|
| 29 | + { |
|
| 30 | + trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
|
| 31 | + parent::__construct($driver, $key, $em); |
|
| 32 | + } |
|
| 33 | 33 | } |
@@ -25,8 +25,7 @@ |
||
| 25 | 25 | */ |
| 26 | 26 | class Item extends \Phpfastcache\Drivers\Memory\Item |
| 27 | 27 | { |
| 28 | - public function __construct(ExtendedCacheItemPoolInterface $driver, string $key, EventManagerInterface $em) |
|
| 29 | - { |
|
| 28 | + public function __construct(ExtendedCacheItemPoolInterface $driver, string $key, EventManagerInterface $em) { |
|
| 30 | 29 | trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
| 31 | 30 | parent::__construct($driver, $key, $em); |
| 32 | 31 | } |
@@ -25,9 +25,9 @@ |
||
| 25 | 25 | */ |
| 26 | 26 | class Driver extends \Phpfastcache\Drivers\Memory\Driver |
| 27 | 27 | { |
| 28 | - public function __construct(#[\SensitiveParameter] ConfigurationOptionInterface $config, string $instanceId, EventManagerInterface $em) |
|
| 29 | - { |
|
| 30 | - trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
|
| 31 | - parent::__construct($config, $instanceId, $em); |
|
| 32 | - } |
|
| 28 | + public function __construct(#[\SensitiveParameter] ConfigurationOptionInterface $config, string $instanceId, EventManagerInterface $em) |
|
| 29 | + { |
|
| 30 | + trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
|
| 31 | + parent::__construct($config, $instanceId, $em); |
|
| 32 | + } |
|
| 33 | 33 | } |
@@ -25,8 +25,7 @@ |
||
| 25 | 25 | */ |
| 26 | 26 | class Driver extends \Phpfastcache\Drivers\Memory\Driver |
| 27 | 27 | { |
| 28 | - public function __construct(#[\SensitiveParameter] ConfigurationOptionInterface $config, string $instanceId, EventManagerInterface $em) |
|
| 29 | - { |
|
| 28 | + public function __construct(#[\SensitiveParameter] ConfigurationOptionInterface $config, string $instanceId, EventManagerInterface $em) { |
|
| 30 | 29 | trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
| 31 | 30 | parent::__construct($config, $instanceId, $em); |
| 32 | 31 | } |
@@ -22,9 +22,9 @@ |
||
| 22 | 22 | */ |
| 23 | 23 | class Config extends \Phpfastcache\Drivers\Memory\Config |
| 24 | 24 | { |
| 25 | - public function __construct(array $parameters = []) |
|
| 26 | - { |
|
| 27 | - trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
|
| 28 | - parent::__construct($parameters); |
|
| 29 | - } |
|
| 25 | + public function __construct(array $parameters = []) |
|
| 26 | + { |
|
| 27 | + trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
|
| 28 | + parent::__construct($parameters); |
|
| 29 | + } |
|
| 30 | 30 | } |
@@ -22,8 +22,7 @@ |
||
| 22 | 22 | */ |
| 23 | 23 | class Config extends \Phpfastcache\Drivers\Memory\Config |
| 24 | 24 | { |
| 25 | - public function __construct(array $parameters = []) |
|
| 26 | - { |
|
| 25 | + public function __construct(array $parameters = []) { |
|
| 27 | 26 | trigger_error('Memstatic driver has changed its name, it is now called "Memory"', E_USER_DEPRECATED); |
| 28 | 27 | parent::__construct($parameters); |
| 29 | 28 | } |
@@ -21,10 +21,10 @@ |
||
| 21 | 21 | |
| 22 | 22 | class Item implements ExtendedCacheItemInterface |
| 23 | 23 | { |
| 24 | - use TaggableCacheItemTrait; |
|
| 24 | + use TaggableCacheItemTrait; |
|
| 25 | 25 | |
| 26 | - protected function getDriverClass(): string |
|
| 27 | - { |
|
| 28 | - return Driver::class; |
|
| 29 | - } |
|
| 26 | + protected function getDriverClass(): string |
|
| 27 | + { |
|
| 28 | + return Driver::class; |
|
| 29 | + } |
|
| 30 | 30 | } |
@@ -31,123 +31,123 @@ |
||
| 31 | 31 | */ |
| 32 | 32 | class Driver implements AggregatablePoolInterface |
| 33 | 33 | { |
| 34 | - use RedisDriverTrait, TaggableCacheItemPoolTrait { |
|
| 35 | - RedisDriverTrait::driverReadMultiple insteadof TaggableCacheItemPoolTrait; |
|
| 36 | - RedisDriverTrait::driverDeleteMultiple insteadof TaggableCacheItemPoolTrait; |
|
| 37 | - } |
|
| 38 | - |
|
| 39 | - /** |
|
| 40 | - * @return bool |
|
| 41 | - */ |
|
| 42 | - public function driverCheck(): bool |
|
| 43 | - { |
|
| 44 | - return extension_loaded('Redis') && class_exists(RedisCluster::class); |
|
| 45 | - } |
|
| 46 | - |
|
| 47 | - /** |
|
| 48 | - * @return DriverStatistic |
|
| 49 | - */ |
|
| 50 | - public function getStats(): DriverStatistic |
|
| 51 | - { |
|
| 52 | - $masters = $this->instance->_masters(); |
|
| 53 | - $infos = array_map(fn($cluster) => $this->instance->info($cluster), $masters); |
|
| 54 | - $date = (new DateTime())->setTimestamp(time() - min(array_column($infos, 'uptime_in_seconds'))); |
|
| 55 | - |
|
| 56 | - return (new DriverStatistic()) |
|
| 57 | - ->setData(implode(', ', array_keys($this->itemInstances))) |
|
| 58 | - ->setRawData($infos) |
|
| 59 | - ->setSize(array_sum(array_column($infos, 'used_memory_dataset'))) |
|
| 60 | - ->setInfo( |
|
| 61 | - sprintf( |
|
| 62 | - trim(<<<EOF |
|
| 34 | + use RedisDriverTrait, TaggableCacheItemPoolTrait { |
|
| 35 | + RedisDriverTrait::driverReadMultiple insteadof TaggableCacheItemPoolTrait; |
|
| 36 | + RedisDriverTrait::driverDeleteMultiple insteadof TaggableCacheItemPoolTrait; |
|
| 37 | + } |
|
| 38 | + |
|
| 39 | + /** |
|
| 40 | + * @return bool |
|
| 41 | + */ |
|
| 42 | + public function driverCheck(): bool |
|
| 43 | + { |
|
| 44 | + return extension_loaded('Redis') && class_exists(RedisCluster::class); |
|
| 45 | + } |
|
| 46 | + |
|
| 47 | + /** |
|
| 48 | + * @return DriverStatistic |
|
| 49 | + */ |
|
| 50 | + public function getStats(): DriverStatistic |
|
| 51 | + { |
|
| 52 | + $masters = $this->instance->_masters(); |
|
| 53 | + $infos = array_map(fn($cluster) => $this->instance->info($cluster), $masters); |
|
| 54 | + $date = (new DateTime())->setTimestamp(time() - min(array_column($infos, 'uptime_in_seconds'))); |
|
| 55 | + |
|
| 56 | + return (new DriverStatistic()) |
|
| 57 | + ->setData(implode(', ', array_keys($this->itemInstances))) |
|
| 58 | + ->setRawData($infos) |
|
| 59 | + ->setSize(array_sum(array_column($infos, 'used_memory_dataset'))) |
|
| 60 | + ->setInfo( |
|
| 61 | + sprintf( |
|
| 62 | + trim(<<<EOF |
|
| 63 | 63 | Redis Cluster version v%s, php-ext v%s with %d master nodes and %d slaves connected are up since %s. |
| 64 | 64 | For more information see RawData. |
| 65 | 65 | EOF), |
| 66 | - implode(', ', array_unique(array_column($infos, 'redis_version'))), |
|
| 67 | - \phpversion("redis"), |
|
| 68 | - count($masters), |
|
| 69 | - array_sum(array_column($infos, 'connected_slaves')), |
|
| 70 | - $date->format(DATE_RFC2822) |
|
| 71 | - ) |
|
| 72 | - ); |
|
| 73 | - } |
|
| 74 | - |
|
| 75 | - /** |
|
| 76 | - * @return bool |
|
| 77 | - * @throws PhpfastcacheLogicException |
|
| 78 | - */ |
|
| 79 | - protected function driverConnect(): bool |
|
| 80 | - { |
|
| 81 | - if (isset($this->instance) && $this->instance instanceof RedisCluster) { |
|
| 82 | - throw new PhpfastcacheLogicException('Already connected to Redis server'); |
|
| 83 | - } |
|
| 84 | - |
|
| 85 | - /** |
|
| 86 | - * In case of a user-provided |
|
| 87 | - * Redis client just return here |
|
| 88 | - */ |
|
| 89 | - if ($this->getConfig()->getRedisClusterClient() instanceof RedisCluster) { |
|
| 90 | - /** |
|
| 91 | - * Unlike Predis, we can't test if we're connected |
|
| 92 | - * or not, so let's just assume that we are |
|
| 93 | - */ |
|
| 94 | - $this->instance = $this->getConfig()->getRedisClusterClient(); |
|
| 95 | - return true; |
|
| 96 | - } |
|
| 97 | - |
|
| 98 | - $this->instance = $this->instance ?? new RedisCluster( |
|
| 99 | - null, |
|
| 100 | - $this->getConfig()->getClusters(), |
|
| 101 | - $this->getConfig()->getTimeout(), |
|
| 102 | - $this->getConfig()->getReadTimeout(), |
|
| 103 | - true, |
|
| 104 | - $this->getConfig()->getPassword() |
|
| 105 | - ); |
|
| 106 | - |
|
| 107 | - $this->instance->setOption(RedisCluster::OPT_SCAN, RedisCluster::SCAN_RETRY); |
|
| 108 | - |
|
| 109 | - if ($this->getConfig()->getOptPrefix()) { |
|
| 110 | - $this->instance->setOption(RedisCluster::OPT_PREFIX, $this->getConfig()->getOptPrefix()); |
|
| 111 | - } |
|
| 112 | - |
|
| 113 | - if ($this->getConfig()->getSlaveFailover()) { |
|
| 114 | - $this->instance->setOption(RedisCluster::OPT_SLAVE_FAILOVER, $this->getConfig()->getSlaveFailover()); |
|
| 115 | - } |
|
| 116 | - |
|
| 117 | - |
|
| 118 | - return true; |
|
| 119 | - } |
|
| 120 | - |
|
| 121 | - /** |
|
| 122 | - * @return array<int, string> |
|
| 123 | - */ |
|
| 124 | - protected function driverReadAllKeys(string $pattern = '*'): iterable |
|
| 125 | - { |
|
| 126 | - $keys = [[]]; |
|
| 127 | - foreach ($this->instance->_masters() as $master) { |
|
| 128 | - $i = -1; |
|
| 129 | - $result = $this->instance->scan( |
|
| 130 | - $i, |
|
| 131 | - $master, |
|
| 132 | - $pattern === '' ? '*' : $pattern, |
|
| 133 | - ExtendedCacheItemPoolInterface::MAX_ALL_KEYS_COUNT |
|
| 134 | - ); |
|
| 135 | - if (is_array($result)) { |
|
| 136 | - $keys[] = $result; |
|
| 137 | - } |
|
| 138 | - } |
|
| 139 | - |
|
| 140 | - return array_unique(array_merge(...$keys)); |
|
| 141 | - } |
|
| 142 | - |
|
| 143 | - /** |
|
| 144 | - * @return bool |
|
| 145 | - */ |
|
| 146 | - protected function driverClear(): bool |
|
| 147 | - { |
|
| 148 | - foreach ($this->instance->_masters() as $nodeMaster) { |
|
| 149 | - $this->instance->flushDb($nodeMaster); |
|
| 150 | - } |
|
| 151 | - return true; |
|
| 152 | - } |
|
| 66 | + implode(', ', array_unique(array_column($infos, 'redis_version'))), |
|
| 67 | + \phpversion("redis"), |
|
| 68 | + count($masters), |
|
| 69 | + array_sum(array_column($infos, 'connected_slaves')), |
|
| 70 | + $date->format(DATE_RFC2822) |
|
| 71 | + ) |
|
| 72 | + ); |
|
| 73 | + } |
|
| 74 | + |
|
| 75 | + /** |
|
| 76 | + * @return bool |
|
| 77 | + * @throws PhpfastcacheLogicException |
|
| 78 | + */ |
|
| 79 | + protected function driverConnect(): bool |
|
| 80 | + { |
|
| 81 | + if (isset($this->instance) && $this->instance instanceof RedisCluster) { |
|
| 82 | + throw new PhpfastcacheLogicException('Already connected to Redis server'); |
|
| 83 | + } |
|
| 84 | + |
|
| 85 | + /** |
|
| 86 | + * In case of a user-provided |
|
| 87 | + * Redis client just return here |
|
| 88 | + */ |
|
| 89 | + if ($this->getConfig()->getRedisClusterClient() instanceof RedisCluster) { |
|
| 90 | + /** |
|
| 91 | + * Unlike Predis, we can't test if we're connected |
|
| 92 | + * or not, so let's just assume that we are |
|
| 93 | + */ |
|
| 94 | + $this->instance = $this->getConfig()->getRedisClusterClient(); |
|
| 95 | + return true; |
|
| 96 | + } |
|
| 97 | + |
|
| 98 | + $this->instance = $this->instance ?? new RedisCluster( |
|
| 99 | + null, |
|
| 100 | + $this->getConfig()->getClusters(), |
|
| 101 | + $this->getConfig()->getTimeout(), |
|
| 102 | + $this->getConfig()->getReadTimeout(), |
|
| 103 | + true, |
|
| 104 | + $this->getConfig()->getPassword() |
|
| 105 | + ); |
|
| 106 | + |
|
| 107 | + $this->instance->setOption(RedisCluster::OPT_SCAN, RedisCluster::SCAN_RETRY); |
|
| 108 | + |
|
| 109 | + if ($this->getConfig()->getOptPrefix()) { |
|
| 110 | + $this->instance->setOption(RedisCluster::OPT_PREFIX, $this->getConfig()->getOptPrefix()); |
|
| 111 | + } |
|
| 112 | + |
|
| 113 | + if ($this->getConfig()->getSlaveFailover()) { |
|
| 114 | + $this->instance->setOption(RedisCluster::OPT_SLAVE_FAILOVER, $this->getConfig()->getSlaveFailover()); |
|
| 115 | + } |
|
| 116 | + |
|
| 117 | + |
|
| 118 | + return true; |
|
| 119 | + } |
|
| 120 | + |
|
| 121 | + /** |
|
| 122 | + * @return array<int, string> |
|
| 123 | + */ |
|
| 124 | + protected function driverReadAllKeys(string $pattern = '*'): iterable |
|
| 125 | + { |
|
| 126 | + $keys = [[]]; |
|
| 127 | + foreach ($this->instance->_masters() as $master) { |
|
| 128 | + $i = -1; |
|
| 129 | + $result = $this->instance->scan( |
|
| 130 | + $i, |
|
| 131 | + $master, |
|
| 132 | + $pattern === '' ? '*' : $pattern, |
|
| 133 | + ExtendedCacheItemPoolInterface::MAX_ALL_KEYS_COUNT |
|
| 134 | + ); |
|
| 135 | + if (is_array($result)) { |
|
| 136 | + $keys[] = $result; |
|
| 137 | + } |
|
| 138 | + } |
|
| 139 | + |
|
| 140 | + return array_unique(array_merge(...$keys)); |
|
| 141 | + } |
|
| 142 | + |
|
| 143 | + /** |
|
| 144 | + * @return bool |
|
| 145 | + */ |
|
| 146 | + protected function driverClear(): bool |
|
| 147 | + { |
|
| 148 | + foreach ($this->instance->_masters() as $nodeMaster) { |
|
| 149 | + $this->instance->flushDb($nodeMaster); |
|
| 150 | + } |
|
| 151 | + return true; |
|
| 152 | + } |
|
| 153 | 153 | } |