friendica/include/cache.php

73 lines
1.8 KiB
PHP
Raw Normal View History

2011-10-24 11:02:38 +00:00
<?php
/**
* cache api
*/
2011-10-24 11:02:38 +00:00
class Cache {
public static function get($key) {
$r = q("SELECT `v` FROM `cache` WHERE `k`='%s' limit 1",
2011-10-24 11:02:38 +00:00
dbesc($key)
);
if (dba::is_result($r))
return $r[0]['v'];
2011-10-24 11:02:38 +00:00
return null;
}
public static function set($key,$value, $duration = CACHE_MONTH) {
2012-05-02 23:27:19 +00:00
q("REPLACE INTO `cache` (`k`,`v`,`expire_mode`,`updated`) VALUES ('%s','%s',%d,'%s')",
dbesc($key),
dbesc($value),
intval($duration),
dbesc(datetime_convert()));
2011-10-24 11:02:38 +00:00
}
2012-05-02 23:27:19 +00:00
/*
2012-05-02 23:27:19 +00:00
*
* Leaving this legacy code temporaily to see how REPLACE fares
2012-05-02 23:27:19 +00: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(dba::is_result($r)) {
* q("UPDATE `cache` SET `v` = '%s', `updated = '%s' WHERE `k` = '%s'",
2012-05-02 23:27:19 +00: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()));
* }
* }
*/
2011-10-24 11:02:38 +00:00
public static function clear(){
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 11:02:38 +00:00
}
2011-10-24 11:02:38 +00:00
}