diff options
Diffstat (limited to 'phpBB/phpbb/cache/driver/memory.php')
| -rw-r--r-- | phpBB/phpbb/cache/driver/memory.php | 222 | 
1 files changed, 35 insertions, 187 deletions
| diff --git a/phpBB/phpbb/cache/driver/memory.php b/phpBB/phpbb/cache/driver/memory.php index 292024212b..baae22d809 100644 --- a/phpBB/phpbb/cache/driver/memory.php +++ b/phpBB/phpbb/cache/driver/memory.php @@ -1,9 +1,13 @@  <?php  /**  * -* @package acm -* @copyright (c) 2005 phpBB Group -* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* This file is part of the phpBB Forum Software package. +* +* @copyright (c) phpBB Limited <https://www.phpbb.com> +* @license GNU General Public License, version 2 (GPL-2.0) +* +* For full copyright and license information, please see +* the docs/CREDITS.txt file.  *  */ @@ -11,19 +15,11 @@ namespace phpbb\cache\driver;  /**  * ACM Abstract Memory Class -* @package acm  */  abstract class memory extends \phpbb\cache\driver\base  {  	var $key_prefix; -	var $vars = array(); -	var $is_modified = false; - -	var $sql_rowset = array(); -	var $sql_row_pointer = array(); -	var $cache_dir = ''; -  	/**  	* Set cache path  	*/ @@ -50,7 +46,7 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Load global cache +	* {@inheritDoc}  	*/  	function load()  	{ @@ -66,22 +62,7 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Unload cache object -	*/ -	function unload() -	{ -		$this->save(); -		unset($this->vars); -		unset($this->sql_rowset); -		unset($this->sql_row_pointer); - -		$this->vars = array(); -		$this->sql_rowset = array(); -		$this->sql_row_pointer = array(); -	} - -	/** -	* Save modified objects +	* {@inheritDoc}  	*/  	function save()  	{ @@ -96,17 +77,18 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Tidy cache +	* {@inheritDoc}  	*/  	function tidy()  	{ -		// cache has auto GC, no need to have any code here :) +		global $config; -		set_config('cache_last_gc', time(), true); +		// cache has auto GC, no need to have any code here :) +		$config->set('cache_last_gc', time(), false);  	}  	/** -	* Get saved cache object +	* {@inheritDoc}  	*/  	function get($var_name)  	{ @@ -126,7 +108,7 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Put data into cache +	* {@inheritDoc}  	*/  	function put($var_name, $var, $ttl = 2592000)  	{ @@ -142,48 +124,7 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Purge cache data -	*/ -	function purge() -	{ -		// Purge all phpbb cache files -		$dir = @opendir($this->cache_dir); - -		if (!$dir) -		{ -			return; -		} - -		while (($entry = readdir($dir)) !== false) -		{ -			if (strpos($entry, 'container_') !== 0 && -				strpos($entry, 'url_matcher') !== 0 && -				strpos($entry, 'sql_') !== 0 && -				strpos($entry, 'data_') !== 0 && -				strpos($entry, 'ctpl_') !== 0 && -				strpos($entry, 'tpl_') !== 0) -			{ -				continue; -			} - -			$this->remove_file($this->cache_dir . $entry); -		} -		closedir($dir); - -		unset($this->vars); -		unset($this->sql_rowset); -		unset($this->sql_row_pointer); - -		$this->vars = array(); -		$this->sql_rowset = array(); -		$this->sql_row_pointer = array(); - -		$this->is_modified = false; -	} - - -	/** -	* Destroy cache data +	* {@inheritDoc}  	*/  	function destroy($var_name, $table = '')  	{ @@ -237,7 +178,7 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Check if a given cache entry exist +	* {@inheritDoc}  	*/  	function _exists($var_name)  	{ @@ -257,43 +198,35 @@ abstract class memory extends \phpbb\cache\driver\base  	}  	/** -	* Load cached sql query -	*/ -	function sql_load($query) -	{ -		// Remove extra spaces and tabs -		$query = preg_replace('/[\n\r\s\t]+/', ' ', $query); -		$query_id = sizeof($this->sql_rowset); - -		if (($result = $this->_read('sql_' . md5($query))) === false) -		{ -			return false; -		} - -		$this->sql_rowset[$query_id] = $result; -		$this->sql_row_pointer[$query_id] = 0; - -		return $query_id; -	} - -	/**  	* {@inheritDoc}  	*/ -	function sql_save(\phpbb\db\driver\driver $db, $query, $query_result, $ttl) +	function sql_save(\phpbb\db\driver\driver_interface $db, $query, $query_result, $ttl)  	{  		// Remove extra spaces and tabs  		$query = preg_replace('/[\n\r\s\t]+/', ' ', $query); -		$hash = md5($query); +		$query_id = md5($query);  		// determine which tables this query belongs to  		// Some queries use backticks, namely the get_database_size() query  		// don't check for conformity, the SQL would error and not reach here. -		if (!preg_match('/FROM \\(?(`?\\w+`?(?: \\w+)?(?:, ?`?\\w+`?(?: \\w+)?)*)\\)?/', $query, $regs)) +		if (!preg_match_all('/(?:FROM \\(?(`?\\w+`?(?: \\w+)?(?:, ?`?\\w+`?(?: \\w+)?)*)\\)?)|(?:JOIN (`?\\w+`?(?: \\w+)?))/', $query, $regs, PREG_SET_ORDER))  		{  			// Bail out if the match fails.  			return $query_result;  		} -		$tables = array_map('trim', explode(',', $regs[1])); + +		$tables = array(); +		foreach ($regs as $match) +		{ +			if ($match[0][0] == 'F') +			{ +				$tables = array_merge($tables, array_map('trim', explode(',', $match[1]))); +			} +			else +			{ +				$tables[] = $match[2]; +			} +		}  		foreach ($tables as $table_name)  		{ @@ -312,14 +245,13 @@ abstract class memory extends \phpbb\cache\driver\base  				$temp = array();  			} -			$temp[$hash] = true; +			$temp[$query_id] = true;  			// This must never expire  			$this->_write('sql_' . $table_name, $temp, 0);  		}  		// store them in the right place -		$query_id = sizeof($this->sql_rowset);  		$this->sql_rowset[$query_id] = array();  		$this->sql_row_pointer[$query_id] = 0; @@ -329,96 +261,12 @@ abstract class memory extends \phpbb\cache\driver\base  		}  		$db->sql_freeresult($query_result); -		$this->_write('sql_' . $hash, $this->sql_rowset[$query_id], $ttl); +		$this->_write('sql_' . $query_id, $this->sql_rowset[$query_id], $ttl);  		return $query_id;  	}  	/** -	* Ceck if a given sql query exist in cache -	*/ -	function sql_exists($query_id) -	{ -		return isset($this->sql_rowset[$query_id]); -	} - -	/** -	* Fetch row from cache (database) -	*/ -	function sql_fetchrow($query_id) -	{ -		if ($this->sql_row_pointer[$query_id] < sizeof($this->sql_rowset[$query_id])) -		{ -			return $this->sql_rowset[$query_id][$this->sql_row_pointer[$query_id]++]; -		} - -		return false; -	} - -	/** -	* Fetch a field from the current row of a cached database result (database) -	*/ -	function sql_fetchfield($query_id, $field) -	{ -		if ($this->sql_row_pointer[$query_id] < sizeof($this->sql_rowset[$query_id])) -		{ -			return (isset($this->sql_rowset[$query_id][$this->sql_row_pointer[$query_id]][$field])) ? $this->sql_rowset[$query_id][$this->sql_row_pointer[$query_id]++][$field] : false; -		} - -		return false; -	} - -	/** -	* Seek a specific row in an a cached database result (database) -	*/ -	function sql_rowseek($rownum, $query_id) -	{ -		if ($rownum >= sizeof($this->sql_rowset[$query_id])) -		{ -			return false; -		} - -		$this->sql_row_pointer[$query_id] = $rownum; -		return true; -	} - -	/** -	* Free memory used for a cached database result (database) -	*/ -	function sql_freeresult($query_id) -	{ -		if (!isset($this->sql_rowset[$query_id])) -		{ -			return false; -		} - -		unset($this->sql_rowset[$query_id]); -		unset($this->sql_row_pointer[$query_id]); - -		return true; -	} - -	/** -	* Removes/unlinks file -	*/ -	function remove_file($filename, $check = false) -	{ -		if (!function_exists('phpbb_is_writable')) -		{ -			global $phpbb_root_path, $phpEx; -			include($phpbb_root_path . 'includes/functions.' . $phpEx); -		} - -		if ($check && !phpbb_is_writable($this->cache_dir)) -		{ -			// E_USER_ERROR - not using language entry - intended. -			trigger_error('Unable to remove files within ' . $this->cache_dir . '. Please check directory permissions.', E_USER_ERROR); -		} - -		return @unlink($filename); -	} - -	/**  	* Check if a cache var exists  	*  	* @access protected | 
