diff options
| author | Nathan Guse <nathaniel.guse@gmail.com> | 2012-12-07 21:14:39 -0600 | 
|---|---|---|
| committer | Nathan Guse <nathaniel.guse@gmail.com> | 2012-12-07 21:14:39 -0600 | 
| commit | 0042f071476b75258f5f8ea0b5b9fcb445ffde23 (patch) | |
| tree | 67cbafd7c655ad94809fef5f7dbe3a23525b232b /phpBB/includes | |
| parent | c911a34b5b7541b46ee2408da366d2dc7c302090 (diff) | |
| parent | b7b8fefdd084b51c93b15dfdfb34d2ef294f4d76 (diff) | |
| download | forums-0042f071476b75258f5f8ea0b5b9fcb445ffde23.tar forums-0042f071476b75258f5f8ea0b5b9fcb445ffde23.tar.gz forums-0042f071476b75258f5f8ea0b5b9fcb445ffde23.tar.bz2 forums-0042f071476b75258f5f8ea0b5b9fcb445ffde23.tar.xz forums-0042f071476b75258f5f8ea0b5b9fcb445ffde23.zip | |
Merge branch 'develop' of github.com:EXreaction/phpbb3 into ticket/11103
Conflicts:
	phpBB/install/database_update.php
	phpBB/styles/prosilver/template/ucp_prefs_personal.html
	phpBB/styles/subsilver2/template/ucp_prefs_personal.html
