mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-04 00:18:21 +02:00
Summary: Per https://github.com/php-fig/fig-standards/blob/master/proposed/phpdoc.md the valid keyword is `$this`. Thus replace `this` to make output of static code analysis slightly less noisy. (See rARC4b7ee1985b3c15b4af81b5480522ae24c0afd6a2 for its Arcanist counterpart.) Test Plan: Read the docs. Reviewers: O1 Blessed Committers, valerio.bozzolan Reviewed By: O1 Blessed Committers, valerio.bozzolan Subscribers: tobiaswiese, valerio.bozzolan, Matthew, Cigaryno Differential Revision: https://we.phorge.it/D25819
108 lines
2.2 KiB
PHP
108 lines
2.2 KiB
PHP
<?php
|
|
|
|
final class PhutilKeyValueCacheProfiler extends PhutilKeyValueCacheProxy {
|
|
|
|
private $profiler;
|
|
private $name;
|
|
|
|
public function setName($name) {
|
|
$this->name = $name;
|
|
return $this;
|
|
}
|
|
|
|
public function getName() {
|
|
return $this->name;
|
|
}
|
|
|
|
/**
|
|
* Set a profiler for cache operations.
|
|
*
|
|
* @param PhutilServiceProfiler $profiler Service profiler.
|
|
* @return $this
|
|
* @task kvimpl
|
|
*/
|
|
public function setProfiler(PhutilServiceProfiler $profiler) {
|
|
$this->profiler = $profiler;
|
|
return $this;
|
|
}
|
|
|
|
|
|
/**
|
|
* Get the current profiler.
|
|
*
|
|
* @return PhutilServiceProfiler|null Profiler, or null if none is set.
|
|
* @task kvimpl
|
|
*/
|
|
public function getProfiler() {
|
|
return $this->profiler;
|
|
}
|
|
|
|
|
|
public function getKeys(array $keys) {
|
|
$call_id = null;
|
|
if ($this->getProfiler()) {
|
|
$call_id = $this->getProfiler()->beginServiceCall(
|
|
array(
|
|
'type' => 'kvcache-get',
|
|
'name' => $this->getName(),
|
|
'keys' => $keys,
|
|
));
|
|
}
|
|
|
|
$results = parent::getKeys($keys);
|
|
|
|
if ($call_id !== null) {
|
|
$this->getProfiler()->endServiceCall(
|
|
$call_id,
|
|
array(
|
|
'hits' => array_keys($results),
|
|
));
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
|
|
public function setKeys(array $keys, $ttl = null) {
|
|
$call_id = null;
|
|
if ($this->getProfiler()) {
|
|
$call_id = $this->getProfiler()->beginServiceCall(
|
|
array(
|
|
'type' => 'kvcache-set',
|
|
'name' => $this->getName(),
|
|
'keys' => array_keys($keys),
|
|
'ttl' => $ttl,
|
|
));
|
|
}
|
|
|
|
$result = parent::setKeys($keys, $ttl);
|
|
|
|
if ($call_id !== null) {
|
|
$this->getProfiler()->endServiceCall($call_id, array());
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
|
|
public function deleteKeys(array $keys) {
|
|
$call_id = null;
|
|
if ($this->getProfiler()) {
|
|
$call_id = $this->getProfiler()->beginServiceCall(
|
|
array(
|
|
'type' => 'kvcache-del',
|
|
'name' => $this->getName(),
|
|
'keys' => $keys,
|
|
));
|
|
}
|
|
|
|
$result = parent::deleteKeys($keys);
|
|
|
|
if ($call_id !== null) {
|
|
$this->getProfiler()->endServiceCall($call_id, array());
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
}
|