2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2023-01-10 22:44:09 +00:00
|
|
|
|
|
|
|
namespace Shimmie2;
|
|
|
|
|
2023-02-02 16:46:25 +00:00
|
|
|
use Psr\SimpleCache\CacheInterface;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
2023-02-02 16:46:25 +00:00
|
|
|
class EventTracingCache implements CacheInterface
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2023-02-02 16:46:25 +00:00
|
|
|
private CacheInterface $engine;
|
|
|
|
private \EventTracer $tracer;
|
2023-11-11 21:49:12 +00:00
|
|
|
private int $hits = 0;
|
|
|
|
private int $misses = 0;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
2023-02-02 16:46:25 +00:00
|
|
|
public function __construct(CacheInterface $engine, \EventTracer $tracer)
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2023-02-02 16:46:25 +00:00
|
|
|
$this->engine = $engine;
|
|
|
|
$this->tracer = $tracer;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2023-11-11 21:49:12 +00:00
|
|
|
public function get($key, $default = null)
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2023-02-02 16:50:09 +00:00
|
|
|
if ($key === "__etc_cache_hits") {
|
|
|
|
return $this->hits;
|
|
|
|
}
|
|
|
|
if ($key === "__etc_cache_misses") {
|
|
|
|
return $this->misses;
|
|
|
|
}
|
2019-05-26 16:33:26 +01:00
|
|
|
|
2023-02-02 16:52:03 +00:00
|
|
|
$sentinel = "__etc_sentinel";
|
2023-11-11 21:49:12 +00:00
|
|
|
$this->tracer->begin("Cache Get", ["key" => $key]);
|
2023-02-02 16:52:03 +00:00
|
|
|
$val = $this->engine->get($key, $sentinel);
|
|
|
|
if ($val != $sentinel) {
|
2019-09-29 14:30:55 +01:00
|
|
|
$res = "hit";
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->hits++;
|
|
|
|
} else {
|
2019-09-29 14:30:55 +01:00
|
|
|
$res = "miss";
|
2023-02-02 16:52:03 +00:00
|
|
|
$val = $default;
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->misses++;
|
|
|
|
}
|
2023-11-11 21:49:12 +00:00
|
|
|
$this->tracer->end(null, ["result" => $res]);
|
2019-09-29 14:30:55 +01:00
|
|
|
return $val;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2023-02-02 16:46:25 +00:00
|
|
|
public function set($key, $value, $ttl = null)
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2023-11-11 21:49:12 +00:00
|
|
|
$this->tracer->begin("Cache Set", ["key" => $key, "ttl" => $ttl]);
|
2023-02-02 16:46:25 +00:00
|
|
|
$val = $this->engine->set($key, $value, $ttl);
|
|
|
|
$this->tracer->end();
|
|
|
|
return $val;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2023-02-02 16:46:25 +00:00
|
|
|
public function delete($key)
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2023-11-11 21:49:12 +00:00
|
|
|
$this->tracer->begin("Cache Delete", ["key" => $key]);
|
2023-02-02 16:46:25 +00:00
|
|
|
$val = $this->engine->delete($key);
|
|
|
|
$this->tracer->end();
|
|
|
|
return $val;
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|
|
|
|
|
2023-02-02 16:46:25 +00:00
|
|
|
public function clear()
|
2023-02-02 16:04:35 +00:00
|
|
|
{
|
2023-02-02 16:46:25 +00:00
|
|
|
$this->tracer->begin("Cache Clear");
|
|
|
|
$val = $this->engine->clear();
|
|
|
|
$this->tracer->end();
|
|
|
|
return $val;
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param string[] $keys
|
|
|
|
* @param mixed $default
|
2024-01-20 19:47:26 +00:00
|
|
|
* @return iterable<mixed>
|
2024-01-20 14:10:59 +00:00
|
|
|
*/
|
2023-02-02 16:46:25 +00:00
|
|
|
public function getMultiple($keys, $default = null)
|
2023-02-02 16:04:35 +00:00
|
|
|
{
|
2023-02-04 13:43:23 +00:00
|
|
|
$this->tracer->begin("Cache Get Multiple", ["keys" => $keys]);
|
2023-02-03 16:44:16 +00:00
|
|
|
$val = $this->engine->getMultiple($keys, $default);
|
2023-02-02 16:46:25 +00:00
|
|
|
$this->tracer->end();
|
|
|
|
return $val;
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param array<string, mixed> $values
|
|
|
|
*/
|
2023-02-02 16:50:09 +00:00
|
|
|
public function setMultiple($values, $ttl = null)
|
|
|
|
{
|
2023-02-04 13:43:23 +00:00
|
|
|
$this->tracer->begin("Cache Set Multiple", ["keys" => array_keys($values)]);
|
2023-02-02 16:46:25 +00:00
|
|
|
$val = $this->engine->setMultiple($values, $ttl);
|
|
|
|
$this->tracer->end();
|
|
|
|
return $val;
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param string[] $keys
|
|
|
|
*/
|
2023-02-02 16:50:09 +00:00
|
|
|
public function deleteMultiple($keys)
|
|
|
|
{
|
2023-02-04 13:43:23 +00:00
|
|
|
$this->tracer->begin("Cache Delete Multiple", ["keys" => $keys]);
|
2023-02-02 16:46:25 +00:00
|
|
|
$val = $this->engine->deleteMultiple($keys);
|
|
|
|
$this->tracer->end();
|
|
|
|
return $val;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2023-02-02 16:50:09 +00:00
|
|
|
public function has($key)
|
|
|
|
{
|
2023-11-11 21:49:12 +00:00
|
|
|
$this->tracer->begin("Cache Has", ["key" => $key]);
|
2023-02-02 16:46:25 +00:00
|
|
|
$val = $this->engine->has($key);
|
2023-11-11 21:49:12 +00:00
|
|
|
$this->tracer->end(null, ["exists" => $val]);
|
2023-02-02 16:46:25 +00:00
|
|
|
return $val;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2018-11-05 22:30:18 +00:00
|
|
|
}
|
2023-02-02 16:04:35 +00:00
|
|
|
|
2023-02-02 16:50:09 +00:00
|
|
|
function loadCache(?string $dsn): CacheInterface
|
|
|
|
{
|
2023-02-02 16:04:35 +00:00
|
|
|
$c = null;
|
2024-01-07 23:28:15 +00:00
|
|
|
if ($dsn && !isset($_GET['DISABLE_CACHE'])) {
|
|
|
|
$url = parse_url($dsn);
|
|
|
|
if($url) {
|
|
|
|
if ($url['scheme'] == "memcached" || $url['scheme'] == "memcache") {
|
|
|
|
$memcache = new \Memcached();
|
|
|
|
$memcache->addServer($url['host'], $url['port']);
|
|
|
|
$c = new \Sabre\Cache\Memcached($memcache);
|
|
|
|
} elseif ($url['scheme'] == "apc") {
|
|
|
|
$c = new \Sabre\Cache\Apcu();
|
|
|
|
} elseif ($url['scheme'] == "redis") {
|
|
|
|
$redis = new \Predis\Client([
|
|
|
|
'scheme' => 'tcp',
|
2024-01-20 19:47:26 +00:00
|
|
|
'host' => $url['host'] ?? "127.0.0.1",
|
|
|
|
'port' => $url['port'] ?? 6379,
|
|
|
|
'username' => $url['user'] ?? null,
|
|
|
|
'password' => $url['pass'] ?? null,
|
2024-01-07 23:28:15 +00:00
|
|
|
], ['prefix' => 'shm:']);
|
|
|
|
$c = new \Naroga\RedisCache\Redis($redis);
|
|
|
|
}
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|
2023-06-27 15:31:59 +01:00
|
|
|
}
|
|
|
|
if(is_null($c)) {
|
2023-02-02 16:46:25 +00:00
|
|
|
$c = new \Sabre\Cache\Memory();
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|
2023-02-02 16:46:25 +00:00
|
|
|
global $_tracer;
|
|
|
|
return new EventTracingCache($c, $_tracer);
|
2023-02-02 16:04:35 +00:00
|
|
|
}
|