Diffstat (limited to 'phpBB/includes')
47 files changed, 608 insertions, 202 deletions
| diff --git a/phpBB/includes/cache/driver/apc.php b/phpBB/includes/cache/driver/apc.php index dc0144fac3..0516b669c8 100644 --- a/phpBB/includes/cache/driver/apc.php +++ b/phpBB/includes/cache/driver/apc.php @@ -26,7 +26,7 @@ class phpbb_cache_driver_apc extends phpbb_cache_driver_memory  	/**  	* Purge cache data  	* -	* @return void +	* @return null  	*/  	function purge()  	{ diff --git a/phpBB/includes/cache/driver/eaccelerator.php b/phpBB/includes/cache/driver/eaccelerator.php index 7939f043c9..257b90c76e 100644 --- a/phpBB/includes/cache/driver/eaccelerator.php +++ b/phpBB/includes/cache/driver/eaccelerator.php @@ -30,7 +30,7 @@ class phpbb_cache_driver_eaccelerator extends phpbb_cache_driver_memory  	/**  	* Purge cache data  	* -	* @return void +	* @return null  	*/  	function purge()  	{ @@ -47,7 +47,7 @@ class phpbb_cache_driver_eaccelerator extends phpbb_cache_driver_memory  	/**  	 * Perform cache garbage collection  	 * -	 * @return void +	 * @return null  	 */  	function tidy()  	{ diff --git a/phpBB/includes/cache/driver/file.php b/phpBB/includes/cache/driver/file.php index 5014ba18af..691abe0438 100644 --- a/phpBB/includes/cache/driver/file.php +++ b/phpBB/includes/cache/driver/file.php @@ -388,10 +388,10 @@ class phpbb_cache_driver_file extends phpbb_cache_driver_base  		if ($this->_write('sql_' . md5($query), $this->sql_rowset[$query_id], $ttl + time(), $query))  		{ -			$query_result = $query_id; +			return $query_id;  		} -		return $query_id; +		return $query_result;  	}  	/** @@ -653,10 +653,11 @@ class phpbb_cache_driver_file extends phpbb_cache_driver_base  		$file = "{$this->cache_dir}$filename.$phpEx"; +		$lock = new phpbb_lock_flock($file); +		$lock->acquire(); +  		if ($handle = @fopen($file, 'wb'))  		{ -			@flock($handle, LOCK_EX); -  			// File header  			fwrite($handle, '<' . '?php exit; ?' . '>'); @@ -697,7 +698,6 @@ class phpbb_cache_driver_file extends phpbb_cache_driver_base  				fwrite($handle, $data);  			} -			@flock($handle, LOCK_UN);  			fclose($handle);  			if (!function_exists('phpbb_chmod')) @@ -708,10 +708,16 @@ class phpbb_cache_driver_file extends phpbb_cache_driver_base  			phpbb_chmod($file, CHMOD_READ | CHMOD_WRITE); -			return true; +			$return_value = true; +		} +		else +		{ +			$return_value = false;  		} -		return false; +		$lock->release(); + +		return $return_value;  	}  	/** diff --git a/phpBB/includes/cache/driver/interface.php b/phpBB/includes/cache/driver/interface.php index 847ba97262..d403bbcd71 100644 --- a/phpBB/includes/cache/driver/interface.php +++ b/phpBB/includes/cache/driver/interface.php @@ -63,42 +63,81 @@ interface phpbb_cache_driver_interface  	public function destroy($var_name, $table = '');  	/** -	* Check if a given cache entry exist +	* Check if a given cache entry exists  	*/  	public function _exists($var_name);  	/** -	* Load cached sql query +	* Load result of an SQL query from cache. +	* +	* @param string $query			SQL query +	* +	* @return int|bool				Query ID (integer) if cache contains a rowset +	*								for the specified query. +	*								False otherwise.  	*/  	public function sql_load($query);  	/** -	* Save sql query +	* Save result of an SQL query in cache. +	* +	* In persistent cache stores, this function stores the query +	* result to persistent storage. In other words, there is no need +	* to call save() afterwards. +	* +	* @param string $query			SQL query, should be used for generating storage key +	* @param mixed $query_result	The result from dbal::sql_query, to be passed to +	* 								dbal::sql_fetchrow to get all rows and store them +	* 								in cache. +	* @param int $ttl				Time to live, after this timeout the query should +	*								expire from the cache. +	* @return int|mixed				If storing in cache succeeded, an integer $query_id +	* 								representing the query should be returned. Otherwise +	* 								the original $query_result should be returned.  	*/  	public function sql_save($query, $query_result, $ttl);  	/** -	* Ceck if a given sql query exist in cache +	* Check if result for a given SQL query exists in cache. +	* +	* @param int $query_id +	* @return bool  	*/  	public function sql_exists($query_id);  	/**  	* Fetch row from cache (database) +	* +	* @param int $query_id +	* @return array|bool 			The query result if found in the cache, otherwise +	* 								false.  	*/  	public function sql_fetchrow($query_id);  	/**  	* Fetch a field from the current row of a cached database result (database) +	* +	* @param int $query_id +	* @param $field 				The name of the column. +	* @return string|bool 			The field of the query result if found in the cache, +	* 								otherwise false.  	*/  	public function sql_fetchfield($query_id, $field);  	/**  	* Seek a specific row in an a cached database result (database) +	* +	* @param int $rownum 			Row to seek to. +	* @param int $query_id +	* @return bool  	*/  	public function sql_rowseek($rownum, $query_id);  	/**  	* Free memory used for a cached database result (database) +	* +	* @param int $query_id +	* @return bool  	*/  	public function sql_freeresult($query_id);  } diff --git a/phpBB/includes/cache/driver/memcache.php b/phpBB/includes/cache/driver/memcache.php index 9fe70f8b44..3fd16b23b0 100644 --- a/phpBB/includes/cache/driver/memcache.php +++ b/phpBB/includes/cache/driver/memcache.php @@ -64,7 +64,7 @@ class phpbb_cache_driver_memcache extends phpbb_cache_driver_memory  	/**  	* Unload the cache resources  	* -	* @return void +	* @return null  	*/  	function unload()  	{ @@ -76,7 +76,7 @@ class phpbb_cache_driver_memcache extends phpbb_cache_driver_memory  	/**  	* Purge cache data  	* -	* @return void +	* @return null  	*/  	function purge()  	{ diff --git a/phpBB/includes/cache/driver/memory.php b/phpBB/includes/cache/driver/memory.php index f6c42c0ea6..c39f9f7850 100644 --- a/phpBB/includes/cache/driver/memory.php +++ b/phpBB/includes/cache/driver/memory.php @@ -299,7 +299,7 @@ abstract class phpbb_cache_driver_memory extends phpbb_cache_driver_base  		if (!preg_match('/FROM \\(?(`?\\w+`?(?: \\w+)?(?:, ?`?\\w+`?(?: \\w+)?)*)\\)?/', $query, $regs))  		{  			// Bail out if the match fails. -			return; +			return $query_result;  		}  		$tables = array_map('trim', explode(',', $regs[1])); @@ -339,8 +339,6 @@ abstract class phpbb_cache_driver_memory extends phpbb_cache_driver_base  		$this->_write('sql_' . $hash, $this->sql_rowset[$query_id], $ttl); -		$query_result = $query_id; -  		return $query_id;  	} diff --git a/phpBB/includes/cache/driver/null.php b/phpBB/includes/cache/driver/null.php index df2c6c026f..687604d14f 100644 --- a/phpBB/includes/cache/driver/null.php +++ b/phpBB/includes/cache/driver/null.php @@ -109,6 +109,7 @@ class phpbb_cache_driver_null extends phpbb_cache_driver_base  	*/  	function sql_save($query, $query_result, $ttl)  	{ +		return $query_result;  	}  	/** diff --git a/phpBB/includes/cache/driver/redis.php b/phpBB/includes/cache/driver/redis.php index a768885962..960735b673 100644 --- a/phpBB/includes/cache/driver/redis.php +++ b/phpBB/includes/cache/driver/redis.php @@ -39,13 +39,39 @@ class phpbb_cache_driver_redis extends phpbb_cache_driver_memory  	var $redis; +	/** +	* Creates a redis cache driver. +	* +	* The following global constants affect operation: +	* +	* PHPBB_ACM_REDIS_HOST +	* PHPBB_ACM_REDIS_PORT +	* PHPBB_ACM_REDIS_PASSWORD +	* PHPBB_ACM_REDIS_DB +	* +	* There are no publicly documented constructor parameters. +	*/  	function __construct()  	{  		// Call the parent constructor  		parent::__construct();  		$this->redis = new Redis(); -		$this->redis->connect(PHPBB_ACM_REDIS_HOST, PHPBB_ACM_REDIS_PORT); + +		$args = func_get_args(); +		if (!empty($args)) +		{ +			$ok = call_user_func_array(array($this->redis, 'connect'), $args); +		} +		else +		{ +			$ok = $this->redis->connect(PHPBB_ACM_REDIS_HOST, PHPBB_ACM_REDIS_PORT); +		} + +		if (!$ok) +		{ +			trigger_error('Could not connect to redis server'); +		}  		if (defined('PHPBB_ACM_REDIS_PASSWORD'))  		{ @@ -74,7 +100,7 @@ class phpbb_cache_driver_redis extends phpbb_cache_driver_memory  	/**  	* Unload the cache resources  	* -	* @return void +	* @return null  	*/  	function unload()  	{ @@ -86,7 +112,7 @@ class phpbb_cache_driver_redis extends phpbb_cache_driver_memory  	/**  	* Purge cache data  	* -	* @return void +	* @return null  	*/  	function purge()  	{ diff --git a/phpBB/includes/cache/driver/wincache.php b/phpBB/includes/cache/driver/wincache.php index fa9eb95f88..58f3b4a581 100644 --- a/phpBB/includes/cache/driver/wincache.php +++ b/phpBB/includes/cache/driver/wincache.php @@ -26,7 +26,7 @@ class phpbb_cache_driver_wincache extends phpbb_cache_driver_memory  	/**  	* Purge cache data  	* -	* @return void +	* @return null  	*/  	function purge()  	{ diff --git a/phpBB/includes/cache/driver/xcache.php b/phpBB/includes/cache/driver/xcache.php index 0b768bdb3e..06c5fafd97 100644 --- a/phpBB/includes/cache/driver/xcache.php +++ b/phpBB/includes/cache/driver/xcache.php @@ -41,7 +41,7 @@ class phpbb_cache_driver_xcache extends phpbb_cache_driver_memory  	/**  	* Purge cache data  	* -	* @return void +	* @return null  	*/  	function purge()  	{ diff --git a/phpBB/includes/config/config.php b/phpBB/includes/config/config.php index 12a4a418b2..4b533dd55c 100644 --- a/phpBB/includes/config/config.php +++ b/phpBB/includes/config/config.php @@ -109,7 +109,7 @@ class phpbb_config implements ArrayAccess, IteratorAggregate, Countable  	* @param  String $key       The configuration option's name  	* @param  bool   $use_cache Whether this variable should be cached or if it  	*                           changes too frequently to be efficiently cached -	* @return void +	* @return null  	*/  	public function delete($key, $use_cache = true)  	{ diff --git a/phpBB/includes/config/db.php b/phpBB/includes/config/db.php index 993a764a7f..45f9f1cb21 100644 --- a/phpBB/includes/config/db.php +++ b/phpBB/includes/config/db.php @@ -96,7 +96,7 @@ class phpbb_config_db extends phpbb_config  	* @param  String $key       The configuration option's name  	* @param  bool   $use_cache Whether this variable should be cached or if it  	*                           changes too frequently to be efficiently cached -	* @return void +	* @return null  	*/  	public function delete($key, $use_cache = true)  	{ diff --git a/phpBB/includes/cron/manager.php b/phpBB/includes/cron/manager.php index ccaa4f3764..84c9650830 100644 --- a/phpBB/includes/cron/manager.php +++ b/phpBB/includes/cron/manager.php @@ -54,7 +54,7 @@ class phpbb_cron_manager  	*  	* @param array|Traversable $tasks		Array of instances of phpbb_cron_task  	* -	* @return void +	* @return null  	*/  	public function load_tasks($tasks)  	{ diff --git a/phpBB/includes/cron/task/core/prune_all_forums.php b/phpBB/includes/cron/task/core/prune_all_forums.php index 252e16e57d..ee0b5f7626 100644 --- a/phpBB/includes/cron/task/core/prune_all_forums.php +++ b/phpBB/includes/cron/task/core/prune_all_forums.php @@ -50,7 +50,7 @@ class phpbb_cron_task_core_prune_all_forums extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/core/prune_forum.php b/phpBB/includes/cron/task/core/prune_forum.php index 41d60af921..fa7a761d88 100644 --- a/phpBB/includes/cron/task/core/prune_forum.php +++ b/phpBB/includes/cron/task/core/prune_forum.php @@ -70,7 +70,7 @@ class phpbb_cron_task_core_prune_forum extends phpbb_cron_task_base implements p  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ @@ -138,7 +138,7 @@ class phpbb_cron_task_core_prune_forum extends phpbb_cron_task_base implements p  	*  	* @param phpbb_request_interface $request Request object.  	* -	* @return void +	* @return null  	*/  	public function parse_parameters(phpbb_request_interface $request)  	{ diff --git a/phpBB/includes/cron/task/core/queue.php b/phpBB/includes/cron/task/core/queue.php index c765660906..732f9c6bea 100644 --- a/phpBB/includes/cron/task/core/queue.php +++ b/phpBB/includes/cron/task/core/queue.php @@ -43,7 +43,7 @@ class phpbb_cron_task_core_queue extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/core/tidy_cache.php b/phpBB/includes/cron/task/core/tidy_cache.php index 6017eea561..16a45dae7c 100644 --- a/phpBB/includes/cron/task/core/tidy_cache.php +++ b/phpBB/includes/cron/task/core/tidy_cache.php @@ -40,7 +40,7 @@ class phpbb_cron_task_core_tidy_cache extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/core/tidy_database.php b/phpBB/includes/cron/task/core/tidy_database.php index 1d256f964f..b882e7b500 100644 --- a/phpBB/includes/cron/task/core/tidy_database.php +++ b/phpBB/includes/cron/task/core/tidy_database.php @@ -43,7 +43,7 @@ class phpbb_cron_task_core_tidy_database extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/core/tidy_search.php b/phpBB/includes/cron/task/core/tidy_search.php index 2e5f3d79d5..fdbe31346e 100644 --- a/phpBB/includes/cron/task/core/tidy_search.php +++ b/phpBB/includes/cron/task/core/tidy_search.php @@ -54,7 +54,7 @@ class phpbb_cron_task_core_tidy_search extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/core/tidy_sessions.php b/phpBB/includes/cron/task/core/tidy_sessions.php index 13531aa30b..95f55235c9 100644 --- a/phpBB/includes/cron/task/core/tidy_sessions.php +++ b/phpBB/includes/cron/task/core/tidy_sessions.php @@ -40,7 +40,7 @@ class phpbb_cron_task_core_tidy_sessions extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/core/tidy_warnings.php b/phpBB/includes/cron/task/core/tidy_warnings.php index 8dd0674fe5..2a7798e56e 100644 --- a/phpBB/includes/cron/task/core/tidy_warnings.php +++ b/phpBB/includes/cron/task/core/tidy_warnings.php @@ -45,7 +45,7 @@ class phpbb_cron_task_core_tidy_warnings extends phpbb_cron_task_base  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run()  	{ diff --git a/phpBB/includes/cron/task/parametrized.php b/phpBB/includes/cron/task/parametrized.php index 0714b2e701..5f0e46eafc 100644 --- a/phpBB/includes/cron/task/parametrized.php +++ b/phpBB/includes/cron/task/parametrized.php @@ -46,7 +46,7 @@ interface phpbb_cron_task_parametrized extends phpbb_cron_task  	*  	* @param phpbb_request_interface $request Request object.  	* -	* @return void +	* @return null  	*/  	public function parse_parameters(phpbb_request_interface $request);  } diff --git a/phpBB/includes/cron/task/task.php b/phpBB/includes/cron/task/task.php index 7b08fed413..2d585df96d 100644 --- a/phpBB/includes/cron/task/task.php +++ b/phpBB/includes/cron/task/task.php @@ -31,7 +31,7 @@ interface phpbb_cron_task  	/**  	* Runs this cron task.  	* -	* @return void +	* @return null  	*/  	public function run(); diff --git a/phpBB/includes/db/mssql.php b/phpBB/includes/db/mssql.php index 1ec8517308..235c48d3f0 100644 --- a/phpBB/includes/db/mssql.php +++ b/phpBB/includes/db/mssql.php @@ -24,11 +24,19 @@ include_once($phpbb_root_path . 'includes/db/dbal.' . $phpEx);  */  class dbal_mssql extends dbal  { +	var $connect_error = ''; +  	/**  	* Connect to server  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ +		if (!function_exists('mssql_connect')) +		{ +			$this->connect_error = 'mssql_connect function does not exist, is mssql extension installed?'; +			return $this->sql_error(''); +		} +  		$this->persistency = $persistency;  		$this->user = $sqluser;  		$this->dbname = $database; @@ -355,34 +363,44 @@ class dbal_mssql extends dbal  	*/  	function _sql_error()  	{ -		$error = array( -			'message'	=> @mssql_get_last_message(), -			'code'		=> '' -		); - -		// Get error code number -		$result_id = @mssql_query('SELECT @@ERROR as code', $this->db_connect_id); -		if ($result_id) +		if (function_exists('mssql_get_last_message'))  		{ -			$row = @mssql_fetch_assoc($result_id); -			$error['code'] = $row['code']; -			@mssql_free_result($result_id); -		} +			$error = array( +				'message'	=> @mssql_get_last_message(), +				'code'		=> '', +			); -		// Get full error message if possible -		$sql = 'SELECT CAST(description as varchar(255)) as message -			FROM master.dbo.sysmessages -			WHERE error = ' . $error['code']; -		$result_id = @mssql_query($sql); -		 -		if ($result_id) -		{ -			$row = @mssql_fetch_assoc($result_id); -			if (!empty($row['message'])) +			// Get error code number +			$result_id = @mssql_query('SELECT @@ERROR as code', $this->db_connect_id); +			if ($result_id) +			{ +				$row = @mssql_fetch_assoc($result_id); +				$error['code'] = $row['code']; +				@mssql_free_result($result_id); +			} + +			// Get full error message if possible +			$sql = 'SELECT CAST(description as varchar(255)) as message +				FROM master.dbo.sysmessages +				WHERE error = ' . $error['code']; +			$result_id = @mssql_query($sql); + +			if ($result_id)  			{ -				$error['message'] .= '<br />' . $row['message']; +				$row = @mssql_fetch_assoc($result_id); +				if (!empty($row['message'])) +				{ +					$error['message'] .= '<br />' . $row['message']; +				} +				@mssql_free_result($result_id);  			} -			@mssql_free_result($result_id); +		} +		else +		{ +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '', +			);  		}  		return $error; diff --git a/phpBB/includes/db/mssql_odbc.php b/phpBB/includes/db/mssql_odbc.php index 7c1ffbc808..2194de4a5e 100644 --- a/phpBB/includes/db/mssql_odbc.php +++ b/phpBB/includes/db/mssql_odbc.php @@ -31,6 +31,7 @@ include_once($phpbb_root_path . 'includes/db/dbal.' . $phpEx);  class dbal_mssql_odbc extends dbal  {  	var $last_query_text = ''; +	var $connect_error = '';  	/**  	* Connect to server @@ -67,7 +68,24 @@ class dbal_mssql_odbc extends dbal  			@ini_set('odbc.defaultlrl', $max_size);  		} -		$this->db_connect_id = ($this->persistency) ? @odbc_pconnect($this->server, $this->user, $sqlpassword) : @odbc_connect($this->server, $this->user, $sqlpassword); +		if ($this->persistency) +		{ +			if (!function_exists('odbc_pconnect')) +			{ +				$this->connect_error = 'odbc_pconnect function does not exist, is odbc extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @odbc_pconnect($this->server, $this->user, $sqlpassword); +		} +		else +		{ +			if (!function_exists('odbc_connect')) +			{ +				$this->connect_error = 'odbc_connect function does not exist, is odbc extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @odbc_connect($this->server, $this->user, $sqlpassword); +		}  		return ($this->db_connect_id) ? $this->db_connect_id : $this->sql_error('');  	} @@ -349,10 +367,22 @@ class dbal_mssql_odbc extends dbal  	*/  	function _sql_error()  	{ -		return array( -			'message'	=> @odbc_errormsg(), -			'code'		=> @odbc_error() -		); +		if (function_exists('odbc_errormsg')) +		{ +			$error = array( +				'message'	=> @odbc_errormsg(), +				'code'		=> @odbc_error(), +			); +		} +		else +		{ +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '', +			); +		} + +		return $error;  	}  	/** diff --git a/phpBB/includes/db/mssqlnative.php b/phpBB/includes/db/mssqlnative.php index e9191fae8a..4a969828e7 100644 --- a/phpBB/includes/db/mssqlnative.php +++ b/phpBB/includes/db/mssqlnative.php @@ -198,16 +198,18 @@ class dbal_mssqlnative extends dbal  	var $m_insert_id = NULL;  	var $last_query_text = '';  	var $query_options = array(); +	var $connect_error = '';  	/**  	* Connect to server  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  	{ -		# Test for driver support, to avoid suppressed fatal error +		// Test for driver support, to avoid suppressed fatal error  		if (!function_exists('sqlsrv_connect'))  		{ -			trigger_error('Native MS SQL Server driver for PHP is missing or needs to be updated. Version 1.1 or later is required to install phpBB3. You can download the driver from: http://www.microsoft.com/sqlserver/2005/en/us/PHP-Driver.aspx\n', E_USER_ERROR); +			$this->connect_error = 'Native MS SQL Server driver for PHP is missing or needs to be updated. Version 1.1 or later is required to install phpBB3. You can download the driver from: http://www.microsoft.com/sqlserver/2005/en/us/PHP-Driver.aspx'; +			return $this->sql_error('');  		}  		//set up connection variables @@ -521,31 +523,43 @@ class dbal_mssqlnative extends dbal  	*/  	function _sql_error()  	{ -		$errors = @sqlsrv_errors(SQLSRV_ERR_ERRORS); -		$error_message = ''; -		$code = 0; - -		if ($errors != null) +		if (function_exists('sqlsrv_errors'))  		{ -			foreach ($errors as $error) +			$errors = @sqlsrv_errors(SQLSRV_ERR_ERRORS); +			$error_message = ''; +			$code = 0; + +			if ($errors != null) +			{ +				foreach ($errors as $error) +				{ +					$error_message .= "SQLSTATE: " . $error[ 'SQLSTATE'] . "\n"; +					$error_message .= "code: " . $error[ 'code'] . "\n"; +					$code = $error['code']; +					$error_message .= "message: " . $error[ 'message'] . "\n"; +				} +				$this->last_error_result = $error_message; +				$error = $this->last_error_result; +			} +			else  			{ -				$error_message .= "SQLSTATE: ".$error[ 'SQLSTATE']."\n"; -				$error_message .= "code: ".$error[ 'code']."\n"; -				$code = $error['code']; -				$error_message .= "message: ".$error[ 'message']."\n"; +				$error = (isset($this->last_error_result) && $this->last_error_result) ? $this->last_error_result : array();  			} -			$this->last_error_result = $error_message; -			$error = $this->last_error_result; + +			$error = array( +				'message'	=> $error, +				'code'		=> $code, +			);  		}  		else  		{ -			$error = (isset($this->last_error_result) && $this->last_error_result) ? $this->last_error_result : array(); +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '', +			);  		} -		return array( -			'message'	=> $error, -			'code'		=> $code, -		); +		return $error;  	}  	/** diff --git a/phpBB/includes/db/mysql.php b/phpBB/includes/db/mysql.php index f685ab055c..dcdeec0401 100644 --- a/phpBB/includes/db/mysql.php +++ b/phpBB/includes/db/mysql.php @@ -29,6 +29,7 @@ include_once($phpbb_root_path . 'includes/db/dbal.' . $phpEx);  class dbal_mysql extends dbal  {  	var $multi_insert = true; +	var $connect_error = '';  	/**  	* Connect to server @@ -43,7 +44,24 @@ class dbal_mysql extends dbal  		$this->sql_layer = 'mysql4'; -		$this->db_connect_id = ($this->persistency) ? @mysql_pconnect($this->server, $this->user, $sqlpassword) : @mysql_connect($this->server, $this->user, $sqlpassword, $new_link); +		if ($this->persistency) +		{ +			if (!function_exists('mysql_pconnect')) +			{ +				$this->connect_error = 'mysql_pconnect function does not exist, is mysql extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @mysql_pconnect($this->server, $this->user, $sqlpassword); +		} +		else +		{ +			if (!function_exists('mysql_connect')) +			{ +				$this->connect_error = 'mysql_connect function does not exist, is mysql extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @mysql_connect($this->server, $this->user, $sqlpassword, $new_link); +		}  		if ($this->db_connect_id && $this->dbname != '')  		{ @@ -426,18 +444,29 @@ class dbal_mysql extends dbal  	*/  	function _sql_error()  	{ -		if (!$this->db_connect_id) +		if ($this->db_connect_id) +		{ +			$error = array( +				'message'	=> @mysql_error($this->db_connect_id), +				'code'		=> @mysql_errno($this->db_connect_id), +			); +		} +		else if (function_exists('mysql_error'))  		{ -			return array( +			$error = array(  				'message'	=> @mysql_error(), -				'code'		=> @mysql_errno() +				'code'		=> @mysql_errno(), +			); +		} +		else +		{ +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '',  			);  		} -		return array( -			'message'	=> @mysql_error($this->db_connect_id), -			'code'		=> @mysql_errno($this->db_connect_id) -		); +		return $error;  	}  	/** diff --git a/phpBB/includes/db/mysqli.php b/phpBB/includes/db/mysqli.php index 6d81b8bc3e..5713b1992c 100644 --- a/phpBB/includes/db/mysqli.php +++ b/phpBB/includes/db/mysqli.php @@ -26,12 +26,19 @@ include_once($phpbb_root_path . 'includes/db/dbal.' . $phpEx);  class dbal_mysqli extends dbal  {  	var $multi_insert = true; +	var $connect_error = '';  	/**  	* Connect to server  	*/  	function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false , $new_link = false)  	{ +		if (!function_exists('mysqli_connect')) +		{ +			$this->connect_error = 'mysqli_connect function does not exist, is mysqli extension installed?'; +			return $this->sql_error(''); +		} +  		// Mysqli extension supports persistent connection since PHP 5.3.0  		$this->persistency = (version_compare(PHP_VERSION, '5.3.0', '>=')) ? $persistency : false;  		$this->user = $sqluser; @@ -423,18 +430,29 @@ class dbal_mysqli extends dbal  	*/  	function _sql_error()  	{ -		if (!$this->db_connect_id) +		if ($this->db_connect_id) +		{ +			$error = array( +				'message'	=> @mysqli_error($this->db_connect_id), +				'code'		=> @mysqli_errno($this->db_connect_id) +			); +		} +		else if (function_exists('mysqli_connect_error'))  		{ -			return array( +			$error = array(  				'message'	=> @mysqli_connect_error(), -				'code'		=> @mysqli_connect_errno() +				'code'		=> @mysqli_connect_errno(), +			); +		} +		else +		{ +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '',  			);  		} -		return array( -			'message'	=> @mysqli_error($this->db_connect_id), -			'code'		=> @mysqli_errno($this->db_connect_id) -		); +		return $error;  	}  	/** diff --git a/phpBB/includes/db/oracle.php b/phpBB/includes/db/oracle.php index 6d9339b2d8..4a2b107865 100644 --- a/phpBB/includes/db/oracle.php +++ b/phpBB/includes/db/oracle.php @@ -24,6 +24,7 @@ include_once($phpbb_root_path . 'includes/db/dbal.' . $phpEx);  class dbal_oracle extends dbal  {  	var $last_query_text = ''; +	var $connect_error = '';  	/**  	* Connect to server @@ -47,7 +48,33 @@ class dbal_oracle extends dbal  			$connect = $sqlserver . (($port) ? ':' . $port : '') . '/' . $database;  		} -		$this->db_connect_id = ($new_link) ? @ocinlogon($this->user, $sqlpassword, $connect, 'UTF8') : (($this->persistency) ? @ociplogon($this->user, $sqlpassword, $connect, 'UTF8') : @ocilogon($this->user, $sqlpassword, $connect, 'UTF8')); +		if ($new_link) +		{ +			if (!function_exists('ocinlogon')) +			{ +				$this->connect_error = 'ocinlogon function does not exist, is oci extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @ocinlogon($this->user, $sqlpassword, $connect, 'UTF8'); +		} +		else if ($this->persistency) +		{ +			if (!function_exists('ociplogon')) +			{ +				$this->connect_error = 'ociplogon function does not exist, is oci extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @ociplogon($this->user, $sqlpassword, $connect, 'UTF8'); +		} +		else +		{ +			if (!function_exists('ocilogon')) +			{ +				$this->connect_error = 'ocilogon function does not exist, is oci extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @ocilogon($this->user, $sqlpassword, $connect, 'UTF8'); +		}  		return ($this->db_connect_id) ? $this->db_connect_id : $this->sql_error('');  	} @@ -646,17 +673,27 @@ class dbal_oracle extends dbal  	*/  	function _sql_error()  	{ -		$error = @ocierror(); -		$error = (!$error) ? @ocierror($this->query_result) : $error; -		$error = (!$error) ? @ocierror($this->db_connect_id) : $error; - -		if ($error) +		if (function_exists('ocierror'))  		{ -			$this->last_error_result = $error; +			$error = @ocierror(); +			$error = (!$error) ? @ocierror($this->query_result) : $error; +			$error = (!$error) ? @ocierror($this->db_connect_id) : $error; + +			if ($error) +			{ +				$this->last_error_result = $error; +			} +			else +			{ +				$error = (isset($this->last_error_result) && $this->last_error_result) ? $this->last_error_result : array(); +			}  		}  		else  		{ -			$error = (isset($this->last_error_result) && $this->last_error_result) ? $this->last_error_result : array(); +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '', +			);  		}  		return $error; diff --git a/phpBB/includes/db/sqlite.php b/phpBB/includes/db/sqlite.php index 5fc89ced18..06e368d586 100644 --- a/phpBB/includes/db/sqlite.php +++ b/phpBB/includes/db/sqlite.php @@ -24,6 +24,8 @@ include_once($phpbb_root_path . 'includes/db/dbal.' . $phpEx);  */  class dbal_sqlite extends dbal  { +	var $connect_error = ''; +  	/**  	* Connect to server  	*/ @@ -35,7 +37,24 @@ class dbal_sqlite extends dbal  		$this->dbname = $database;  		$error = ''; -		$this->db_connect_id = ($this->persistency) ? @sqlite_popen($this->server, 0666, $error) : @sqlite_open($this->server, 0666, $error); +		if ($this->persistency) +		{ +			if (!function_exists('sqlite_popen')) +			{ +				$this->connect_error = 'sqlite_popen function does not exist, is sqlite extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @sqlite_popen($this->server, 0666, $error); +		} +		else +		{ +			if (!function_exists('sqlite_open')) +			{ +				$this->connect_error = 'sqlite_open function does not exist, is sqlite extension installed?'; +				return $this->sql_error(''); +			} +			$this->db_connect_id = @sqlite_open($this->server, 0666, $error); +		}  		if ($this->db_connect_id)  		{ @@ -280,10 +299,22 @@ class dbal_sqlite extends dbal  	*/  	function _sql_error()  	{ -		return array( -			'message'	=> @sqlite_error_string(@sqlite_last_error($this->db_connect_id)), -			'code'		=> @sqlite_last_error($this->db_connect_id) -		); +		if (function_exists('sqlite_error_string')) +		{ +			$error = array( +				'message'	=> @sqlite_error_string(@sqlite_last_error($this->db_connect_id)), +				'code'		=> @sqlite_last_error($this->db_connect_id), +			); +		} +		else +		{ +			$error = array( +				'message'	=> $this->connect_error, +				'code'		=> '', +			); +		} + +		return $error;  	}  	/** diff --git a/phpBB/includes/functions.php b/phpBB/includes/functions.php index 69b6932d30..c2694d3bd7 100644 --- a/phpBB/includes/functions.php +++ b/phpBB/includes/functions.php @@ -2904,7 +2904,7 @@ function meta_refresh($time, $url, $disable_cd_check = false)  *  * @param int $code HTTP status code  * @param string $message Message for the status code -* @return void +* @return null  */  function send_status_line($code, $message)  { @@ -4843,7 +4843,7 @@ function phpbb_get_plural_form($rule, $number)  *  * @param array	$param		Parameter array, see $param_defaults array.  * -* @return void +* @return null  */  function phpbb_http_login($param)  { diff --git a/phpBB/includes/functions_admin.php b/phpBB/includes/functions_admin.php index e15bf12279..69ca44861f 100644 --- a/phpBB/includes/functions_admin.php +++ b/phpBB/includes/functions_admin.php @@ -3324,7 +3324,7 @@ function obtain_latest_version_info($force_update = false, $warn_fail = false, $   * @param int		$flag			The binary flag which is OR-ed with the current column value   * @param string	$sql_more		This string is attached to the sql query generated to update the table.   * - * @return void + * @return null   */  function enable_bitfield_column_flag($table_name, $column_name, $flag, $sql_more = '')  { diff --git a/phpBB/includes/functions_download.php b/phpBB/includes/functions_download.php index b6371dbecc..fc6f1cc762 100644 --- a/phpBB/includes/functions_download.php +++ b/phpBB/includes/functions_download.php @@ -433,7 +433,7 @@ function set_modified_headers($stamp, $browser)  *  * @param bool $exit		Whether to die or not.  * -* @return void +* @return null  */  function file_gc($exit = true)  { diff --git a/phpBB/includes/functions_install.php b/phpBB/includes/functions_install.php index 7a799993db..ab6b3ea009 100644 --- a/phpBB/includes/functions_install.php +++ b/phpBB/includes/functions_install.php @@ -87,7 +87,7 @@ function get_available_dbms($dbms = false, $return_unavailable = false, $only_20  			'2.0.x'			=> false,  		),  		'postgres' => array( -			'LABEL'			=> 'PostgreSQL 7.x/8.x', +			'LABEL'			=> 'PostgreSQL 8.3+',  			'SCHEMA'		=> 'postgres',  			'MODULE'		=> 'pgsql',  			'DELIM'			=> ';', diff --git a/phpBB/includes/functions_messenger.php b/phpBB/includes/functions_messenger.php index cf03de08c4..a18aeddabd 100644 --- a/phpBB/includes/functions_messenger.php +++ b/phpBB/includes/functions_messenger.php @@ -651,64 +651,6 @@ class queue  	}  	/** -	* Obtains exclusive lock on queue cache file. -	* Returns resource representing the lock -	*/ -	function lock() -	{ -		// For systems that can't have two processes opening -		// one file for writing simultaneously -		if (file_exists($this->cache_file . '.lock')) -		{ -			$mode = 'rb'; -		} -		else -		{ -			$mode = 'wb'; -		} - -		$lock_fp = @fopen($this->cache_file . '.lock', $mode); - -		if ($mode == 'wb') -		{ -			if (!$lock_fp) -			{ -				// Two processes may attempt to create lock file at the same time. -				// Have the losing process try opening the lock file again for reading -				// on the assumption that the winning process created it -				$mode = 'rb'; -				$lock_fp = @fopen($this->cache_file . '.lock', $mode); -			} -			else -			{ -				// Only need to set mode when the lock file is written -				@chmod($this->cache_file . '.lock', 0666); -			} -		} - -		if ($lock_fp) -		{ -			@flock($lock_fp, LOCK_EX); -		} - -		return $lock_fp; -	} - -	/** -	* Releases lock on queue cache file, using resource obtained from lock() -	*/ -	function unlock($lock_fp) -	{ -		// lock() will return null if opening lock file, and thus locking, failed. -		// Accept null values here so that client code does not need to check them -		if ($lock_fp) -		{ -			@flock($lock_fp, LOCK_UN); -			fclose($lock_fp); -		} -	} - -	/**  	* Process queue  	* Using lock file  	*/ @@ -716,16 +658,24 @@ class queue  	{  		global $db, $config, $phpEx, $phpbb_root_path, $user; -		$lock_fp = $this->lock(); +		$lock = new phpbb_lock_flock($this->cache_file); +		$lock->acquire(); -		set_config('last_queue_run', time(), true); - -		if (!file_exists($this->cache_file) || filemtime($this->cache_file) > time() - $config['queue_interval']) +		// avoid races, check file existence once +		$have_cache_file = file_exists($this->cache_file); +		if (!$have_cache_file || $config['last_queue_run'] > time() - $config['queue_interval'])  		{ -			$this->unlock($lock_fp); +			if (!$have_cache_file) +			{ +				set_config('last_queue_run', time(), true); +			} + +			$lock->release();  			return;  		} +		set_config('last_queue_run', time(), true); +  		include($this->cache_file);  		foreach ($this->queue_data as $object => $data_ary) @@ -789,7 +739,7 @@ class queue  				break;  				default: -					$this->unlock($lock_fp); +					$lock->release();  					return;  			} @@ -865,7 +815,7 @@ class queue  			}  		} -		$this->unlock($lock_fp); +		$lock->release();  	}  	/** @@ -878,7 +828,8 @@ class queue  			return;  		} -		$lock_fp = $this->lock(); +		$lock = new phpbb_lock_flock($this->cache_file); +		$lock->acquire();  		if (file_exists($this->cache_file))  		{ @@ -905,7 +856,7 @@ class queue  			phpbb_chmod($this->cache_file, CHMOD_READ | CHMOD_WRITE);  		} -		$this->unlock($lock_fp); +		$lock->release();  	}  } diff --git a/phpBB/includes/functions_module.php b/phpBB/includes/functions_module.php index ad76be9f2f..0d387ace6d 100644 --- a/phpBB/includes/functions_module.php +++ b/phpBB/includes/functions_module.php @@ -759,7 +759,26 @@ class p_master  				}  			} -			$u_title = $module_url . $delim . 'i=' . (($item_ary['cat']) ? $item_ary['id'] : $item_ary['name'] . (($item_ary['is_duplicate']) ? '&icat=' . $current_id : '') . '&mode=' . $item_ary['mode']); +			$u_title = $module_url . $delim . 'i='; +			// if the item has a name use it, else use its id +			if (empty($item_ary['name'])) +			{ +				$u_title .=  $item_ary['id']; +			} +			else +			{ +				// if the category has a name, then use it. +				$u_title .=  $item_ary['name']; +			} +			// If the item is not a category append the mode +			if (!$item_ary['cat']) +			{ +				if ($item_ary['is_duplicate']) +				{ +					$u_title .= '&icat=' . $current_id; +				} +				$u_title .= '&mode=' . $item_ary['mode']; +			}  			// Was not allowed in categories before - /*!$item_ary['cat'] && */  			$u_title .= (isset($item_ary['url_extra'])) ? $item_ary['url_extra'] : ''; diff --git a/phpBB/includes/group_positions.php b/phpBB/includes/group_positions.php index 74de3516cb..60352ed97d 100644 --- a/phpBB/includes/group_positions.php +++ b/phpBB/includes/group_positions.php @@ -104,7 +104,7 @@ class phpbb_group_positions  	* Addes a group by group_id  	*  	* @param	int		$group_id	group_id of the group to be added -	* @return	void +	* @return	null  	*/  	public function add_group($group_id)  	{ @@ -128,7 +128,7 @@ class phpbb_group_positions  	*  	* @param	int		$group_id		group_id of the group to be deleted  	* @param	bool	$skip_group		Skip setting the group to GROUP_DISABLED, to save the query, when you need to update it anyway. -	* @return	void +	* @return	null  	*/  	public function delete_group($group_id, $skip_group = false)  	{ @@ -159,7 +159,7 @@ class phpbb_group_positions  	* Moves a group up by group_id  	*  	* @param	int		$group_id	group_id of the group to be moved -	* @return	void +	* @return	null  	*/  	public function move_up($group_id)  	{ @@ -170,7 +170,7 @@ class phpbb_group_positions  	* Moves a group down by group_id  	*  	* @param	int		$group_id	group_id of the group to be moved -	* @return	void +	* @return	null  	*/  	public function move_down($group_id)  	{ @@ -184,7 +184,7 @@ class phpbb_group_positions  	* @param	int		$delta		number of steps:  	*								- positive = move up  	*								- negative = move down -	* @return	void +	* @return	null  	*/  	public function move($group_id, $delta)  	{ diff --git a/phpBB/includes/lock/db.php b/phpBB/includes/lock/db.php index fa559d6887..6e94dd5a85 100644 --- a/phpBB/includes/lock/db.php +++ b/phpBB/includes/lock/db.php @@ -125,7 +125,7 @@ class phpbb_lock_db  	* Note: Attempting to release a lock that is already released,  	* that is, calling release() multiple times, is harmless.  	* -	* @return void +	* @return null  	*/  	public function release()  	{ diff --git a/phpBB/includes/lock/flock.php b/phpBB/includes/lock/flock.php new file mode 100644 index 0000000000..97bc7dd2b9 --- /dev/null +++ b/phpBB/includes/lock/flock.php @@ -0,0 +1,133 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @ignore +*/ +if (!defined('IN_PHPBB')) +{ +	exit; +} + +/** +* File locking class +* @package phpBB3 +*/ +class phpbb_lock_flock +{ +	/** +	* Path to the file to which access is controlled +	* +	* @var string +	*/ +	private $path; + +	/** +	* File pointer for the lock file +	* @var string +	*/ +	private $lock_fp; + +	/** +	* Constructor. +	* +	* You have to call acquire() to actually acquire the lock. +	* +	* @param	string	$path	Path to the file to which access is controlled +	*/ +	public function __construct($path) +	{ +		$this->path = $path; +		$this->lock_fp = null; +	} + +	/** +	* Tries to acquire the lock. +	* +	* If the lock is already held by another process, this call will block +	* until the other process releases the lock. If a lock is acquired and +	* is not released before script finishes but the process continues to +	* live (apache/fastcgi) then subsequent processes trying to acquire +	* the same lock will be blocked forever. +	* +	* If the lock is already held by the same process via another instance +	* of this class, this call will block forever. +	* +	* If flock function is disabled in php or fails to work, lock +	* acquisition will fail and false will be returned. +	* +	* @return	bool			true if lock was acquired +	*							false otherwise +	*/ +	public function acquire() +	{ +		if ($this->lock_fp) +		{ +			return false; +		} + +		// For systems that can't have two processes opening +		// one file for writing simultaneously +		if (file_exists($this->path . '.lock')) +		{ +			$mode = 'rb'; +		} +		else +		{ +			$mode = 'wb'; +		} + +		$this->lock_fp = @fopen($this->path . '.lock', $mode); + +		if ($mode == 'wb') +		{ +			if (!$this->lock_fp) +			{ +				// Two processes may attempt to create lock file at the same time. +				// Have the losing process try opening the lock file again for reading +				// on the assumption that the winning process created it +				$mode = 'rb'; +				$this->lock_fp = @fopen($this->path . '.lock', $mode); +			} +			else +			{ +				// Only need to set mode when the lock file is written +				@chmod($this->path . '.lock', 0666); +			} +		} + +		if ($this->lock_fp) +		{ +			@flock($this->lock_fp, LOCK_EX); +		} + +		return (bool) $this->lock_fp; +	} + +	/** +	* Releases the lock. +	* +	* The lock must have been previously obtained, that is, acquire() call +	* was issued and returned true. +	* +	* Note: Attempting to release a lock that is already released, +	* that is, calling release() multiple times, is harmless. +	* +	* @return null +	*/ +	public function release() +	{ +		if ($this->lock_fp) +		{ +			@flock($this->lock_fp, LOCK_UN); +			fclose($this->lock_fp); +			$this->lock_fp = null; +		} +	} +} diff --git a/phpBB/includes/questionnaire/questionnaire.php b/phpBB/includes/questionnaire/questionnaire.php index f0fb8c3c06..2d29fe978e 100644 --- a/phpBB/includes/questionnaire/questionnaire.php +++ b/phpBB/includes/questionnaire/questionnaire.php @@ -70,7 +70,7 @@ class phpbb_questionnaire_data_collector  	/**  	* Collect info into the data property.  	* -	* @return	void +	* @return	null  	*/  	function collect()  	{ diff --git a/phpBB/includes/search/fulltext_mysql.php b/phpBB/includes/search/fulltext_mysql.php index 58a4dd7d6a..ff2e24aa05 100644 --- a/phpBB/includes/search/fulltext_mysql.php +++ b/phpBB/includes/search/fulltext_mysql.php @@ -86,6 +86,14 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  		$this->word_length = array('min' => $this->config['fulltext_mysql_min_word_len'], 'max' => $this->config['fulltext_mysql_max_word_len']); +		/** +		 * Load the UTF tools +		 */ +		if (!function_exists('utf8_strlen')) +		{ +			include($phpbb_root_path . 'includes/utf/utf_tools.' . $phpEx); +		} +  		$error = false;  	} @@ -230,7 +238,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  			}  			else  			{ -				$tmp_split_words[] = $word . ' '; +				$tmp_split_words[] = $word;  			}  		}  		if ($phrase) diff --git a/phpBB/includes/search/fulltext_postgres.php b/phpBB/includes/search/fulltext_postgres.php index 08f64735b6..2880610655 100644 --- a/phpBB/includes/search/fulltext_postgres.php +++ b/phpBB/includes/search/fulltext_postgres.php @@ -121,6 +121,14 @@ class phpbb_search_fulltext_postgres extends phpbb_search_base  			}  		} +		/** +		 * Load the UTF tools +		 */ +		if (!function_exists('utf8_strlen')) +		{ +			include($phpbb_root_path . 'includes/utf/utf_tools.' . $phpEx); +		} +  		$error = false;  	} diff --git a/phpBB/includes/style/resource_locator.php b/phpBB/includes/style/resource_locator.php index 04beddb434..4cf767c062 100644 --- a/phpBB/includes/style/resource_locator.php +++ b/phpBB/includes/style/resource_locator.php @@ -110,7 +110,7 @@ class phpbb_style_resource_locator implements phpbb_template_locator  	* Typically it is one directory level deep, e.g. "template/".  	*  	* @param string $template_path Relative path to templates directory within style directories -	* @return void +	* @return null  	*/  	public function set_template_path($template_path)  	{ @@ -121,7 +121,7 @@ class phpbb_style_resource_locator implements phpbb_template_locator  	* Sets the location of templates directory within style directories  	* to the default, which is "template/".  	* -	* @return void +	* @return null  	*/  	public function set_default_template_path()  	{ diff --git a/phpBB/includes/template/compile.php b/phpBB/includes/template/compile.php index 82b301c1a2..22da21820e 100644 --- a/phpBB/includes/template/compile.php +++ b/phpBB/includes/template/compile.php @@ -58,6 +58,9 @@ class phpbb_template_compile  	*/  	public function compile_file_to_file($source_file, $compiled_file)  	{ +		$lock = new phpbb_lock_flock($compiled_file); +		$lock->acquire(); +  		$source_handle = @fopen($source_file, 'rb');  		$destination_handle = @fopen($compiled_file, 'wb'); @@ -66,16 +69,15 @@ class phpbb_template_compile  			return false;  		} -		@flock($destination_handle, LOCK_EX); -  		$this->compile_stream_to_stream($source_handle, $destination_handle);  		@fclose($source_handle); -		@flock($destination_handle, LOCK_UN);  		@fclose($destination_handle);  		phpbb_chmod($compiled_file, CHMOD_READ | CHMOD_WRITE); +		$lock->release(); +  		clearstatcache();  		return true; @@ -118,7 +120,7 @@ class phpbb_template_compile  	*  	* @param resource $source_stream Source stream  	* @param resource $dest_stream Destination stream -	* @return void +	* @return null  	*/  	private function compile_stream_to_stream($source_stream, $dest_stream)  	{ diff --git a/phpBB/includes/ucp/info/ucp_profile.php b/phpBB/includes/ucp/info/ucp_profile.php index 201216e9fd..3581a7f533 100644 --- a/phpBB/includes/ucp/info/ucp_profile.php +++ b/phpBB/includes/ucp/info/ucp_profile.php @@ -19,7 +19,7 @@ class ucp_profile_info  			'title'		=> 'UCP_PROFILE',  			'version'	=> '1.0.0',  			'modes'		=> array( -				'profile_info'	=> array('title' => 'UCP_PROFILE_PROFILE_INFO', 'auth' => '', 'cat' => array('UCP_PROFILE')), +				'profile_info'	=> array('title' => 'UCP_PROFILE_PROFILE_INFO', 'auth' => 'acl_u_chgprofileinfo', 'cat' => array('UCP_PROFILE')),  				'signature'		=> array('title' => 'UCP_PROFILE_SIGNATURE', 'auth' => 'acl_u_sig', 'cat' => array('UCP_PROFILE')),  				'avatar'		=> array('title' => 'UCP_PROFILE_AVATAR', 'auth' => 'cfg_allow_avatar && (cfg_allow_avatar_local || cfg_allow_avatar_remote || cfg_allow_avatar_upload || cfg_allow_avatar_remote_upload)', 'cat' => array('UCP_PROFILE')),  				'reg_details'	=> array('title' => 'UCP_PROFILE_REG_DETAILS', 'auth' => '', 'cat' => array('UCP_PROFILE')), diff --git a/phpBB/includes/ucp/ucp_prefs.php b/phpBB/includes/ucp/ucp_prefs.php index 4b49d2092d..7c3286c1d1 100644 --- a/phpBB/includes/ucp/ucp_prefs.php +++ b/phpBB/includes/ucp/ucp_prefs.php @@ -127,6 +127,36 @@ class ucp_prefs  				$dateformat_options .= '>' . $user->lang['CUSTOM_DATEFORMAT'] . '</option>';  				$timezone_selects = phpbb_timezone_select($user, $data['tz'], true); + +				// check if there are any user-selectable languages +				$sql = 'SELECT COUNT(lang_id) as languages_count +								FROM ' . LANG_TABLE; +				$result = $db->sql_query($sql); +				if ($db->sql_fetchfield('languages_count') > 1) +				{ +					$s_more_languages = true; +				} +				else +				{ +					$s_more_languages = false; +				} +				$db->sql_freeresult($result); + +				// check if there are any user-selectable styles +				$sql = 'SELECT COUNT(style_id) as styles_count +								FROM ' . STYLES_TABLE . ' +								WHERE style_active = 1'; +				$result = $db->sql_query($sql); +				if ($db->sql_fetchfield('styles_count') > 1) +				{ +					$s_more_styles = true; +				} +				else +				{ +					$s_more_styles = false; +				} +				$db->sql_freeresult($result); +  				$template->assign_vars(array(  					'ERROR'				=> (sizeof($error)) ? implode('<br />', $error) : '', @@ -145,6 +175,9 @@ class ucp_prefs  					'DEFAULT_DATEFORMAT'	=> $config['default_dateformat'],  					'A_DEFAULT_DATEFORMAT'	=> addslashes($config['default_dateformat']), +					'S_MORE_LANGUAGES'	=> $s_more_languages, +					'S_MORE_STYLES'			=> $s_more_styles, +  					'S_LANG_OPTIONS'		=> language_select($data['lang']),  					'S_STYLE_OPTIONS'		=> ($config['override_user_style']) ? '' : style_select($data['style']),  					'S_TZ_OPTIONS'			=> $timezone_selects['tz_select'], diff --git a/phpBB/includes/ucp/ucp_profile.php b/phpBB/includes/ucp/ucp_profile.php index 89bf20a30f..e7cea06a45 100644 --- a/phpBB/includes/ucp/ucp_profile.php +++ b/phpBB/includes/ucp/ucp_profile.php @@ -251,6 +251,11 @@ class ucp_profile  			break;  			case 'profile_info': +				// Do not display profile information panel if not authed to do so +				if (!$auth->acl_get('u_chgprofileinfo')) +				{ +					trigger_error('NO_AUTH_PROFILEINFO'); +				}  				include($phpbb_root_path . 'includes/functions_profile_fields.' . $phpEx); | 
