diff options
36 files changed, 584 insertions, 291 deletions
| diff --git a/git-tools/merge.php b/git-tools/merge.php index 41a96c0890..f6142095fb 100755 --- a/git-tools/merge.php +++ b/git-tools/merge.php @@ -124,19 +124,34 @@ function get_repository_url($username, $repository, $ssh = false)  function api_request($query)  { -	$contents = file_get_contents("http://github.com/api/v2/json/$query"); +	return api_url_request("https://api.github.com/$query?per_page=100"); +} + +function api_url_request($url) +{ +	$contents = file_get_contents($url, false, stream_context_create(array( +		'http' => array( +			'header' => "User-Agent: phpBB/1.0\r\n", +		), +	)));  	if ($contents === false)  	{  		throw new RuntimeException("Error: failed to retrieve pull request data\n", 4);  	} +	$contents = json_decode($contents); + +	if (isset($contents->message) && strpos($contents->message, 'API Rate Limit') === 0) +	{ +		throw new RuntimeException('Reached github API Rate Limit. Please try again later' . "\n", 4); +	} -	return json_decode($contents); +	return $contents;  }  function get_pull($username, $repository, $pull_id)  { -	$request = api_request("pulls/$username/$repository/$pull_id"); +	$request = api_request("repos/$username/$repository/pulls/$pull_id");  	$pull = $request->pull; diff --git a/git-tools/setup_github_network.php b/git-tools/setup_github_network.php index 5f2e1609a7..4e144edae6 100755 --- a/git-tools/setup_github_network.php +++ b/git-tools/setup_github_network.php @@ -15,14 +15,14 @@ function show_usage()  	echo "$filename adds repositories of a github network as remotes to a local git repository.\n";  	echo "\n"; -	echo "Usage: [php] $filename -s collaborators|organisation|contributors|network [OPTIONS]\n"; +	echo "Usage: [php] $filename -s collaborators|organisation|contributors|forks [OPTIONS]\n";  	echo "\n";  	echo "Scopes:\n";  	echo "  collaborators                 Repositories of people who have push access to the specified repository\n";  	echo "  contributors                  Repositories of people who have contributed to the specified repository\n";  	echo "  organisation                  Repositories of members of the organisation at github\n"; -	echo "  network                       All repositories of the whole github network\n"; +	echo "  forks                         All repositories of the whole github network\n";  	echo "\n";  	echo "Options:\n"; @@ -55,31 +55,31 @@ exit(work($scope, $username, $repository, $developer));  function work($scope, $username, $repository, $developer)  {  	// Get some basic data -	$network		= get_network($username, $repository); +	$forks		= get_forks($username, $repository);  	$collaborators	= get_collaborators($username, $repository); -	if ($network === false || $collaborators === false) +	if ($forks === false || $collaborators === false)  	{ -		echo "Error: failed to retrieve network or collaborators\n"; +		echo "Error: failed to retrieve forks or collaborators\n";  		return 1;  	}  	switch ($scope)  	{  		case 'collaborators': -			$remotes = array_intersect_key($network, $collaborators); +			$remotes = array_intersect_key($forks, $collaborators);  		break;  		case 'organisation': -			$remotes = array_intersect_key($network, get_organisation_members($username)); +			$remotes = array_intersect_key($forks, get_organisation_members($username));  		break;  		case 'contributors': -			$remotes = array_intersect_key($network, get_contributors($username, $repository)); +			$remotes = array_intersect_key($forks, get_contributors($username, $repository));  		break; -		case 'network': -			$remotes = $network; +		case 'forks': +			$remotes = $forks;  		break;  		default: @@ -145,26 +145,66 @@ function get_repository_url($username, $repository, $ssh = false)  function api_request($query)  { -	$contents = file_get_contents("http://github.com/api/v2/json/$query"); +	return api_url_request("https://api.github.com/$query?per_page=100"); +} + +function api_url_request($url) +{ +	$contents = file_get_contents($url, false, stream_context_create(array( +		'http' => array( +			'header' => "User-Agent: phpBB/1.0\r\n", +		), +	))); + +	$sub_request_result = array(); +	// Check headers for pagination links +	if (!empty($http_response_header)) +	{ +		foreach ($http_response_header as $header_element) +		{ +			// Find Link Header which gives us a link to the next page +			if (strpos($header_element, 'Link: ') === 0) +			{ +				list($head, $header_content) = explode(': ', $header_element); +				foreach (explode(', ', $header_content) as $links) +				{ +					list($url, $rel) = explode('; ', $links); +					if ($rel == 'rel="next"') +					{ +						// Found a next link, follow it and merge the results +						$sub_request_result = api_url_request(substr($url, 1, -1)); +					} +				} +			} +		} +	} +  	if ($contents === false)  	{  		return false;  	} -	return json_decode($contents); +	$contents = json_decode($contents); + +	if (isset($contents->message) && strpos($contents->message, 'API Rate Limit') === 0) +	{ +		throw new RuntimeException('Reached github API Rate Limit. Please try again later' . "\n", 4); +	} + +	return ($sub_request_result) ? array_merge($sub_request_result, $contents) : $contents;  }  function get_contributors($username, $repository)  { -	$request = api_request("repos/show/$username/$repository/contributors"); +	$request = api_request("repos/$username/$repository/stats/contributors");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->contributors as $contributor) +	foreach ($request as $contribution)  	{ -		$usernames[$contributor->login] = $contributor->login; +		$usernames[$contribution->author->login] = $contribution->author->login;  	}  	return $usernames; @@ -172,14 +212,14 @@ function get_contributors($username, $repository)  function get_organisation_members($username)  { -	$request = api_request("organizations/$username/public_members"); +	$request = api_request("orgs/$username/public_members");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->users as $member) +	foreach ($request as $member)  	{  		$usernames[$member->login] = $member->login;  	} @@ -189,35 +229,35 @@ function get_organisation_members($username)  function get_collaborators($username, $repository)  { -	$request = api_request("repos/show/$username/$repository/collaborators"); +	$request = api_request("repos/$username/$repository/collaborators");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->collaborators as $collaborator) +	foreach ($request as $collaborator)  	{ -		$usernames[$collaborator] = $collaborator; +		$usernames[$collaborator->login] = $collaborator->login;  	}  	return $usernames;  } -function get_network($username, $repository) +function get_forks($username, $repository)  { -	$request = api_request("repos/show/$username/$repository/network"); +	$request = api_request("repos/$username/$repository/forks");  	if ($request === false)  	{  		return false;  	}  	$usernames = array(); -	foreach ($request->network as $network) +	foreach ($request as $fork)  	{ -		$usernames[$network->owner] = array( -			'username'		=> $network->owner, -			'repository'	=> $network->name, +		$usernames[$fork->owner->login] = array( +			'username'		=> $fork->owner->login, +			'repository'	=> $fork->name,  		);  	} diff --git a/phpBB/adm/style/acp_icons.html b/phpBB/adm/style/acp_icons.html index 373a7b890c..eca02d2798 100644 --- a/phpBB/adm/style/acp_icons.html +++ b/phpBB/adm/style/acp_icons.html @@ -243,8 +243,8 @@  				<td style="text-align: center;">{items.EMOTION}</td>  			<!-- ENDIF -->  			<td style="text-align: right; white-space: nowrap;"> -				<!-- IF items.S_FIRST_ROW and not PREVIOUS_PAGE -->{ICON_MOVE_UP_DISABLED}<!-- ELSE --><a href="{items.U_MOVE_UP}">{ICON_MOVE_UP}</a><!-- ENDIF -->  -				<!-- IF items.S_LAST_ROW and not NEXT_PAGE -->{ICON_MOVE_DOWN_DISABLED}<!-- ELSE --><a href="{items.U_MOVE_DOWN}">{ICON_MOVE_DOWN}</a><!-- ENDIF --> +				<!-- IF items.S_FIRST_ROW and not U_PREVIOUS_PAGE -->{ICON_MOVE_UP_DISABLED}<!-- ELSE --><a href="{items.U_MOVE_UP}">{ICON_MOVE_UP}</a><!-- ENDIF -->  +				<!-- IF items.S_LAST_ROW and not U_NEXT_PAGE -->{ICON_MOVE_DOWN_DISABLED}<!-- ELSE --><a href="{items.U_MOVE_DOWN}">{ICON_MOVE_DOWN}</a><!-- ENDIF -->  				 <a href="{items.U_EDIT}">{ICON_EDIT}</a> <a href="{items.U_DELETE}" data-ajax="row_delete">{ICON_DELETE}</a>  			</td>  		</tr> diff --git a/phpBB/docs/README.html b/phpBB/docs/README.html index 164c4a2f55..95a2f56825 100644 --- a/phpBB/docs/README.html +++ b/phpBB/docs/README.html @@ -34,7 +34,7 @@  <!-- BEGIN DOCUMENT --> -	<p>Thank you for downloading phpBB3. This README will guide through the basics of installation and operation of phpBB3. Please ensure you read this and the accompanying documentation fully <strong>before</strong> proceeding with the installation.</p> +	<p>Thank you for downloading phpBB3. This README will guide you through the basics of installation and operation of phpBB3. Please ensure you read this and the accompanying documentation fully <strong>before</strong> proceeding with the installation.</p>  	<h1>Readme</h1> @@ -61,7 +61,7 @@  				</ol>  				</li>  				<li><a href="#status">Status of this version</a></li> -				<li><a href="#bugs">Reporting Bugs</a> +				<li><a href="#bugs">Reporting bugs</a>  				<ol style="list-style-type: lower-roman;">  					<li><a href="#securitybugs">Security related bugs</a></li>  				</ol> @@ -84,12 +84,11 @@  		<div class="inner"><span class="corners-top"><span></span></span>  		<div class="content"> - -	<p>Installation, update and conversion instructions can be found in the <a href="INSTALL.html">INSTALL</a> document contained in this distribution. If you are intending to convert from a previous phpBB 2.0.x or 3.0.x installation we highly recommend you backup any existing data before proceeding!</p> +	<p>Installation, update and conversion instructions can be found in the <a href="INSTALL.html">INSTALL</a> document in this directory. If you are intending on converting from a phpBB 2.0.x or 3.0.x installation we highly recommend that you backup any existing data before proceeding!</p>  	<p>Users of phpBB 3.0 and 3.1 Beta versions cannot directly update.</p> -	<p>Please note that we won't support the following installation types:</p> +	<p>Please note that we don't support the following installation types:</p>  	<ul>  		<li>Updates from phpBB 3.0 Beta versions to phpBB 3.0 RC1 and higher</li>  		<li>Updates from phpBB 3.1 Beta versions to phpBB 3.1 RC1 and higher</li> @@ -103,8 +102,8 @@  		<li>Updates from phpBB 3.0 RC1 and 3.1 RC1 to the latest version</li>  		<li>Note: if using the <em>Automatic Update Package</em>, updates are supported from phpBB 3.0.2 onward. To update a pre-3.0.2 installation, first update to 3.0.2 and then update to the current version.</li>  		<li>Conversions from phpBB 2.0.x to the latest version</li> -		<li>New installations of phpBB 3.0.x - always only the latest released version</li> -		<li>New installations of phpBB 3.1.x - always only the latest released version</li> +		<li>New installations of phpBB 3.0.x - only the latest released version</li> +		<li>New installations of phpBB 3.1.x - only the latest released version</li>  	</ul>  		</div> @@ -131,7 +130,7 @@  	<p>For more information about language packs, please see: <a href="http://www.phpbb.com/languages/">http://www.phpbb.com/languages/</a></p> -	<p>This is the <em>official</em> location for all supported language sets. If you download a package from a 3rd party site you do so with the understanding that we cannot offer support. So please, do not ask for help in these cases!</p> +	<p>This is the <em>official</em> location for all supported language sets. If you download a package from a 3rd party site you do so with the understanding that we cannot offer support. Please do not ask for support if you download a language pack from a 3rd party site.</p>  	<p>Installation of these packages is straightforward: simply download the required language pack, uncompress (unzip) it and via FTP transfer the included <code>language</code> and <code>styles</code> folders to the root of your board installation. The language can then be installed via the Administration Control Panel of your board: <code>System tab -> General Tasks -> Language packs</code>. A more detailed description of the process is in the Knowledge Base article, <a href="http://www.phpbb.com/kb/article/how-to-install-a-language-pack/">How to Install a Language Pack</a>.</p> @@ -175,15 +174,15 @@  		<div class="content"> -	<p>phpBB3 can seem a little daunting to new users in places, particularly with regard the permission system. The first thing you should do is check the <a href="FAQ.html">FAQ</a> which covers a few basic getting started questions. If you need additional help there are several places you should look.</p> +	<p>phpBB3 can sometimes seem a little daunting to new users, particularly with regards to the permission system. The first thing you should do is check the <a href="FAQ.html">FAQ</a>, which covers a few basic getting started questions. If you need additional help there are several places you can find it.</p>  	<a name="docs"></a><h3>3.i. phpBB3 Documentation</h3> -	<p>A comprehensive documentation is now available online and can be accessed from the following location:</p> +	<p>Comprehensive documentation is now available on the phpBB website:</p>  	<p><a href="http://www.phpbb.com/support/documentation/3.0/">http://www.phpbb.com/support/documentation/3.0/</a></p> -	<p>This covers everything from installation through setting permissions and managing users.</p> +	<p>This covers everything from installation to setting permissions and managing users.</p>  	<a name="kb"></a><h3>3.ii. Knowledge Base</h3> @@ -197,7 +196,7 @@  	<p><a href="http://www.phpbb.com/community/">http://www.phpbb.com/community/</a></p> -	<p>If you do seek help via our forums please be sure to do a Search before posting. This may well save both you and us time and allow the developer, moderator and support groups to spend more time responding to people with unknown issues and problems. Please also remember that phpBB is an entirely volunteer effort, no one receives any compensation for the time they give, this includes moderators as well as developers. So please be respectful and mindful when awaiting responses.</p> +	<p>If you do seek help via our forums please be sure to do a search before posting; if someone has experienced the issue before, then you may find that your question has already been answered. Please remember that phpBB is entirely staffed by volunteers, no one receives any compensation for the time they give, including moderators as well as developers; please be respectful and mindful when awaiting responses and receiving support.</p>  	<a name="irc"></a><h3>3.iv Internet Relay Chat</h3> @@ -268,7 +267,7 @@  	<p>The relevant database type/version is listed within the administration control panel.</p> -	<p>Please also be as detailed as you can in your report, if possible list the steps required to duplicate the problem. If you have a patch that fixes the issue, please attach it to the ticket or submit a pull request <a href="https://github.com/phpbb/phpbb3">on GitHub</a>.</p> +	<p>Please be as detailed as you can in your report, and if possible, list the steps required to duplicate the problem. If you have a patch that fixes the issue, please attach it to the ticket or submit a pull request to our repository <a href="https://github.com/phpbb/phpbb3">on GitHub</a>.</p>  	<p>If you create a patch, it is very much appreciated (but not required) if you follow the phpBB coding guidelines. Please note that the coding guidelines are somewhat different between different versions of phpBB. For phpBB 3.1.x the coding guidelines may be found here: <a href="http://area51.phpbb.com/docs/31x/coding-guidelines.html">http://area51.phpbb.com/docs/31x/coding-guidelines.html</a></p> @@ -299,8 +298,8 @@  	<p>This list is not complete but does represent those bugs which may affect users on a wider scale. Other bugs listed in the tracker have typically been shown to be limited to certain setups or methods of installation, updating and/or conversions.</p>  	<ul> -		<li>Conversions may fail to complete on large boards under some hosts</li> -		<li>Updates may fail to complete on large update sets under some hosts</li> +		<li>Conversions may fail to complete on large boards under some hosts.</li> +		<li>Updates may fail to complete on large update sets under some hosts.</li>  		<li>Smilies placed directly after bbcode tags will not get parsed. Smilies always need to be separated by spaces.</li>  	</ul> @@ -322,7 +321,7 @@  	<p>phpBB 3.1.x takes advantage of new features added in PHP 5.3. We recommend that you upgrade to the latest stable release of PHP5 to run phpBB. The minimum version required is PHP 5.3.3.</p> -	<p>Please remember that running any application on a developmental version of PHP can lead to strange/unexpected results which may appear to be bugs in the application (which may not be true). Therefore we recommend you upgrade to the newest stable version of PHP before running phpBB3. If you are running a developmental version of PHP please check any bugs you find on a system running a stable release before submitting.</p> +	<p>Please remember that running any application on a development (unstable, e.g. a beta release) version of PHP can lead to strange/unexpected results which may appear to be bugs in the application. Therefore, we recommend you upgrade to the newest stable version of PHP before running phpBB3. If you are running a development version of PHP please check any bugs you find on a system running a stable release before submitting.</p>  	<p>This board has been developed and tested under Linux and Windows (amongst others) running Apache using MySQL 3.23, 4.x, 5.x, MSSQL Server 2000, PostgreSQL 8.x, Oracle 8, SQLite 2 and Firebird. Versions of PHP used range from 5.3.x to 5.4.x without problem.</p> diff --git a/phpBB/includes/acp/acp_captcha.php b/phpBB/includes/acp/acp_captcha.php index c7c64ae56b..1a083c20ac 100644 --- a/phpBB/includes/acp/acp_captcha.php +++ b/phpBB/includes/acp/acp_captcha.php @@ -124,6 +124,8 @@ class acp_captcha  					'CAPTCHA_PREVIEW_TPL'	=> $demo_captcha->get_demo_template($id),  					'S_CAPTCHA_HAS_CONFIG'	=> $demo_captcha->has_config(),  					'CAPTCHA_SELECT'		=> $captcha_select, + +					'U_ACTION'				=> $this->u_action,  				));  			}  		} diff --git a/phpBB/includes/acp/acp_permission_roles.php b/phpBB/includes/acp/acp_permission_roles.php index 004187af84..e830479389 100644 --- a/phpBB/includes/acp/acp_permission_roles.php +++ b/phpBB/includes/acp/acp_permission_roles.php @@ -21,6 +21,7 @@ if (!defined('IN_PHPBB'))  class acp_permission_roles  {  	var $u_action; +	protected $auth_admin;  	function main($id, $mode)  	{ @@ -30,7 +31,7 @@ class acp_permission_roles  		include_once($phpbb_root_path . 'includes/functions_user.' . $phpEx);  		include_once($phpbb_root_path . 'includes/acp/auth.' . $phpEx); -		$auth_admin = new auth_admin(); +		$this->auth_admin = new auth_admin();  		$user->add_lang('acp/permissions');  		add_permission_language(); @@ -210,7 +211,7 @@ class acp_permission_roles  					}  					// Now add the auth settings -					$auth_admin->acl_set_role($role_id, $auth_settings); +					$this->auth_admin->acl_set_role($role_id, $auth_settings);  					$role_name = (!empty($user->lang[$role_name])) ? $user->lang[$role_name] : $role_name;  					add_log('admin', 'LOG_' . strtoupper($permission_type) . 'ROLE_' . strtoupper($action), $role_name); @@ -343,7 +344,7 @@ class acp_permission_roles  				// Get users/groups/forums using this preset...  				if ($action == 'edit')  				{ -					$hold_ary = $auth_admin->get_role_mask($role_id); +					$hold_ary = $this->auth_admin->get_role_mask($role_id);  					if (sizeof($hold_ary))  					{ @@ -354,7 +355,7 @@ class acp_permission_roles  							'L_ROLE_ASSIGNED_TO'	=> sprintf($user->lang['ROLE_ASSIGNED_TO'], $role_name))  						); -						$auth_admin->display_role_mask($hold_ary); +						$this->auth_admin->display_role_mask($hold_ary);  					}  				} @@ -445,8 +446,8 @@ class acp_permission_roles  				'S_DISPLAY_ROLE_MASK'	=> true)  			); -			$hold_ary = $auth_admin->get_role_mask($display_item); -			$auth_admin->display_role_mask($hold_ary); +			$hold_ary = $this->auth_admin->get_role_mask($display_item); +			$this->auth_admin->display_role_mask($hold_ary);  		}  	} @@ -462,7 +463,7 @@ class acp_permission_roles  		$auth_options = array(0 => $auth_options);  		// Making use of auth_admin method here (we do not really want to change two similar code fragments) -		auth_admin::build_permission_array($auth_options, $content_array, $categories, $key_sort_array); +		$this->auth_admin->build_permission_array($auth_options, $content_array, $categories, $key_sort_array);  		$content_array = $content_array[0]; @@ -500,8 +501,6 @@ class acp_permission_roles  	{  		global $db; -		$auth_admin = new auth_admin(); -  		// Get complete auth array  		$sql = 'SELECT auth_option, auth_option_id  			FROM ' . ACL_OPTIONS_TABLE . " @@ -529,19 +528,19 @@ class acp_permission_roles  		$db->sql_freeresult($result);  		// Get role assignments -		$hold_ary = $auth_admin->get_role_mask($role_id); +		$hold_ary = $this->auth_admin->get_role_mask($role_id);  		// Re-assign permissions  		foreach ($hold_ary as $forum_id => $forum_ary)  		{  			if (isset($forum_ary['users']))  			{ -				$auth_admin->acl_set('user', $forum_id, $forum_ary['users'], $auth_settings, 0, false); +				$this->auth_admin->acl_set('user', $forum_id, $forum_ary['users'], $auth_settings, 0, false);  			}  			if (isset($forum_ary['groups']))  			{ -				$auth_admin->acl_set('group', $forum_id, $forum_ary['groups'], $auth_settings, 0, false); +				$this->auth_admin->acl_set('group', $forum_id, $forum_ary['groups'], $auth_settings, 0, false);  			}  		} @@ -563,6 +562,6 @@ class acp_permission_roles  			WHERE role_id = ' . $role_id;  		$db->sql_query($sql); -		$auth_admin->acl_clear_prefetch(); +		$this->auth_admin->acl_clear_prefetch();  	}  } diff --git a/phpBB/includes/constants.php b/phpBB/includes/constants.php index 8c27d3fd0c..96011f4ec5 100644 --- a/phpBB/includes/constants.php +++ b/phpBB/includes/constants.php @@ -156,6 +156,7 @@ define('PHYSICAL_LINK', 2);  define('CONFIRM_REG', 1);  define('CONFIRM_LOGIN', 2);  define('CONFIRM_POST', 3); +define('CONFIRM_REPORT', 4);  // Categories - Attachments  define('ATTACHMENT_CATEGORY_NONE', 0); diff --git a/phpBB/includes/db/driver/mssql_odbc.php b/phpBB/includes/db/driver/mssql_odbc.php index cde9d332ba..a1d1a5d5dd 100644 --- a/phpBB/includes/db/driver/mssql_odbc.php +++ b/phpBB/includes/db/driver/mssql_odbc.php @@ -253,7 +253,7 @@ class phpbb_db_driver_mssql_odbc extends phpbb_db_driver_mssql_base  	* Fetch current row  	* @note number of bytes returned depends on odbc.defaultlrl php.ini setting. If it is limited to 4K for example only 4K of data is returned max.  	*/ -	function sql_fetchrow($query_id = false, $debug = false) +	function sql_fetchrow($query_id = false)  	{  		global $cache; diff --git a/phpBB/includes/db/driver/mssqlnative.php b/phpBB/includes/db/driver/mssqlnative.php index 6f433e10cf..28fc88298a 100644 --- a/phpBB/includes/db/driver/mssqlnative.php +++ b/phpBB/includes/db/driver/mssqlnative.php @@ -326,7 +326,7 @@ class phpbb_db_driver_mssqlnative extends phpbb_db_driver_mssql_base  					$this->sql_report('stop', $query);  				} -				if ($cache_ttl) +				if ($cache && $cache_ttl)  				{  					$this->open_queries[(int) $this->query_result] = $this->query_result;  					$this->query_result = $cache->sql_save($this, $query, $this->query_result, $cache_ttl); @@ -394,7 +394,7 @@ class phpbb_db_driver_mssqlnative extends phpbb_db_driver_mssql_base  	*/  	function sql_affectedrows()  	{ -		return (!empty($this->query_result)) ? @sqlsrv_rows_affected($this->query_result) : false; +		return ($this->db_connect_id) ? @sqlsrv_rows_affected($this->query_result) : false;  	}  	/** @@ -409,7 +409,7 @@ class phpbb_db_driver_mssqlnative extends phpbb_db_driver_mssql_base  			$query_id = $this->query_result;  		} -		if ($cache->sql_exists($query_id)) +		if ($cache && $cache->sql_exists($query_id))  		{  			return $cache->sql_fetchrow($query_id);  		} @@ -474,9 +474,9 @@ class phpbb_db_driver_mssqlnative extends phpbb_db_driver_mssql_base  			return $cache->sql_freeresult($query_id);  		} -		if (isset($this->open_queries[$query_id])) +		if (isset($this->open_queries[(int) $query_id]))  		{ -			unset($this->open_queries[$query_id]); +			unset($this->open_queries[(int) $query_id]);  			return @sqlsrv_free_stmt($query_id);  		}  		return false; diff --git a/phpBB/includes/functions.php b/phpBB/includes/functions.php index b087e1298b..6a1b3fd4f8 100644 --- a/phpBB/includes/functions.php +++ b/phpBB/includes/functions.php @@ -2345,9 +2345,8 @@ function phpbb_generate_template_pagination($template, $base_url, $block_var_nam  		$tpl_prefix . 'BASE_URL'		=> $base_url,  		'A_' . $tpl_prefix . 'BASE_URL'		=> addslashes($base_url),  		$tpl_prefix . 'PER_PAGE'		=> $per_page, -		$tpl_prefix . 'PREVIOUS_PAGE'	=> $previous_page, -		$tpl_prefix . 'PREV_PAGE'		=> $previous_page, -		$tpl_prefix . 'NEXT_PAGE'		=> ($on_page != $total_pages) ? $base_url . $url_delim . $start_name . '=' . ($on_page * $per_page) : '', +		'U_' . $tpl_prefix . 'PREVIOUS_PAGE'	=> $previous_page, +		'U_' . $tpl_prefix . 'NEXT_PAGE'		=> ($on_page != $total_pages) ? $base_url . $url_delim . $start_name . '=' . ($on_page * $per_page) : '',  		$tpl_prefix . 'TOTAL_PAGES'		=> $total_pages,  		$tpl_prefix . 'CURRENT_PAGE'	=> $on_page,  	); diff --git a/phpBB/includes/search/fulltext_sphinx.php b/phpBB/includes/search/fulltext_sphinx.php index 63e35eb4af..889324bbda 100644 --- a/phpBB/includes/search/fulltext_sphinx.php +++ b/phpBB/includes/search/fulltext_sphinx.php @@ -611,7 +611,7 @@ class phpbb_search_fulltext_sphinx  		$result_count = $result['total_found']; -		if ($start >= $result_count) +		if ($result_count && $start >= $result_count)  		{  			$start = floor(($result_count - 1) / $per_page) * $per_page; diff --git a/phpBB/includes/template/filter.php b/phpBB/includes/template/filter.php index f2bd442010..1c0a56c9f5 100644 --- a/phpBB/includes/template/filter.php +++ b/phpBB/includes/template/filter.php @@ -475,6 +475,7 @@ class phpbb_template_filter extends php_user_filter  	*/  	private function compile_var_tags(&$text_blocks)  	{ +		$is_expr = null;  		$text_blocks = $this->get_varref($text_blocks, $is_expr);  		$lang_replaced = $this->compile_language_tags($text_blocks); diff --git a/phpBB/report.php b/phpBB/report.php index ce9fae13ef..3f2e7a91ff 100644 --- a/phpBB/report.php +++ b/phpBB/report.php @@ -144,9 +144,25 @@ else  	$reported_post_enable_magic_url		= $report_data['reported_post_enable_magic_url'];  } +if ($config['enable_post_confirm'] && !$user->data['is_registered']) +{ +	include($phpbb_root_path . 'includes/captcha/captcha_factory.' . $phpEx); +	$captcha =& phpbb_captcha_factory::get_instance($config['captcha_plugin']); +	$captcha->init(CONFIRM_REPORT); +} + +$error	= array(); +$s_hidden_fields = ''; +  // Submit report?  if ($submit && $reason_id)  { +	$visual_confirmation_response = $captcha->validate(); +	if ($visual_confirmation_response) +	{ +		$error[] = $visual_confirmation_response; +	} +  	$sql = 'SELECT *  		FROM ' . REPORTS_REASONS_TABLE . "  		WHERE reason_id = $reason_id"; @@ -156,96 +172,108 @@ if ($submit && $reason_id)  	if (!$row || (!$report_text && strtolower($row['reason_title']) == 'other'))  	{ -		trigger_error('EMPTY_REPORT'); +		$error[] = $user->lang('EMPTY_REPORT');  	} -	$sql_ary = array( -		'reason_id'							=> (int) $reason_id, -		'post_id'							=> $post_id, -		'pm_id'								=> $pm_id, -		'user_id'							=> (int) $user->data['user_id'], -		'user_notify'						=> (int) $user_notify, -		'report_closed'						=> 0, -		'report_time'						=> (int) time(), -		'report_text'						=> (string) $report_text, -		'reported_post_text'				=> $reported_post_text, -		'reported_post_uid'					=> $reported_post_uid, -		'reported_post_bitfield'			=> $reported_post_bitfield, -		'reported_post_enable_bbcode'		=> $reported_post_enable_bbcode, -		'reported_post_enable_smilies'		=> $reported_post_enable_smilies, -		'reported_post_enable_magic_url'	=> $reported_post_enable_magic_url, -	); - -	$sql = 'INSERT INTO ' . REPORTS_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary); -	$db->sql_query($sql); -	$report_id = $db->sql_nextid(); - -	$phpbb_notifications = $phpbb_container->get('notification_manager'); - -	if ($post_id) +	if (!sizeof($error))  	{ -		$sql = 'UPDATE ' . POSTS_TABLE . ' -			SET post_reported = 1 -			WHERE post_id = ' . $post_id; -		$db->sql_query($sql); - -		if (!$report_data['topic_reported']) +		if (isset($captcha))  		{ -			$sql = 'UPDATE ' . TOPICS_TABLE . ' -				SET topic_reported = 1 -				WHERE topic_id = ' . $report_data['topic_id'] . ' -					OR topic_moved_id = ' . $report_data['topic_id']; -			$db->sql_query($sql); +			$captcha->reset();  		} -		$lang_return = $user->lang['RETURN_TOPIC']; -		$lang_success = $user->lang['POST_REPORTED_SUCCESS']; - -		$phpbb_notifications->add_notifications('report_post', array_merge($report_data, $row, $forum_data, array( -			'report_text'	=> $report_text, -		))); -	} -	else -	{ -		$sql = 'UPDATE ' . PRIVMSGS_TABLE . ' -			SET message_reported = 1 -			WHERE msg_id = ' . $pm_id; -		$db->sql_query($sql); -  		$sql_ary = array( -			'msg_id'		=> $pm_id, -			'user_id'		=> ANONYMOUS, -			'author_id'		=> (int) $report_data['author_id'], -			'pm_deleted'	=> 0, -			'pm_new'		=> 0, -			'pm_unread'		=> 0, -			'pm_replied'	=> 0, -			'pm_marked'		=> 0, -			'pm_forwarded'	=> 0, -			'folder_id'		=> PRIVMSGS_INBOX, +			'reason_id'							=> (int) $reason_id, +			'post_id'							=> $post_id, +			'pm_id'								=> $pm_id, +			'user_id'							=> (int) $user->data['user_id'], +			'user_notify'						=> (int) $user_notify, +			'report_closed'						=> 0, +			'report_time'						=> (int) time(), +			'report_text'						=> (string) $report_text, +			'reported_post_text'				=> $reported_post_text, +			'reported_post_uid'					=> $reported_post_uid, +			'reported_post_bitfield'			=> $reported_post_bitfield, +			'reported_post_enable_bbcode'		=> $reported_post_enable_bbcode, +			'reported_post_enable_smilies'		=> $reported_post_enable_smilies, +			'reported_post_enable_magic_url'	=> $reported_post_enable_magic_url,  		); -		$sql = 'INSERT INTO ' . PRIVMSGS_TO_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary); +		$sql = 'INSERT INTO ' . REPORTS_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary);  		$db->sql_query($sql); +		$report_id = $db->sql_nextid(); -		$lang_return = $user->lang['RETURN_PM']; -		$lang_success = $user->lang['PM_REPORTED_SUCCESS']; +		$phpbb_notifications = $phpbb_container->get('notification_manager'); -		$phpbb_notifications->add_notifications('report_pm', array_merge($report_data, $row, array( -			'report_text'	=> $report_text, -			'from_user_id'	=> $report_data['author_id'], -			'report_id'		=> $report_id, -		))); -	} +		if ($post_id) +		{ +			$sql = 'UPDATE ' . POSTS_TABLE . ' +				SET post_reported = 1 +				WHERE post_id = ' . $post_id; +			$db->sql_query($sql); -	meta_refresh(3, $redirect_url); +			if (!$report_data['topic_reported']) +			{ +				$sql = 'UPDATE ' . TOPICS_TABLE . ' +					SET topic_reported = 1 +					WHERE topic_id = ' . $report_data['topic_id'] . ' +						OR topic_moved_id = ' . $report_data['topic_id']; +				$db->sql_query($sql); +			} + +			$lang_return = $user->lang['RETURN_TOPIC']; +			$lang_success = $user->lang['POST_REPORTED_SUCCESS']; + +			$phpbb_notifications->add_notifications('report_post', array_merge($report_data, $row, $forum_data, array( +				'report_text'	=> $report_text, +			))); +		} +		else +		{ +			$sql = 'UPDATE ' . PRIVMSGS_TABLE . ' +				SET message_reported = 1 +				WHERE msg_id = ' . $pm_id; +			$db->sql_query($sql); + +			$sql_ary = array( +				'msg_id'		=> $pm_id, +				'user_id'		=> ANONYMOUS, +				'author_id'		=> (int) $report_data['author_id'], +				'pm_deleted'	=> 0, +				'pm_new'		=> 0, +				'pm_unread'		=> 0, +				'pm_replied'	=> 0, +				'pm_marked'		=> 0, +				'pm_forwarded'	=> 0, +				'folder_id'		=> PRIVMSGS_INBOX, +			); + +			$sql = 'INSERT INTO ' . PRIVMSGS_TO_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary); +			$db->sql_query($sql); + +			$lang_return = $user->lang['RETURN_PM']; +			$lang_success = $user->lang['PM_REPORTED_SUCCESS']; + +			$phpbb_notifications->add_notifications('report_pm', array_merge($report_data, $row, array( +				'report_text'	=> $report_text, +				'from_user_id'	=> $report_data['author_id'], +				'report_id'		=> $report_id, +			))); +		} + +		meta_refresh(3, $redirect_url); -	$message = $lang_success . '<br /><br />' . sprintf($lang_return, '<a href="' . $redirect_url . '">', '</a>'); -	if ($return_forum_url) +		$message = $lang_success . '<br /><br />' . sprintf($lang_return, '<a href="' . $redirect_url . '">', '</a>'); +		if ($return_forum_url) +		{ +			$message .= '<br /><br />' . sprintf($user->lang['RETURN_FORUM'], '<a href="' . $return_forum_url . '">', '</a>'); +		} +		trigger_error($message); +	} +	else if (isset($captcha) && $captcha->is_solved() !== false)  	{ -		$message .= '<br /><br />' . sprintf($user->lang['RETURN_FORUM'], '<a href="' . $return_forum_url . '">', '</a>'); +		$s_hidden_fields .= build_hidden_fields($captcha->get_hidden_fields());  	} -	trigger_error($message);  }  // Generate the reasons @@ -253,10 +281,20 @@ display_reasons($reason_id);  $page_title = ($pm_id) ? $user->lang['REPORT_MESSAGE'] : $user->lang['REPORT_POST']; +if (isset($captcha) && $captcha->is_solved() === false) +{ +	$template->assign_vars(array( +		'S_CONFIRM_CODE'	=> true, +		'CAPTCHA_TEMPLATE'	=> $captcha->get_template(), +	)); +} +  $template->assign_vars(array( +	'ERROR'				=> (sizeof($error)) ? implode('<br />', $error) : '',  	'S_REPORT_POST'		=> ($pm_id) ? false : true,  	'REPORT_TEXT'		=> $report_text,  	'S_REPORT_ACTION'	=> append_sid("{$phpbb_root_path}report.$phpEx", 'f=' . $forum_id . '&p=' . $post_id . '&pm=' . $pm_id), +	'S_HIDDEN_FIELDS'	=> (sizeof($s_hidden_fields)) ? $s_hidden_fields : null,  	'S_NOTIFY'			=> $user_notify,  	'S_CAN_NOTIFY'		=> ($user->data['is_registered']) ? true : false) diff --git a/phpBB/styles/prosilver/template/mcp_forum.html b/phpBB/styles/prosilver/template/mcp_forum.html index ac686932b7..db5525fcd0 100644 --- a/phpBB/styles/prosilver/template/mcp_forum.html +++ b/phpBB/styles/prosilver/template/mcp_forum.html @@ -85,8 +85,8 @@  	<!-- ENDIF -->  	<fieldset class="display-options"> -		<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> -		<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +		<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +		<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF -->  		<label>{L_DISPLAY_TOPICS}{L_COLON} {S_SELECT_SORT_DAYS}</label>  		<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label>  		<label>{S_SELECT_SORT_DIR} <input type="submit" name="sort" value="{L_GO}" class="button2" /></label> diff --git a/phpBB/styles/prosilver/template/mcp_logs.html b/phpBB/styles/prosilver/template/mcp_logs.html index c9db4e8afa..492c8cf201 100644 --- a/phpBB/styles/prosilver/template/mcp_logs.html +++ b/phpBB/styles/prosilver/template/mcp_logs.html @@ -54,8 +54,8 @@  	<!-- IF .log -->  		<fieldset class="display-options"> -			<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> -			<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +			<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +			<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF -->  			<label>{L_DISPLAY_POSTS}{L_COLON} {S_SELECT_SORT_DAYS}</label>  			<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label>  			<label>{S_SELECT_SORT_DIR}</label> diff --git a/phpBB/styles/prosilver/template/mcp_notes_user.html b/phpBB/styles/prosilver/template/mcp_notes_user.html index 328d12a04f..1738e45045 100644 --- a/phpBB/styles/prosilver/template/mcp_notes_user.html +++ b/phpBB/styles/prosilver/template/mcp_notes_user.html @@ -95,8 +95,8 @@  	<hr />  	<fieldset class="display-options"> -		<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> -		<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +		<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +		<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF -->  		<label>{L_DISPLAY_LOG}{L_COLON} {S_SELECT_SORT_DAYS}</label>  		<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label><label>{S_SELECT_SORT_DIR}</label>  		<input type="submit" name="sort" value="{L_GO}" class="button2" /> diff --git a/phpBB/styles/prosilver/template/mcp_queue.html b/phpBB/styles/prosilver/template/mcp_queue.html index 4d20804e66..d630606175 100644 --- a/phpBB/styles/prosilver/template/mcp_queue.html +++ b/phpBB/styles/prosilver/template/mcp_queue.html @@ -67,8 +67,8 @@  		</ul>  		<fieldset class="display-options"> -			<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> -			<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +			<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +			<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF -->  			<label>{L_DISPLAY_POSTS}{L_COLON} {S_SELECT_SORT_DAYS}</label>  			<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label><label>{S_SELECT_SORT_DIR}</label>  			<!-- IF TOPIC_ID --><label><input type="checkbox" class="radio" name="t" value="{TOPIC_ID}" checked="checked" />  <strong>{L_ONLY_TOPIC}</strong></label><!-- ENDIF --> diff --git a/phpBB/styles/prosilver/template/mcp_reports.html b/phpBB/styles/prosilver/template/mcp_reports.html index 9a70b4a62a..902744fe25 100644 --- a/phpBB/styles/prosilver/template/mcp_reports.html +++ b/phpBB/styles/prosilver/template/mcp_reports.html @@ -72,8 +72,8 @@  		</ul>  		<fieldset class="display-options"> -			<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> -			<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +			<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +			<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF -->  			<label>{L_DISPLAY_POSTS}{L_COLON} {S_SELECT_SORT_DAYS}</label>  			<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label><label>{S_SELECT_SORT_DIR}</label>  			<!-- IF TOPIC_ID --><label><input type="checkbox" class="radio" name="t" value="{TOPIC_ID}" checked="checked" />  <strong>{L_ONLY_TOPIC}</strong></label><!-- ENDIF --> diff --git a/phpBB/styles/prosilver/template/memberlist_body.html b/phpBB/styles/prosilver/template/memberlist_body.html index 17dc2c33c0..07a7e2e182 100644 --- a/phpBB/styles/prosilver/template/memberlist_body.html +++ b/phpBB/styles/prosilver/template/memberlist_body.html @@ -140,8 +140,8 @@  <!-- IF S_IN_SEARCH_POPUP and not S_SEARCH_USER -->  <fieldset class="display-options"> -	<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> -	<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +	<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +	<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF -->  	<label for="sk">{L_SELECT_SORT_METHOD}{L_COLON} <select name="sk" id="sk">{S_MODE_SELECT}</select></label>  	<label for="sd">{L_ORDER} <select name="sd" id="sd">{S_ORDER_SELECT}</select> <input type="submit" name="sort" value="{L_SUBMIT}" class="button2" /></label>  </fieldset> diff --git a/phpBB/styles/prosilver/template/memberlist_search.html b/phpBB/styles/prosilver/template/memberlist_search.html index 61bfd630ff..a4468b4af4 100644 --- a/phpBB/styles/prosilver/template/memberlist_search.html +++ b/phpBB/styles/prosilver/template/memberlist_search.html @@ -74,6 +74,10 @@ function insert_single(user)  		<dt><label for="msn">{L_MSNM}{L_COLON}</label></dt>  		<dd><input type="text" name="msn" id="msn" value="{MSNM}" class="inputbox" /></dd>  	</dl> +	<dl> +		<dt><label for="jabber">{L_JABBER}:</label></dt> +		<dd><input type="text" name="jabber" id="jabber" value="{JABBER}" class="inputbox" /></dd> +	</dl>  	</fieldset>  	<fieldset class="fields1 column2"> diff --git a/phpBB/styles/prosilver/template/report_body.html b/phpBB/styles/prosilver/template/report_body.html index 4cb03dc51c..2a5e6c9d0e 100644 --- a/phpBB/styles/prosilver/template/report_body.html +++ b/phpBB/styles/prosilver/template/report_body.html @@ -10,6 +10,7 @@  		<p><!-- IF S_REPORT_POST -->{L_REPORT_POST_EXPLAIN}<!-- ELSE -->{L_REPORT_MESSAGE_EXPLAIN}<!-- ENDIF --></p>  		<fieldset> +		<!-- IF ERROR --><dl><dd class="error">{ERROR}</dd></dl><!-- ENDIF -->  		<dl class="fields2">  			<dt><label for="reason_id">{L_REASON}{L_COLON}</label></dt>  			<dd><select name="reason_id" id="reason_id" class="full"><!-- BEGIN reason --><option value="{reason.ID}"<!-- IF reason.S_SELECTED --> selected="selected"<!-- ENDIF -->>{reason.DESCRIPTION}</option><!-- END reason --></select></dd> @@ -27,6 +28,9 @@  			<dt><label for="report_text">{L_MORE_INFO}{L_COLON}</label><br /><span>{L_CAN_LEAVE_BLANK}</span></dt>  			<dd><textarea name="report_text" id="report_text" rows="10" cols="76" class="inputbox">{REPORT_TEXT}</textarea></dd>  		</dl> +		<!-- IF CAPTCHA_TEMPLATE --> +			<!-- INCLUDE {CAPTCHA_TEMPLATE} --> +		<!-- ENDIF -->  		</fieldset>  	</div> diff --git a/phpBB/styles/prosilver/template/search_results.html b/phpBB/styles/prosilver/template/search_results.html index 1132e5295a..e31c278a4b 100644 --- a/phpBB/styles/prosilver/template/search_results.html +++ b/phpBB/styles/prosilver/template/search_results.html @@ -154,8 +154,8 @@  	<form method="post" action="{S_SEARCH_ACTION}">  	<fieldset class="display-options"> -		<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> -		<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +		<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +		<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF -->  		<!-- IF S_SELECT_SORT_DAYS or S_SELECT_SORT_KEY -->  			<label><!-- IF S_SHOW_TOPICS -->{L_DISPLAY_POSTS}<!-- ELSE -->{L_SORT_BY}</label><label><!-- ENDIF --> {S_SELECT_SORT_DAYS}<!-- IF S_SELECT_SORT_KEY --></label> <label>{S_SELECT_SORT_KEY}</label>  			<label>{S_SELECT_SORT_DIR}<!-- ENDIF --> <input type="submit" name="sort" value="{L_GO}" class="button2" /></label> diff --git a/phpBB/styles/prosilver/template/ucp_attachments.html b/phpBB/styles/prosilver/template/ucp_attachments.html index 6e1bdfdd57..feb04278dc 100644 --- a/phpBB/styles/prosilver/template/ucp_attachments.html +++ b/phpBB/styles/prosilver/template/ucp_attachments.html @@ -51,8 +51,8 @@  		</ul>  		<fieldset class="display-options"> -			<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> -			<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +			<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +			<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF -->  			<label for="sk">{L_SORT_BY}{L_COLON} <select name="sk" id="sk">{S_SORT_OPTIONS}</select></label>   			<label><select name="sd" id="sd">{S_ORDER_SELECT}</select></label>  			<input class="button2" type="submit" name="sort" value="{L_SORT}" /> diff --git a/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html b/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html index 00b735fae6..c5078df268 100644 --- a/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html +++ b/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html @@ -122,8 +122,8 @@  	<!-- IF FOLDER_CUR_MESSAGES neq 0 -->  	<fieldset class="display-options"> -		<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> -		<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +		<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +		<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF -->  		<label>{L_DISPLAY}{L_COLON} {S_SELECT_SORT_DAYS}</label>  		<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label>  		<label>{S_SELECT_SORT_DIR} <input type="submit" name="sort" value="{L_GO}" class="button2" /></label> diff --git a/phpBB/styles/prosilver/template/viewforum_body.html b/phpBB/styles/prosilver/template/viewforum_body.html index dd16b27988..9cbe7bc45a 100644 --- a/phpBB/styles/prosilver/template/viewforum_body.html +++ b/phpBB/styles/prosilver/template/viewforum_body.html @@ -192,8 +192,8 @@  <!-- IF S_SELECT_SORT_DAYS and not S_DISPLAY_ACTIVE -->  	<form method="post" action="{S_FORUM_ACTION}">  		<fieldset class="display-options"> -			<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> -			<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +			<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +			<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF -->  	<!-- IF not S_IS_BOT -->  			<label>{L_DISPLAY_TOPICS}{L_COLON} {S_SELECT_SORT_DAYS}</label>  			<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label> diff --git a/phpBB/styles/prosilver/template/viewonline_body.html b/phpBB/styles/prosilver/template/viewonline_body.html index cb19a40d8f..74e891f7d0 100644 --- a/phpBB/styles/prosilver/template/viewonline_body.html +++ b/phpBB/styles/prosilver/template/viewonline_body.html @@ -47,9 +47,9 @@  	</div>  </div> -<!-- IF PREVIOUS_PAGE or NEXT_PAGE --> +<!-- IF U_PREVIOUS_PAGE or U_NEXT_PAGE -->  <fieldset class="display-options right-box"> -	<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ELSE -->{L_PREVIOUS}<!-- ENDIF --> • <!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ELSE -->{L_NEXT}<!-- ENDIF --> +	<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ELSE -->{L_PREVIOUS}<!-- ENDIF --> • <!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ELSE -->{L_NEXT}<!-- ENDIF -->  </fieldset>  <!-- ENDIF --> diff --git a/phpBB/styles/prosilver/template/viewtopic_body.html b/phpBB/styles/prosilver/template/viewtopic_body.html index 5f999ade0c..9c0743d04d 100644 --- a/phpBB/styles/prosilver/template/viewtopic_body.html +++ b/phpBB/styles/prosilver/template/viewtopic_body.html @@ -245,12 +245,12 @@  <!-- IF S_QUICK_REPLY -->  	<!-- INCLUDE quickreply_editor.html -->  <!-- ENDIF --> -<!-- IF S_NUM_POSTS > 1 or PREVIOUS_PAGE or NEXT_PAGE --> +<!-- IF S_NUM_POSTS > 1 or U_PREVIOUS_PAGE or U_NEXT_PAGE -->  	<form id="viewtopic" method="post" action="{S_TOPIC_ACTION}">  	<fieldset class="display-options" style="margin-top: 0; "> -		<!-- IF PREVIOUS_PAGE --><a href="{PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> -		<!-- IF NEXT_PAGE --><a href="{NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF --> +		<!-- IF U_PREVIOUS_PAGE --><a href="{U_PREVIOUS_PAGE}" class="left-box arrow-{S_CONTENT_FLOW_BEGIN}">{L_PREVIOUS}</a><!-- ENDIF --> +		<!-- IF U_NEXT_PAGE --><a href="{U_NEXT_PAGE}" class="right-box arrow-{S_CONTENT_FLOW_END}">{L_NEXT}</a><!-- ENDIF -->  		<!-- IF not S_IS_BOT -->  		<label>{L_DISPLAY_POSTS}{L_COLON} {S_SELECT_SORT_DAYS}</label>  		<label>{L_SORT_BY} {S_SELECT_SORT_KEY}</label> <label>{S_SELECT_SORT_DIR} <input type="submit" name="sort" value="{L_GO}" class="button2" /></label> diff --git a/phpBB/styles/subsilver2/template/report_body.html b/phpBB/styles/subsilver2/template/report_body.html index 9ed510bb9f..906a957ef4 100644 --- a/phpBB/styles/subsilver2/template/report_body.html +++ b/phpBB/styles/subsilver2/template/report_body.html @@ -6,6 +6,11 @@  <tr>  	<th colspan="2"><!-- IF S_REPORT_POST -->{L_REPORT_POST}<!-- ELSE -->{L_REPORT_MESSAGE}<!-- ENDIF --></th>  </tr> +<!-- IF ERROR --> +	<tr> +		<td class="row3" colspan="2" align="center"><span class="genmed error">{ERROR}</span></td> +	</tr> +<!-- ENDIF -->  <tr>  	<td class="row3" colspan="2"><span class="gensmall"><!-- IF S_REPORT_POST -->{L_REPORT_POST_EXPLAIN}<!-- ELSE -->{L_REPORT_MESSAGE_EXPLAIN}<!-- ENDIF --></span></td>  </tr> @@ -25,6 +30,9 @@  	<td class="row1" valign="top"><span class="gen"><b>{L_MORE_INFO}{L_COLON}</b></span><br /><span class="gensmall">{L_CAN_LEAVE_BLANK}</span></td>  	<td class="row2"><textarea class="post" name="report_text" rows="10" cols="50">{REPORT_TEXT}</textarea></td>  </tr> +<!-- IF CAPTCHA_TEMPLATE --> +			<!-- INCLUDE {CAPTCHA_TEMPLATE} --> +<!-- ENDIF -->	  <tr>  	<td class="cat" colspan="2" align="center"><input type="submit" name="submit" class="btnmain" value="{L_SUBMIT}" /> <input type="submit" name="cancel" class="btnlite" value="{L_CANCEL}" /></td>  </tr> diff --git a/tests/RUNNING_TESTS.md b/tests/RUNNING_TESTS.md index f89c1fefeb..f2688ab675 100644 --- a/tests/RUNNING_TESTS.md +++ b/tests/RUNNING_TESTS.md @@ -50,9 +50,11 @@ Database Tests  By default all tests requiring a database connection will use sqlite. If you  do not have sqlite installed the tests will be skipped. If you wish to run the  tests on a different database you have to create a test_config.php file within -your tests directory following the same format as phpBB's config.php. An -example for mysqli can be found below. More information on configuration -options can be found on the wiki (see below). +your tests directory following the same format as phpBB's config.php. Testing +makes use of a seperate database defined in this config file and before running +the tests each time this database is deleted. An example for mysqli can be +found below. More information on configuration options can be found on the +wiki (see below).      <?php      $dbms = 'phpbb_db_driver_mysqli'; @@ -132,8 +134,36 @@ only want the slow tests, run:      $ phpBB/vendor/bin/phpunit --group slow +Functional tests +----------------- + +Functional tests test software the way a user would. They simulate a user +browsing the website, but they do these steps in an automated way. +phpBB allows you to write such tests. + +Running +======= + +Running the tests requires your phpBB3 repository to be accessible through a +local web server. You will need to supply the URL to the webserver in +the 'tests/test_config.php' file. This is as simple as defining the +'$phpbb_functional_url' variable, which contains the URL for the directory containing +the board. Make sure you include the trailing slash. Note that without extensive +changes to the test framework, you cannot use a board outside of the repository +on which to run tests. + +    $phpbb_functional_url = 'http://localhost/phpBB3/'; + +To then run the tests, you run PHPUnit, but use the phpunit.xml.functional +config file instead of the default one. Specify this through the "-c" option: + +    $ phpBB/vendor/bin/phpunit -c phpunit.xml.functional + +This will change your board's config.php file, but it makes a backup at +config_dev.php, so you can restore it after the test run is complete. +  More Information  ================  Further information is available on phpbb wiki: -http://wiki.phpbb.com/Unit_Tests +http://wiki.phpbb.com/Automated_Tests diff --git a/tests/functional/paging_test.php b/tests/functional/paging_test.php new file mode 100644 index 0000000000..d5adc6ad0a --- /dev/null +++ b/tests/functional/paging_test.php @@ -0,0 +1,39 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2013 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @group functional +*/ +class phpbb_functional_paging_test extends phpbb_functional_test_case +{ + +	public function test_pagination() +	{ +		$this->login(); + +		$post = $this->create_topic(2, 'Test Topic 1', 'This is a test topic posted by the testing framework.'); +		for ($post_id = 1; $post_id < 20; $post_id++) +		{ +			$this->create_post(2, $post['topic_id'], 'Re: Test Topic 1', 'This is a test post no' . $post_id . ' posted by the testing framework.'); +		} +		$crawler = self::request('GET', "viewtopic.php?t={$post['topic_id']}&sid={$this->sid}"); +		$this->assertContains('post no9', $crawler->text()); +		$this->assertNotContains('post no19', $crawler->text()); + +		$next_link = $crawler->filter('#viewtopic > fieldset > a.arrow-right')->attr('href'); +		$crawler = self::request('GET', $next_link); +		$this->assertContains('post no19', $crawler->text()); +		$this->assertNotContains('post no9', $crawler->text()); + +		$prev_link = $crawler->filter('#viewtopic > fieldset > a.arrow-left')->attr('href'); +		$crawler = self::request('GET', $prev_link); +		$this->assertContains('post no9', $crawler->text()); +		$this->assertNotContains('post no19', $crawler->text()); +	} +} diff --git a/tests/functional/posting_test.php b/tests/functional/posting_test.php index 9bcfcc2fda..7fd1e4fdcf 100644 --- a/tests/functional/posting_test.php +++ b/tests/functional/posting_test.php @@ -32,105 +32,4 @@ class phpbb_functional_posting_test extends phpbb_functional_test_case  		$crawler = self::request('GET', "posting.php?mode=quote&f=2&t={$post2['topic_id']}&p={$post2['post_id']}&sid={$this->sid}");  		$this->assertContains('This is a test post posted by the testing framework.', $crawler->filter('html')->text());  	} - -	/** -	* Creates a topic -	*  -	* Be sure to login before creating -	*  -	* @param int $forum_id -	* @param string $subject -	* @param string $message -	* @param array $additional_form_data Any additional form data to be sent in the request -	* @return array post_id, topic_id -	*/ -	public function create_topic($forum_id, $subject, $message, $additional_form_data = array()) -	{ -		$posting_url = "posting.php?mode=post&f={$forum_id}&sid={$this->sid}"; - -		$form_data = array_merge(array( -			'subject'		=> $subject, -			'message'		=> $message, -			'post'			=> true, -		), $additional_form_data); - -		return self::submit_post($posting_url, 'POST_TOPIC', $form_data); -	} - -	/** -	* Creates a post -	*  -	* Be sure to login before creating -	*  -	* @param int $forum_id -	* @param string $subject -	* @param string $message -	* @param array $additional_form_data Any additional form data to be sent in the request -	* @return array post_id, topic_id -	*/ -	public function create_post($forum_id, $topic_id, $subject, $message, $additional_form_data = array()) -	{ -		$posting_url = "posting.php?mode=reply&f={$forum_id}&t={$topic_id}&sid={$this->sid}"; - -		$form_data = array_merge(array( -			'subject'		=> $subject, -			'message'		=> $message, -			'post'			=> true, -		), $additional_form_data); - -		return self::submit_post($posting_url, 'POST_REPLY', $form_data); -	} -	 -	/** -	* Helper for submitting posts -	*  -	* @param string $posting_url -	* @param string $posting_contains -	* @param array $form_data -	* @return array post_id, topic_id -	*/ -	protected function submit_post($posting_url, $posting_contains, $form_data) -	{ -		$this->add_lang('posting'); - -		$crawler = self::request('GET', $posting_url); -		$this->assertContains($this->lang($posting_contains), $crawler->filter('html')->text()); - -		$hidden_fields = array( -			$crawler->filter('[type="hidden"]')->each(function ($node, $i) { -				return array('name' => $node->getAttribute('name'), 'value' => $node->getAttribute('value')); -			}), -		); - -		foreach ($hidden_fields as $fields) -		{ -			foreach($fields as $field) -			{ -				$form_data[$field['name']] = $field['value']; -			} -		} - -		// Bypass time restriction that said that if the lastclick time (i.e. time when the form was opened) -		// is not at least 2 seconds before submission, cancel the form -		$form_data['lastclick'] = 0; - -		// I use a request because the form submission method does not allow you to send data that is not -		// contained in one of the actual form fields that the browser sees (i.e. it ignores "hidden" inputs) -		// Instead, I send it as a request with the submit button "post" set to true. -		$crawler = self::request('POST', $posting_url, $form_data); -		$this->assertContains($this->lang('POST_STORED'), $crawler->filter('html')->text()); - -		$url = $crawler->selectLink($this->lang('VIEW_MESSAGE', '', ''))->link()->getUri(); -		 -		$matches = $topic_id = $post_id = false; -		preg_match_all('#&t=([0-9]+)(&p=([0-9]+))?#', $url, $matches); -		 -		$topic_id = (int) (isset($matches[1][0])) ? $matches[1][0] : 0; -		$post_id = (int) (isset($matches[3][0])) ? $matches[3][0] : 0; - -		return array( -			'topic_id'	=> $topic_id, -			'post_id'	=> $post_id, -		); -	}  } diff --git a/tests/functional/report_post_captcha.php b/tests/functional/report_post_captcha.php new file mode 100644 index 0000000000..af713775c5 --- /dev/null +++ b/tests/functional/report_post_captcha.php @@ -0,0 +1,61 @@ +<?php +/** + * + * @package testing + * @copyright (c) 2013 phpBB Group + * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 + * + */ + +/** + * @group functional + */ +class phpbb_functional_report_post_captcha_test extends phpbb_functional_test_case +{ +	public function test_user_report_post() +	{ +		$this->login(); +		$crawler = self::request('GET', 'report.php?f=2&p=1'); +		$this->assertNotContains($this->lang('CONFIRM_CODE'), $crawler->filter('html')->text()); +	} + +	public function test_guest_report_post() +	{ +		$crawler = self::request('GET', 'report.php?f=2&p=1'); +		$this->add_lang('mcp'); +		$this->assertContains($this->lang('USER_CANNOT_REPORT'), $crawler->filter('html')->text()); + +		$this->set_reporting_guest(1); +		$crawler = self::request('GET', 'report.php?f=2&p=1'); +		$this->assertContains($this->lang('CONFIRM_CODE'), $crawler->filter('html')->text()); +		$this->set_reporting_guest(-1); +	} + +	protected function set_reporting_guest($report_post_allowed) +	{ +		$this->login(); +		$this->admin_login(); + +		$crawler = self::request('GET', 'adm/index.php?i=permissions&icat=12&mode=setting_group_local&sid=' . $this->sid); +		$form = $crawler->selectButton('Submit')->form(); +		$values = $form->getValues(); +		$values["group_id[0]"] = 1; +		$form->setValues($values); +		$crawler = self::submit($form); + +		$form = $crawler->selectButton('Submit')->form(); +		$values = $form->getValues(); +		$values["forum_id"] = 2; +		$form->setValues($values); +		$crawler = self::submit($form); + +		$this->add_lang('acp/permissions'); +		$form = $crawler->selectButton($this->lang('APPLY_ALL_PERMISSIONS'))->form(); +		$values = $form->getValues(); +		$values["setting[1][2][f_report]"] = $report_post_allowed; +		$form->setValues($values); +		$crawler = self::submit($form); + +		$crawler = self::request('GET', 'ucp.php?mode=logout&sid=' . $this->sid); +	} +} diff --git a/tests/notification/fixtures/notification.xml b/tests/notification/fixtures/notification.xml index 38e5f811dd..c7b2d03ff1 100644 --- a/tests/notification/fixtures/notification.xml +++ b/tests/notification/fixtures/notification.xml @@ -1,5 +1,13 @@  <?xml version="1.0" encoding="UTF-8" ?>  <dataset> +	<table name="phpbb_bookmarks"> +	</table>  	<table name="phpbb_notifications">  	</table> +	<table name="phpbb_notification_types"> +	</table> +	<table name="phpbb_topics_watch"> +	</table> +	<table name="phpbb_user_notifications"> +	</table>  </dataset> diff --git a/tests/session/init_test.php b/tests/session/creation_test.php index 43af8c554f..fde76d6b06 100644 --- a/tests/session/init_test.php +++ b/tests/session/creation_test.php @@ -9,7 +9,7 @@  require_once dirname(__FILE__) . '/testable_factory.php'; -class phpbb_session_init_test extends phpbb_database_test_case +class phpbb_session_creation_test extends phpbb_database_test_case  {  	public function getDataSet()  	{ @@ -47,10 +47,11 @@ class phpbb_session_init_test extends phpbb_database_test_case  		$this->assertSqlResultEquals(  			array(array('session_user_id' => 3)),  			$sql, -			'Check if exacly one session for user id 3 was created' +			'Check if exactly one session for user id 3 was created'  		); -		$cookie_expire = $session->time_now + 31536000; // default is one year +		$one_year_in_seconds = 365 * 24 * 60 * 60; +		$cookie_expire = $session->time_now + $one_year_in_seconds;  		$session->check_cookies($this, array(  			'u' => array(null, $cookie_expire), diff --git a/tests/template/template_test_case.php b/tests/template/template_test_case.php index 3c997cb00e..5d38ebed67 100644 --- a/tests/template/template_test_case.php +++ b/tests/template/template_test_case.php @@ -83,9 +83,14 @@ class phpbb_template_template_test_case extends phpbb_test_case  			$this->markTestSkipped("Template cache directory ({$template_cache_dir}) is not writable.");  		} -		foreach (glob($this->template->cachepath . '*') as $file) +		$file_array = scandir($template_cache_dir); +		$file_prefix = basename($this->template->cachepath); +		foreach ($file_array as $file)  		{ -			unlink($file); +			if (strpos($file, $file_prefix) === 0) +			{ +				unlink($template_cache_dir . '/' . $file); +			}  		}  		$this->setup_engine(); @@ -95,9 +100,15 @@ class phpbb_template_template_test_case extends phpbb_test_case  	{  		if (is_object($this->template))  		{ -			foreach (glob($this->template->cachepath . '*') as $file) +			$template_cache_dir = dirname($this->template->cachepath); +			$file_array = scandir($template_cache_dir); +			$file_prefix = basename($this->template->cachepath); +			foreach ($file_array as $file)  			{ -				unlink($file); +				if (strpos($file, $file_prefix) === 0) +				{ +					unlink($template_cache_dir . '/' . $file); +				}  			}  		}  	} diff --git a/tests/test_framework/phpbb_functional_test_case.php b/tests/test_framework/phpbb_functional_test_case.php index 97fe147d8e..7e2e750e30 100644 --- a/tests/test_framework/phpbb_functional_test_case.php +++ b/tests/test_framework/phpbb_functional_test_case.php @@ -219,15 +219,19 @@ class phpbb_functional_test_case extends phpbb_test_case  		self::recreate_database(self::$config); -		if (file_exists($phpbb_root_path . "config.$phpEx")) +		$config_file = $phpbb_root_path . "config.$phpEx"; +		$config_file_dev = $phpbb_root_path . "config_dev.$phpEx"; +		$config_file_test = $phpbb_root_path . "config_test.$phpEx"; + +		if (file_exists($config_file))  		{ -			if (!file_exists($phpbb_root_path . "config_dev.$phpEx")) +			if (!file_exists($config_file_dev))  			{ -				rename($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "config_dev.$phpEx"); +				rename($config_file, $config_file_dev);  			}  			else  			{ -				unlink($phpbb_root_path . "config.$phpEx"); +				unlink($config_file);  			}  		} @@ -251,10 +255,12 @@ class phpbb_functional_test_case extends phpbb_test_case  		self::assertContains('Welcome to Installation', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(); +		// install/index.php?mode=install&sub=requirements  		$crawler = self::submit($form);  		self::assertContains('Installation compatibility', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(); +		// install/index.php?mode=install&sub=database  		$crawler = self::submit($form);  		self::assertContains('Database configuration', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(array( @@ -268,10 +274,12 @@ class phpbb_functional_test_case extends phpbb_test_case  			'table_prefix'	=> self::$config['table_prefix'],  		)); +		// install/index.php?mode=install&sub=database  		$crawler = self::submit($form);  		self::assertContains('Successful connection', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(); +		// install/index.php?mode=install&sub=administrator  		$crawler = self::submit($form);  		self::assertContains('Administrator configuration', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(array( @@ -282,16 +290,38 @@ class phpbb_functional_test_case extends phpbb_test_case  			'board_email'	=> 'nobody@example.com',  		)); +		// install/index.php?mode=install&sub=administrator  		$crawler = self::submit($form);  		self::assertContains('Tests passed', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(); -		$crawler = self::submit($form); -		self::assertContains('The configuration file has been written.', $crawler->filter('#main')->text()); -		file_put_contents($phpbb_root_path . "config.$phpEx", phpbb_create_config_file_data(self::$config, self::$config['dbms'], true, true)); -		$form = $crawler->selectButton('submit')->form(); +		// We have to skip install/index.php?mode=install&sub=config_file +		// because that step will create a config.php file if phpBB has the +		// permission to do so. We have to create the config file on our own +		// in order to get the DEBUG constants defined. +		$config_php_data = phpbb_create_config_file_data(self::$config, self::$config['dbms'], true, true); +		$config_created = file_put_contents($config_file, $config_php_data) !== false; +		if (!$config_created) +		{ +			self::markTestSkipped("Could not write $config_file file."); +		} -		$crawler = self::submit($form); +		// We also have to create a install lock that is normally created by +		// the installer. The file will be removed by the final step of the +		// installer. +		$install_lock_file = $phpbb_root_path . 'cache/install_lock'; +		$lock_created = file_put_contents($install_lock_file, '') !== false; +		if (!$lock_created) +		{ +			self::markTestSkipped("Could not create $lock_created file."); +		} +		@chmod($install_lock_file, 0666); + +		// install/index.php?mode=install&sub=advanced +		$form_data = $form->getValues(); +		unset($form_data['submit']); + +		$crawler = self::request('POST', 'install/index.php?mode=install&sub=advanced', $form_data);  		self::assertContains('The settings on this page are only necessary to set if you know that you require something different from the default.', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(array(  			'email_enable'		=> true, @@ -308,14 +338,17 @@ class phpbb_functional_test_case extends phpbb_test_case  			'script_path'		=> $parseURL['path'],  		)); +		// install/index.php?mode=install&sub=create_table  		$crawler = self::submit($form);  		self::assertContains('The database tables used by phpBB', $crawler->filter('#main')->text());  		self::assertContains('have been created and populated with some initial data.', $crawler->filter('#main')->text());  		$form = $crawler->selectButton('submit')->form(); +		// install/index.php?mode=install&sub=final  		$crawler = self::submit($form);  		self::assertContains('You have successfully installed', $crawler->text()); -		copy($phpbb_root_path . "config.$phpEx", $phpbb_root_path . "config_test.$phpEx"); + +		copy($config_file, $config_file_test);  	}  	static private function recreate_database($config) @@ -703,4 +736,105 @@ class phpbb_functional_test_case extends phpbb_test_case  		return $result;  	} + +	/** +	* Creates a topic +	* +	* Be sure to login before creating +	* +	* @param int $forum_id +	* @param string $subject +	* @param string $message +	* @param array $additional_form_data Any additional form data to be sent in the request +	* @return array post_id, topic_id +	*/ +	public function create_topic($forum_id, $subject, $message, $additional_form_data = array()) +	{ +		$posting_url = "posting.php?mode=post&f={$forum_id}&sid={$this->sid}"; + +		$form_data = array_merge(array( +			'subject'		=> $subject, +			'message'		=> $message, +			'post'			=> true, +		), $additional_form_data); + +		return self::submit_post($posting_url, 'POST_TOPIC', $form_data); +	} + +	/** +	* Creates a post +	* +	* Be sure to login before creating +	* +	* @param int $forum_id +	* @param string $subject +	* @param string $message +	* @param array $additional_form_data Any additional form data to be sent in the request +	* @return array post_id, topic_id +	*/ +	public function create_post($forum_id, $topic_id, $subject, $message, $additional_form_data = array()) +	{ +		$posting_url = "posting.php?mode=reply&f={$forum_id}&t={$topic_id}&sid={$this->sid}"; + +		$form_data = array_merge(array( +			'subject'		=> $subject, +			'message'		=> $message, +			'post'			=> true, +		), $additional_form_data); + +		return self::submit_post($posting_url, 'POST_REPLY', $form_data); +	} + +	/** +	* Helper for submitting posts +	* +	* @param string $posting_url +	* @param string $posting_contains +	* @param array $form_data +	* @return array post_id, topic_id +	*/ +	protected function submit_post($posting_url, $posting_contains, $form_data) +	{ +		$this->add_lang('posting'); + +		$crawler = self::request('GET', $posting_url); +		$this->assertContains($this->lang($posting_contains), $crawler->filter('html')->text()); + +		$hidden_fields = array( +			$crawler->filter('[type="hidden"]')->each(function ($node, $i) { +				return array('name' => $node->getAttribute('name'), 'value' => $node->getAttribute('value')); +			}), +		); + +		foreach ($hidden_fields as $fields) +		{ +			foreach($fields as $field) +			{ +				$form_data[$field['name']] = $field['value']; +			} +		} + +		// Bypass time restriction that said that if the lastclick time (i.e. time when the form was opened) +		// is not at least 2 seconds before submission, cancel the form +		$form_data['lastclick'] = 0; + +		// I use a request because the form submission method does not allow you to send data that is not +		// contained in one of the actual form fields that the browser sees (i.e. it ignores "hidden" inputs) +		// Instead, I send it as a request with the submit button "post" set to true. +		$crawler = self::request('POST', $posting_url, $form_data); +		$this->assertContains($this->lang('POST_STORED'), $crawler->filter('html')->text()); + +		$url = $crawler->selectLink($this->lang('VIEW_MESSAGE', '', ''))->link()->getUri(); + +		$matches = $topic_id = $post_id = false; +		preg_match_all('#&t=([0-9]+)(&p=([0-9]+))?#', $url, $matches); + +		$topic_id = (int) (isset($matches[1][0])) ? $matches[1][0] : 0; +		$post_id = (int) (isset($matches[3][0])) ? $matches[3][0] : 0; + +		return array( +			'topic_id'	=> $topic_id, +			'post_id'	=> $post_id, +		); +	}  } | 
