1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-18 05:09:05 +01:00
php-e107/e107_handlers/cache_handler.php
2008-01-16 10:54:33 +00:00

231 lines
7.1 KiB
PHP

<?php
/*
+ ----------------------------------------------------------------------------+
| e107 website system
|
| Steve Dunstan 2001-2002
| http://e107.org
| jalist@e107.org
|
| Released under the terms and conditions of the
| GNU General Public License (http://gnu.org).
|
| $Source: /cvs_backup/e107_0.8/e107_handlers/cache_handler.php,v $
| $Revision: 1.8 $
| $Date: 2008-01-16 10:54:33 $
| $Author: e107coders $
+----------------------------------------------------------------------------+
*/
if (!defined('e107_INIT')) { exit; }
/**
* Class to cache data as files, improving site speed and throughput.
*
* @package e107
* @version $Revision: 1.8 $
* @author $Author: e107coders $
*/
class ecache {
var $CachePageMD5;
var $CachenqMD5;
/**
* @return string
* @param string $query
* @desc Internal class function that returns the filename of a cache file based on the query.
* @scope private
* If the tag begins 'menu_', e_QUERY is not included in the hash which creates the file name
*/
function cache_fname($CacheTag, $syscache = false)
{
global $FILES_DIRECTORY;
if(strpos($CacheTag, "nomd5_") === 0) {
// Add 'nomd5' to indicate we are not calculating an md5
$CheckTag = '_nomd5';
}
elseif (isset($this)) {
if (defined("THEME")) {
if (strpos($CacheTag, "nq_") === 0) {
// We do not care about e_QUERY, so don't use it in the md5 calculation
if (!$this->CachenqMD5) {
$this->CachenqMD5 = md5(e_BASE.(defined("ADMIN") && ADMIN == true ? "admin" : "").e_LANGUAGE.THEME.USERCLASS_LIST.filemtime(THEME.'theme.php'));
}
// Add 'nq' to indicate we are not using e_QUERY
$CheckTag = '_nq_'.$this->CachenqMD5;
} else {
// It's a page - need the query in the hash
if (!$this->CachePageMD5) {
$this->CachePageMD5 = md5(e_BASE.e_LANGUAGE.THEME.USERCLASS_LIST.e_QUERY.filemtime(THEME.'theme.php'));
}
$CheckTag = '_'.$this->CachePageMD5;
}
} else {
// Check if a custom CachePageMD5 is in use in e_module.php.
$CheckTag = ($this->CachePageMD5) ? "_".$this->CachePageMD5 : "";
}
} else {
$CheckTag = '';
}
$q = ($syscache ? "S_" : "C_").preg_replace("#\W#", "_", $CacheTag);
$fname = e_CACHE.$q.$CheckTag.'.cache.php';
//echo "cache f_name = $fname <br />";
return $fname;
}
/**
* @return string
* @param string $query
* @param int $MaximumAge the time in minutes before the cache file 'expires'
* @desc Returns the data from the cache file associated with $query, else it returns false if there is no cache for $query.
* @scope public
*/
function retrieve($CacheTag, $MaximumAge = false, $ForcedCheck = false, $syscache = false) {
global $pref, $tp;
if(($ForcedCheck != false ) || ($syscache == false && varsettrue($pref['cachestatus'])) || ($syscache == true && varsettrue($pref['syscachestatus'])) && !$tp->checkHighlighting())
{
$cache_file = (isset($this) ? $this->cache_fname($CacheTag, $syscache) : ecache::cache_fname($CacheTag, $syscache));
if (file_exists($cache_file)) {
if ($MaximumAge != false && (filemtime($cache_file) + ($MaximumAge * 60)) < time()) {
unlink($cache_file);
return false;
} else {
$ret = file_get_contents($cache_file);
$ret = substr($ret, 5);
return $ret;
}
} else {
return false;
}
}
return false;
}
/**
* @return string
* @param string $query
* @param int $MaximumAge the time in minutes before the cache file 'expires'
* @desc Returns the data from the cache file associated with $query, else it returns false if there is no cache for $query.
* @scope public
*/
function retrieve_sys($CacheTag, $MaximumAge = false, $ForcedCheck = false)
{
if(isset($this))
{
return $this->retrieve($CacheTag, $MaximumAge, $ForcedCheck, true);
}
else
{
return ecache::retrieve($CacheTag, $MaximumAge, $ForcedCheck, true);
}
}
/**
* @return void
* @param string $CacheTag - name of tag for future retrieval
* @param string $Data - data to be cached
* @param bool $ForceCache (optional, default false) - if TRUE, writes cache even when disabled
* @param bool $bRaw (optional, default false) - if TRUE, writes data exactly as provided instead of prefacing with php leadin
* @desc Creates / overwrites the cache file for $query, $text is the data to store for $query.
* @scope public
*/
function set($CacheTag, $Data, $ForceCache = false, $bRaw=0, $syscache = false) {
global $pref, $FILES_DIRECTORY, $tp;
if(($ForceCache != false ) || ($syscache == false && varsettrue($pref['cachestatus'])) || ($syscache == true && varsettrue($pref['syscachestatus'])) && !$tp->checkHighlighting())
{
$cache_file = (isset($this) ? $this->cache_fname($CacheTag, $syscache) : ecache::cache_fname($CacheTag, $syscache));
file_put_contents($cache_file, ($bRaw? $Data : '<?php'.$Data) );
@chmod($cache_file, 0755); //Cache should not be world-writeable
@touch($cache_file);
}
}
/**
* @return void
* @param string $CacheTag - name of tag for future retrieval
* @param string $Data - data to be cached
* @param bool $ForceCache (optional, default false) - if TRUE, writes cache even when disabled
* @param bool $bRaw (optional, default false) - if TRUE, writes data exactly as provided instead of prefacing with php leadin
* @desc Creates / overwrites the cache file for $query, $text is the data to store for $query.
* @scope public
*/
function set_sys($CacheTag, $Data, $ForceCache = false, $bRaw=0)
{
if(isset($this))
{
return $this->set($CacheTag, $Data, $ForceCache, $bRaw, true);
}
else
{
ecache::set($CacheTag, $Data, $ForceCache, $bRaw, true);
}
}
/**
* @return bool
* @param string $CacheTag
* @desc Deletes cache files. If $query is set, deletes files named {$CacheTag}*.cache.php, if not it deletes all cache files - (*.cache.php)
*/
function clear($CacheTag = '', $syscache = false)
{
global $pref;
$file = ($CacheTag) ? preg_replace("#\W#", "_", $CacheTag)."*.cache.php" : "*.cache.php";
$ret = ecache::delete(e_CACHE, $file, $syscache);
return $ret;
}
/**
* @return bool
* @param string $CacheTag
* @desc Deletes cache files. If $query is set, deletes files named {$CacheTag}*.cache.php, if not it deletes all cache files - (*.cache.php)
*/
function clear_sys($CacheTag = '')
{
if(isset($this))
{
return $this->clear($CacheTag, true);
}
else
{
ecache::clear($CacheTag, true);
}
}
/**
* @return bool
* @param string $dir
* @param string $pattern
* @desc Internal class function to allow deletion of cache files using a pattern, default '*.*'
* @scope private
*/
function delete($dir, $pattern = "*.*", $syscache = false) {
$deleted = false;
$pattern = ($syscache ? "S_" : "C_").$pattern;
$pattern = str_replace(array("\*", "\?"), array(".*", "."), preg_quote($pattern));
if (substr($dir, -1) != "/") {
$dir .= "/";
}
if (is_dir($dir))
{
$d = opendir($dir);
while ($file = readdir($d)) {
if (is_file($dir.$file) && preg_match("/^{$pattern}$/", $file)) {
if (unlink($dir.$file)) {
$deleted[] = $file;
}
}
}
closedir($d);
return true;
} else {
return false;
}
}
}
?>