2011-10-24 13:02:38 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* cache api
|
|
|
|
*/
|
2014-02-23 15:51:57 +01:00
|
|
|
|
2011-10-24 13:02:38 +02:00
|
|
|
class Cache {
|
2014-02-23 15:51:57 +01:00
|
|
|
public static function get($key) {
|
|
|
|
|
2012-01-25 02:04:49 +01:00
|
|
|
$r = q("SELECT `v` FROM `cache` WHERE `k`='%s' limit 1",
|
2011-10-24 13:02:38 +02:00
|
|
|
dbesc($key)
|
|
|
|
);
|
2014-02-23 15:51:57 +01:00
|
|
|
|
2015-08-24 17:24:14 +02:00
|
|
|
if (count($r))
|
2014-02-23 15:51:57 +01:00
|
|
|
return $r[0]['v'];
|
2015-08-24 17:24:14 +02:00
|
|
|
|
2011-10-24 13:02:38 +02:00
|
|
|
return null;
|
|
|
|
}
|
2014-02-23 15:51:57 +01:00
|
|
|
|
2015-08-24 17:24:14 +02:00
|
|
|
public static function set($key,$value, $duration = CACHE_MONTH) {
|
2012-05-03 01:27:19 +02:00
|
|
|
|
2015-08-24 17:24:14 +02:00
|
|
|
q("REPLACE INTO `cache` (`k`,`v`,`expire_mode`,`updated`) VALUES ('%s','%s',%d,'%s')",
|
2012-01-25 02:04:49 +01:00
|
|
|
dbesc($key),
|
|
|
|
dbesc($value),
|
2015-08-24 17:24:14 +02:00
|
|
|
intval($duration),
|
2012-01-25 02:04:49 +01:00
|
|
|
dbesc(datetime_convert()));
|
2014-02-23 15:51:57 +01:00
|
|
|
|
2011-10-24 13:02:38 +02:00
|
|
|
}
|
2012-05-03 01:27:19 +02:00
|
|
|
|
2014-02-23 15:51:57 +01:00
|
|
|
|
|
|
|
/*
|
2012-05-03 01:27:19 +02:00
|
|
|
*
|
2014-02-23 15:51:57 +01:00
|
|
|
* Leaving this legacy code temporaily to see how REPLACE fares
|
2012-05-03 01:27:19 +02:00
|
|
|
* as opposed to non-atomic checks when faced with fast moving key duplication.
|
|
|
|
* As a MySQL extension it isn't portable, but we're not yet very portable.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* $r = q("SELECT * FROM `cache` WHERE `k`='%s' limit 1",
|
|
|
|
* dbesc($key)
|
|
|
|
* );
|
|
|
|
* if(count($r)) {
|
2014-03-11 23:52:32 +01:00
|
|
|
* q("UPDATE `cache` SET `v` = '%s', `updated = '%s' WHERE `k` = '%s'",
|
2012-05-03 01:27:19 +02:00
|
|
|
* dbesc($value),
|
|
|
|
* dbesc(datetime_convert()),
|
|
|
|
* dbesc($key));
|
|
|
|
* }
|
|
|
|
* else {
|
|
|
|
* q("INSERT INTO `cache` (`k`,`v`,`updated`) VALUES ('%s','%s','%s')",
|
|
|
|
* dbesc($key),
|
|
|
|
* dbesc($value),
|
|
|
|
* dbesc(datetime_convert()));
|
|
|
|
* }
|
|
|
|
* }
|
|
|
|
*/
|
|
|
|
|
2014-02-23 15:51:57 +01:00
|
|
|
|
2011-10-24 13:02:38 +02:00
|
|
|
public static function clear(){
|
2015-08-24 17:24:14 +02:00
|
|
|
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
|
|
|
|
dbesc(datetime_convert('UTC','UTC',"now - 30 days")), intval(CACHE_MONTH));
|
|
|
|
|
|
|
|
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
|
|
|
|
dbesc(datetime_convert('UTC','UTC',"now - 7 days")), intval(CACHE_WEEK));
|
|
|
|
|
|
|
|
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
|
|
|
|
dbesc(datetime_convert('UTC','UTC',"now - 1 days")), intval(CACHE_DAY));
|
|
|
|
|
|
|
|
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
|
|
|
|
dbesc(datetime_convert('UTC','UTC',"now - 1 hours")), intval(CACHE_HOUR));
|
2011-10-24 13:02:38 +02:00
|
|
|
}
|
2014-02-23 15:51:57 +01:00
|
|
|
|
2011-10-24 13:02:38 +02:00
|
|
|
}
|
2014-02-23 15:51:57 +01:00
|
|
|
|