diff options
22 files changed, 568 insertions, 215 deletions
| diff --git a/phpBB/docs/events.md b/phpBB/docs/events.md index f0b3b81822..3723bf7b3f 100644 --- a/phpBB/docs/events.md +++ b/phpBB/docs/events.md @@ -124,6 +124,15 @@ viewtopic_print_head_append  * Location: styles/prosilver/template/viewtopic_print.html  * Purpose: Add asset calls directly before the `</head>` tag of the Print Topic screen +viewtopic_body_footer_before +=== +* Locations: +    + styles/prosilver/template/viewtopic_body.html +    + styles/subsilver2/template/viewtopic_body.html +* Purpose: Add content to the bottom of the View topic screen below the posts +and quick reply, directly before the jumpbox in Prosilver, breadcrumbs in +Subsilver2. +  viewtopic_topic_title_prepend  ===  * Locations: diff --git a/phpBB/docs/sphinx.sample.conf b/phpBB/docs/sphinx.sample.conf index fcaba6dcf3..d1b98d6cbc 100644 --- a/phpBB/docs/sphinx.sample.conf +++ b/phpBB/docs/sphinx.sample.conf @@ -1,46 +1,31 @@  source source_phpbb_{SPHINX_ID}_main  { -	type = mysql #mysql or pgsql -	sql_host = localhost #SQL server host sphinx connects to +	type = mysql # mysql or pgsql +	sql_host = localhost # SQL server host sphinx connects to  	sql_user = username  	sql_pass = password  	sql_db = db_name -	sql_port =  3306 #optional, default is 3306 for mysql and 5432 for pgsql +	sql_port =  3306 # optional, default is 3306 for mysql and 5432 for pgsql  	sql_query_pre = SET NAMES 'utf8' -	sql_query_pre = UPDATE phpbb_sphinx SET max_doc_id = MAX(post_id) WHERE counter_id = 1 +	sql_query_pre = UPDATE phpbb_sphinx SET max_doc_id = (SELECT MAX(post_id) FROM phpbb_posts) WHERE counter_id = 1  	sql_query_range = SELECT MIN(post_id), MAX(post_id) FROM phpbb_posts  	sql_range_step = 5000 -	sql_query = SELECT -\ -							p.post_id AS id, -\ -							p.forum_id, -\ -							p.topic_id, -\ -							p.poster_id, -\ -							CASE WHEN p.post_id = t.topic_first_post_id THEN 1 ELSE 0 END as topic_first_post, -\ -							p.post_time, -\ -							p.post_subject, -\ -							p.post_subject as title, -\ -							p.post_text as data, -\ -							t.topic_last_post_time, -\ -							0 as deleted -\ -						FROM phpbb_posts p, phpbb_topics t -\ -						WHERE -\ -							p.topic_id = t.topic_id -\ -							AND p.post_id >= $start AND p.post_id <= $end  +	sql_query = SELECT \ +							p.post_id AS id, \ +							p.forum_id, \ +							p.topic_id, \ +							p.poster_id, \ +							CASE WHEN p.post_id = t.topic_first_post_id THEN 1 ELSE 0 END as topic_first_post, \ +							p.post_time, \ +							p.post_subject, \ +							p.post_subject as title, \ +							p.post_text as data, \ +							t.topic_last_post_time, \ +							0 as deleted\ +						FROM phpbb_posts p, phpbb_topics t \ +						WHERE \ +							p.topic_id = t.topic_id \ +							AND p.post_id >= $start AND p.post_id <= $end  	sql_query_post =  	sql_query_post_index = UPDATE phpbb_sphinx SET max_doc_id = $maxid WHERE counter_id = 1  	sql_query_info = SELECT * FROM phpbb_posts WHERE post_id = $id @@ -55,39 +40,25 @@ source source_phpbb_{SPHINX_ID}_main  }  source source_phpbb_{SPHINX_ID}_delta : source_phpbb_{SPHINX_ID}_main  { +	sql_query_pre =  	sql_query_range =  	sql_range_step = -	sql_query = SELECT -\ -							p.post_id AS id, -\ -							p.forum_id, -\ -							p.topic_id, -\ -							p.poster_id, -\ -							CASE WHEN p.post_id = t.topic_first_post_id THEN 1 ELSE 0 END as topic_first_post, -\ -							p.post_time, -\ -							p.post_subject, -\ -							p.post_subject as title, -\ -							p.post_text as data, -\ -							t.topic_last_post_time, -\ -							0 as deleted -\ -						FROM phpbb_posts p, phpbb_topics t -\ -						WHERE -\ -							p.topic_id = t.topic_id -\ -							AND p.post_id >=  ( SELECT max_doc_id FROM phpbb_sphinx WHERE counter_id=1 )  +	sql_query = SELECT \ +							p.post_id AS id, \ +							p.forum_id, \ +							p.topic_id, \ +							p.poster_id, \ +							CASE WHEN p.post_id = t.topic_first_post_id THEN 1 ELSE 0 END as topic_first_post, \ +							p.post_time, \ +							p.post_subject, \ +							p.post_subject as title, \ +							p.post_text as data, \ +							t.topic_last_post_time, \ +							0 as deleted \ +						FROM phpbb_posts p, phpbb_topics t \ +						WHERE \ +							p.topic_id = t.topic_id \ +							AND p.post_id >= ( SELECT max_doc_id FROM phpbb_sphinx WHERE counter_id=1 )  	sql_query_pre =  }  index index_phpbb_{SPHINX_ID}_main diff --git a/phpBB/includes/db/driver/driver.php b/phpBB/includes/db/driver/driver.php index 8dda94bc2c..b915ee081b 100644 --- a/phpBB/includes/db/driver/driver.php +++ b/phpBB/includes/db/driver/driver.php @@ -568,12 +568,12 @@ class phpbb_db_driver  	* Run more than one insert statement.  	*  	* @param string $table table name to run the statements on -	* @param array &$sql_ary multi-dimensional array holding the statement data. +	* @param array $sql_ary multi-dimensional array holding the statement data.  	*  	* @return bool false if no statements were executed.  	* @access public  	*/ -	function sql_multi_insert($table, &$sql_ary) +	function sql_multi_insert($table, $sql_ary)  	{  		if (!sizeof($sql_ary))  		{ diff --git a/phpBB/includes/db/sql_insert_buffer.php b/phpBB/includes/db/sql_insert_buffer.php new file mode 100644 index 0000000000..c18f908429 --- /dev/null +++ b/phpBB/includes/db/sql_insert_buffer.php @@ -0,0 +1,150 @@ +<?php +/** +* +* @package dbal +* @copyright (c) 2013 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @ignore +*/ +if (!defined('IN_PHPBB')) +{ +	exit; +} + +/** +* Collects rows for insert into a database until the buffer size is reached. +* Then flushes the buffer to the database and starts over again. +* +* Benefits over collecting a (possibly huge) insert array and then using +* $db->sql_multi_insert() include: +* +*  - Going over max packet size of the database connection is usually prevented +*    because the data is submitted in batches. +* +*  - Reaching database connection timeout is usually prevented because +*    submission of batches talks to the database every now and then. +* +*  - Usage of less PHP memory because data no longer needed is discarded on +*    buffer flush. +* +* Attention: +* Please note that users of this class have to call flush() to flush the +* remaining rows to the database after their batch insert operation is +* finished. +* +* Usage: +* <code> +*	$buffer = new phpbb_db_sql_insert_buffer($db, 'test_table', 1234); +* +*	while (do_stuff()) +*	{ +*		$buffer->insert(array( +*			'column1' => 'value1', +*			'column2' => 'value2', +*		)); +*	} +* +*	$buffer->flush(); +* </code> +* +* @package dbal +*/ +class phpbb_db_sql_insert_buffer +{ +	/** @var phpbb_db_driver */ +	protected $db; + +	/** @var string */ +	protected $table_name; + +	/** @var int */ +	protected $max_buffered_rows; + +	/** @var array */ +	protected $buffer = array(); + +	/** +	* @param phpbb_db_driver $db +	* @param string          $table_name +	* @param int             $max_buffered_rows +	*/ +	public function __construct(phpbb_db_driver $db, $table_name, $max_buffered_rows = 500) +	{ +		$this->db = $db; +		$this->table_name = $table_name; +		$this->max_buffered_rows = $max_buffered_rows; +	} + +	/** +	* Inserts a single row into the buffer if multi insert is supported by the +	* database (otherwise an insert query is sent immediately). Then flushes +	* the buffer if the number of rows in the buffer is now greater than or +	* equal to $max_buffered_rows. +	* +	* @param array $row +	* +	* @return bool		True when some data was flushed to the database. +	*					False otherwise. +	*/ +	public function insert(array $row) +	{ +		$this->buffer[] = $row; + +		// Flush buffer if it is full or when DB does not support multi inserts. +		// In the later case, the buffer will always only contain one row. +		if (!$this->db->multi_insert || sizeof($this->buffer) >= $this->max_buffered_rows) +		{ +			return $this->flush(); +		} + +		return false; +	} + +	/** +	* Inserts a row set, i.e. an array of rows, by calling insert(). +	* +	* Please note that it is in most cases better to use insert() instead of +	* first building a huge rowset. Or at least sizeof($rows) should be kept +	* small. +	* +	* @param array $rows  +	* +	* @return bool		True when some data was flushed to the database. +	*					False otherwise. +	*/ +	public function insert_all(array $rows) +	{ +		// Using bitwise |= because PHP does not have logical ||= +		$result = 0; + +		foreach ($rows as $row) +		{ +			$result |= (int) $this->insert($row); +		} + +		return (bool) $result; +	} + +	/** +	* Flushes the buffer content to the DB and clears the buffer. +	* +	* @return bool		True when some data was flushed to the database. +	*					False otherwise. +	*/ +	public function flush() +	{ +		if (!empty($this->buffer)) +		{ +			$this->db->sql_multi_insert($this->table_name, $this->buffer); +			$this->buffer = array(); + +			return true; +		} + +		return false; +	} +} diff --git a/phpBB/includes/notification/manager.php b/phpBB/includes/notification/manager.php index ff83d4bb37..9eceeb753a 100644 --- a/phpBB/includes/notification/manager.php +++ b/phpBB/includes/notification/manager.php @@ -256,6 +256,7 @@ class phpbb_notification_manager  			SET notification_read = 1  			WHERE notification_time <= " . (int) $time .  				(($item_type !== false) ? ' AND ' . (is_array($item_type) ? $this->db->sql_in_set('item_type', $item_type) : " item_type = '" . $this->db->sql_escape($item_type) . "'") : '') . +				(($user_id !== false) ? ' AND ' . (is_array($user_id) ? $this->db->sql_in_set('user_id', $user_id) : 'user_id = ' . (int) $user_id) : '') .  				(($item_id !== false) ? ' AND ' . (is_array($item_id) ? $this->db->sql_in_set('item_id', $item_id) : 'item_id = ' . (int) $item_id) : '');  		$this->db->sql_query($sql);  	} @@ -389,7 +390,6 @@ class phpbb_notification_manager  		$user_ids = array();  		$notification_objects = $notification_methods = array(); -		$new_rows = array();  		// Never send notifications to the anonymous user!  		unset($notify_users[ANONYMOUS]); @@ -419,6 +419,8 @@ class phpbb_notification_manager  		$pre_create_data = $notification->pre_create_insert_array($data, $notify_users);  		unset($notification); +		$insert_buffer = new phpbb_db_sql_insert_buffer($this->db, $this->notifications_table); +  		// Go through each user so we can insert a row in the DB and then notify them by their desired means  		foreach ($notify_users as $user => $methods)  		{ @@ -426,8 +428,8 @@ class phpbb_notification_manager  			$notification->user_id = (int) $user; -			// Store the creation array in our new rows that will be inserted later -			$new_rows[] = $notification->create_insert_array($data, $pre_create_data); +			// Insert notification row using buffer. +			$insert_buffer->insert($notification->create_insert_array($data, $pre_create_data));  			// Users are needed to send notifications  			$user_ids = array_merge($user_ids, $notification->users_to_query()); @@ -447,8 +449,7 @@ class phpbb_notification_manager  			}  		} -		// insert into the db -		$this->db->sql_multi_insert($this->notifications_table, $new_rows); +		$insert_buffer->flush();  		// We need to load all of the users to send notifications  		$this->user_loader->load_users($user_ids); diff --git a/phpBB/includes/notification/method/email.php b/phpBB/includes/notification/method/email.php index 4a7fea6df3..dc505c0d41 100644 --- a/phpBB/includes/notification/method/email.php +++ b/phpBB/includes/notification/method/email.php @@ -34,20 +34,6 @@ class phpbb_notification_method_email extends phpbb_notification_method_base  	}  	/** -	* Notify method (since jabber gets sent through the same messenger, we let the jabber class inherit from this to reduce code duplication) -	* -	* @var mixed -	*/ -	protected $notify_method = NOTIFY_EMAIL; - -	/** -	* Base directory to prepend to the email template name -	* -	* @var string -	*/ -	protected $email_template_base_dir = ''; - -	/**  	* Is this method available for the user?  	* This is checked on the notifications options  	*/ @@ -61,68 +47,6 @@ class phpbb_notification_method_email extends phpbb_notification_method_base  	*/  	public function notify()  	{ -		if (!sizeof($this->queue)) -		{ -			return; -		} - -		// Load all users we want to notify (we need their email address) -		$user_ids = $users = array(); -		foreach ($this->queue as $notification) -		{ -			$user_ids[] = $notification->user_id; -		} - -		// We do not send emails to banned users -		if (!function_exists('phpbb_get_banned_user_ids')) -		{ -			include($this->phpbb_root_path . 'includes/functions_user.' . $this->php_ext); -		} -		$banned_users = phpbb_get_banned_user_ids($user_ids); - -		// Load all the users we need -		$this->user_loader->load_users($user_ids); - -		// Load the messenger -		if (!class_exists('messenger')) -		{ -			include($this->phpbb_root_path . 'includes/functions_messenger.' . $this->php_ext); -		} -		$messenger = new messenger(); -		$board_url = generate_board_url(); - -		// Time to go through the queue and send emails -		foreach ($this->queue as $notification) -		{ -			if ($notification->get_email_template() === false) -			{ -				continue; -			} - -			$user = $this->user_loader->get_user($notification->user_id); - -			if ($user['user_type'] == USER_IGNORE || in_array($notification->user_id, $banned_users)) -			{ -				continue; -			} - -			$messenger->template($this->email_template_base_dir . $notification->get_email_template(), $user['user_lang']); - -			$messenger->to($user['user_email'], $user['username']); - -			$messenger->assign_vars(array_merge(array( -				'USERNAME'						=> $user['username'], - -				'U_NOTIFICATION_SETTINGS'		=> generate_board_url() . '/ucp.' . $this->php_ext . '?i=ucp_notifications', -			), $notification->get_email_template_variables())); - -			$messenger->send($this->notify_method); -		} - -		// Save the queue in the messenger class (has to be called or these emails could be lost?) -		$messenger->save_queue(); - -		// We're done, empty the queue -		$this->empty_queue(); +		return $this->notify_using_messenger(NOTIFY_EMAIL);  	}  } diff --git a/phpBB/includes/notification/method/jabber.php b/phpBB/includes/notification/method/jabber.php index 863846b8a5..debffa8ce5 100644 --- a/phpBB/includes/notification/method/jabber.php +++ b/phpBB/includes/notification/method/jabber.php @@ -21,7 +21,7 @@ if (!defined('IN_PHPBB'))  *  * @package notifications  */ -class phpbb_notification_method_jabber extends phpbb_notification_method_email +class phpbb_notification_method_jabber extends phpbb_notification_method_messenger_base  {  	/**  	* Get notification method name @@ -34,20 +34,6 @@ class phpbb_notification_method_jabber extends phpbb_notification_method_email  	}  	/** -	* Notify method (since jabber gets sent through the same messenger, we let the jabber class inherit from this to reduce code duplication) -	* -	* @var mixed -	*/ -	protected $notify_method = NOTIFY_IM; - -	/** -	* Base directory to prepend to the email template name -	* -	* @var string -	*/ -	protected $email_template_base_dir = 'short/'; - -	/**  	* Is this method available for the user?  	* This is checked on the notifications options  	*/ @@ -72,6 +58,6 @@ class phpbb_notification_method_jabber extends phpbb_notification_method_email  			return;  		} -		return parent::notify(); +		return $this->notify_using_messenger(NOTIFY_IM, 'short/');  	}  } diff --git a/phpBB/includes/notification/method/messenger_base.php b/phpBB/includes/notification/method/messenger_base.php new file mode 100644 index 0000000000..ce1ecc09ce --- /dev/null +++ b/phpBB/includes/notification/method/messenger_base.php @@ -0,0 +1,100 @@ +<?php +/** +* +* @package notifications +* @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; +} + +/** +* Abstract notification method handling email and jabber notifications +* using the phpBB messenger. +* +* @package notifications +*/ +abstract class phpbb_notification_method_messenger_base extends phpbb_notification_method_base +{ +	/** +	* Notify using phpBB messenger +	* +	* @param int $notify_method				Notify method for messenger (e.g. NOTIFY_IM) +	* @param string $template_dir_prefix	Base directory to prepend to the email template name +	* +	* @return null +	*/ +	protected function notify_using_messenger($notify_method, $template_dir_prefix = '') +	{ +		if (empty($this->queue)) +		{ +			return; +		} + +		// Load all users we want to notify (we need their email address) +		$user_ids = $users = array(); +		foreach ($this->queue as $notification) +		{ +			$user_ids[] = $notification->user_id; +		} + +		// We do not send emails to banned users +		if (!function_exists('phpbb_get_banned_user_ids')) +		{ +			include($this->phpbb_root_path . 'includes/functions_user.' . $this->php_ext); +		} +		$banned_users = phpbb_get_banned_user_ids($user_ids); + +		// Load all the users we need +		$this->user_loader->load_users($user_ids); + +		// Load the messenger +		if (!class_exists('messenger')) +		{ +			include($this->phpbb_root_path . 'includes/functions_messenger.' . $this->php_ext); +		} +		$messenger = new messenger(); +		$board_url = generate_board_url(); + +		// Time to go through the queue and send emails +		foreach ($this->queue as $notification) +		{ +			if ($notification->get_email_template() === false) +			{ +				continue; +			} + +			$user = $this->user_loader->get_user($notification->user_id); + +			if ($user['user_type'] == USER_IGNORE || in_array($notification->user_id, $banned_users)) +			{ +				continue; +			} + +			$messenger->template($email_template_base_dir . $notification->get_email_template(), $user['user_lang']); + +			$messenger->to($user['user_email'], $user['username']); + +			$messenger->assign_vars(array_merge(array( +				'USERNAME'						=> $user['username'], + +				'U_NOTIFICATION_SETTINGS'		=> generate_board_url() . '/ucp.' . $this->php_ext . '?i=ucp_notifications', +			), $notification->get_email_template_variables())); + +			$messenger->send($notify_method); +		} + +		// Save the queue in the messenger class (has to be called or these emails could be lost?) +		$messenger->save_queue(); + +		// We're done, empty the queue +		$this->empty_queue(); +	} +} diff --git a/phpBB/includes/search/fulltext_sphinx.php b/phpBB/includes/search/fulltext_sphinx.php index 48445d0794..28761792ec 100644 --- a/phpBB/includes/search/fulltext_sphinx.php +++ b/phpBB/includes/search/fulltext_sphinx.php @@ -258,13 +258,13 @@ class phpbb_search_fulltext_sphinx  		$config_object = new phpbb_search_sphinx_config($this->config_file_data);  		$config_data = array(  			'source source_phpbb_' . $this->id . '_main' => array( -				array('type',						$this->dbtype), +				array('type',						$this->dbtype . ' # mysql or pgsql'),  				// This config value sql_host needs to be changed incase sphinx and sql are on different servers -				array('sql_host',					$dbhost), +				array('sql_host',					$dbhost . ' # SQL server host sphinx connects to'),  				array('sql_user',					$dbuser),  				array('sql_pass',					$dbpasswd),  				array('sql_db',						$dbname), -				array('sql_port',					$dbport), +				array('sql_port',					$dbport . ' # optional, default is 3306 for mysql and 5432 for pgsql'),  				array('sql_query_pre',				'SET NAMES \'utf8\''),  				array('sql_query_pre',				'UPDATE ' . SPHINX_TABLE . ' SET max_doc_id = (SELECT MAX(post_id) FROM ' . POSTS_TABLE . ') WHERE counter_id = 1'),  				array('sql_query_range',			'SELECT MIN(post_id), MAX(post_id) FROM ' . POSTS_TABLE . ''), diff --git a/phpBB/includes/search/sphinx/config_variable.php b/phpBB/includes/search/sphinx/config_variable.php index 35abe281cb..2c1d35a49c 100644 --- a/phpBB/includes/search/sphinx/config_variable.php +++ b/phpBB/includes/search/sphinx/config_variable.php @@ -75,6 +75,6 @@ class phpbb_search_sphinx_config_variable  	*/  	function to_string()  	{ -		return "\t" . $this->name . ' = ' . str_replace("\n", "\\\n", $this->value) . ' ' . $this->comment . "\n"; +		return "\t" . $this->name . ' = ' . str_replace("\n", " \\\n", $this->value) . ' ' . $this->comment . "\n";  	}  } diff --git a/phpBB/includes/ucp/ucp_pm_viewmessage.php b/phpBB/includes/ucp/ucp_pm_viewmessage.php index 712032463f..b7d2dd6821 100644 --- a/phpBB/includes/ucp/ucp_pm_viewmessage.php +++ b/phpBB/includes/ucp/ucp_pm_viewmessage.php @@ -94,8 +94,7 @@ function view_message($id, $mode, $folder_id, $msg_id, $folder, $message_row)  	// Editing information  	if ($message_row['message_edit_count'] && $config['display_last_edited'])  	{ -		$l_edit_time_total = ($message_row['message_edit_count'] == 1) ? $user->lang['EDITED_TIME_TOTAL'] : $user->lang['EDITED_TIMES_TOTAL']; -		$l_edited_by = '<br /><br />' . sprintf($l_edit_time_total, (!$message_row['message_edit_user']) ? $message_row['username'] : $message_row['message_edit_user'], $user->format_date($message_row['message_edit_time'], false, true), $message_row['message_edit_count']); +		$l_edited_by = '<br /><br />' . $user->lang('EDITED_TIMES_TOTAL', (int) $message_row['message_edit_count'], (!$message_row['message_edit_user']) ? $message_row['username'] : $message_row['message_edit_user'], $user->format_date($message_row['message_edit_time'], false, true));  	}  	else  	{ diff --git a/phpBB/includes/user_loader.php b/phpBB/includes/user_loader.php index 77128d6570..37bf9648c1 100644 --- a/phpBB/includes/user_loader.php +++ b/phpBB/includes/user_loader.php @@ -70,8 +70,8 @@ class phpbb_user_loader  	{  		$user_ids[] = ANONYMOUS; -		// Load the users -		$user_ids = array_unique($user_ids); +		// Make user_ids unique and convert to integer. +		$user_ids = array_map('intval', array_unique($user_ids));  		// Do not load users we already have in $this->users  		$user_ids = array_diff($user_ids, array_keys($this->users)); diff --git a/phpBB/install/database_update.php b/phpBB/install/database_update.php index 2ecddf49d4..867235e607 100644 --- a/phpBB/install/database_update.php +++ b/phpBB/install/database_update.php @@ -41,10 +41,12 @@ if (!function_exists('phpbb_require_updated'))  	}  } -function phpbb_end_update($cache) +function phpbb_end_update($cache, $config)  {  	$cache->purge(); +	$config->increment('assets_version', 1); +  ?>  								</p>  							</div> @@ -232,7 +234,7 @@ while (!$migrator->finished())  	{  		echo $e->getLocalisedMessage($user); -		phpbb_end_update($cache); +		phpbb_end_update($cache, $config);  	}  	$state = array_merge(array( @@ -265,7 +267,7 @@ while (!$migrator->finished())  		echo $user->lang['DATABASE_UPDATE_NOT_COMPLETED'] . '<br />';  		echo '<a href="' . append_sid($phpbb_root_path . 'test.' . $phpEx) . '">' . $user->lang['DATABASE_UPDATE_CONTINUE'] . '</a>'; -		phpbb_end_update($cache); +		phpbb_end_update($cache, $config);  	}  } @@ -276,4 +278,4 @@ if ($orig_version != $config['version'])  echo $user->lang['DATABASE_UPDATE_COMPLETE']; -phpbb_end_update($cache); +phpbb_end_update($cache, $config); diff --git a/phpBB/install/schemas/schema_data.sql b/phpBB/install/schemas/schema_data.sql index f118d330ba..c25925a9c8 100644 --- a/phpBB/install/schemas/schema_data.sql +++ b/phpBB/install/schemas/schema_data.sql @@ -777,9 +777,9 @@ INSERT INTO phpbb_extensions (group_id, extension) VALUES (9, 'ogg');  INSERT INTO phpbb_extensions (group_id, extension) VALUES (9, 'ogm');  # User Notification Options (for first user) -INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('phpbb_notification_type_post', 0, 2, ''); -INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('phpbb_notification_type_post', 0, 2, 'phpbb_notification_method_email'); -INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('phpbb_notification_type_topic', 0, 2, ''); -INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('phpbb_notification_type_topic', 0, 2, 'phpbb_notification_method_email'); +INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('post', 0, 2, ''); +INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('post', 0, 2, 'email'); +INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('topic', 0, 2, ''); +INSERT INTO phpbb_user_notifications (item_type, item_id, user_id, method) VALUES('topic', 0, 2, 'email');  # POSTGRES COMMIT # diff --git a/phpBB/styles/prosilver/template/viewtopic_body.html b/phpBB/styles/prosilver/template/viewtopic_body.html index c9a6882b6f..5ec8480deb 100644 --- a/phpBB/styles/prosilver/template/viewtopic_body.html +++ b/phpBB/styles/prosilver/template/viewtopic_body.html @@ -301,6 +301,7 @@  	<!-- ENDIF -->  </div> +<!-- EVENT viewtopic_body_footer_before -->  <!-- INCLUDE jumpbox.html -->  <!-- IF .quickmod --> diff --git a/phpBB/styles/subsilver2/template/viewtopic_body.html b/phpBB/styles/subsilver2/template/viewtopic_body.html index 9e6377022a..b561b99abd 100644 --- a/phpBB/styles/subsilver2/template/viewtopic_body.html +++ b/phpBB/styles/subsilver2/template/viewtopic_body.html @@ -328,6 +328,7 @@  <!-- INCLUDE quickreply_editor.html -->  <!-- ENDIF --> +<!-- EVENT viewtopic_body_footer_before -->  <!-- INCLUDE breadcrumbs.html -->  <!-- IF S_DISPLAY_ONLINE_LIST --> diff --git a/phpunit.xml.all b/phpunit.xml.all index fde3bbb1a7..3639843771 100644 --- a/phpunit.xml.all +++ b/phpunit.xml.all @@ -24,15 +24,6 @@          <whitelist>              <directory suffix=".php">./phpBB/includes/</directory>              <exclude> -                <file>./phpBB/includes/db/firebird.php</file> -                <file>./phpBB/includes/db/mysql.php</file> -                <file>./phpBB/includes/db/mysqli.php</file> -                <file>./phpBB/includes/db/mssql.php</file> -                <file>./phpBB/includes/db/mssql_odbc.php</file> -                <file>./phpBB/includes/db/mssqlnative.php</file> -                <file>./phpBB/includes/db/oracle.php</file> -                <file>./phpBB/includes/db/postgres.php</file> -                <file>./phpBB/includes/db/sqlite.php</file>                  <file>./phpBB/includes/search/fulltext_native.php</file>                  <file>./phpBB/includes/search/fulltext_mysql.php</file>                  <directory suffix=".php">./phpBB/includes/captcha/</directory> diff --git a/phpunit.xml.dist b/phpunit.xml.dist index 27dee48aac..f1cb4b9d09 100644 --- a/phpunit.xml.dist +++ b/phpunit.xml.dist @@ -31,15 +31,6 @@          <whitelist>              <directory suffix=".php">./phpBB/includes/</directory>              <exclude> -                <file>./phpBB/includes/db/firebird.php</file> -                <file>./phpBB/includes/db/mysql.php</file> -                <file>./phpBB/includes/db/mysqli.php</file> -                <file>./phpBB/includes/db/mssql.php</file> -                <file>./phpBB/includes/db/mssql_odbc.php</file> -                <file>./phpBB/includes/db/mssqlnative.php</file> -                <file>./phpBB/includes/db/oracle.php</file> -                <file>./phpBB/includes/db/postgres.php</file> -                <file>./phpBB/includes/db/sqlite.php</file>                  <file>./phpBB/includes/search/fulltext_native.php</file>                  <file>./phpBB/includes/search/fulltext_mysql.php</file>                  <directory suffix=".php">./phpBB/includes/captcha/</directory> diff --git a/phpunit.xml.functional b/phpunit.xml.functional index 9facbcff8b..99f11477aa 100644 --- a/phpunit.xml.functional +++ b/phpunit.xml.functional @@ -30,15 +30,6 @@          <whitelist>              <directory suffix=".php">./phpBB/includes/</directory>              <exclude> -                <file>./phpBB/includes/db/firebird.php</file> -                <file>./phpBB/includes/db/mysql.php</file> -                <file>./phpBB/includes/db/mysqli.php</file> -                <file>./phpBB/includes/db/mssql.php</file> -                <file>./phpBB/includes/db/mssql_odbc.php</file> -                <file>./phpBB/includes/db/mssqlnative.php</file> -                <file>./phpBB/includes/db/oracle.php</file> -                <file>./phpBB/includes/db/postgres.php</file> -                <file>./phpBB/includes/db/sqlite.php</file>                  <file>./phpBB/includes/search/fulltext_native.php</file>                  <file>./phpBB/includes/search/fulltext_mysql.php</file>                  <directory suffix=".php">./phpBB/includes/captcha/</directory> diff --git a/tests/dbal/sql_insert_buffer_test.php b/tests/dbal/sql_insert_buffer_test.php new file mode 100644 index 0000000000..45339a6b50 --- /dev/null +++ b/tests/dbal/sql_insert_buffer_test.php @@ -0,0 +1,116 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2013 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +class phpbb_dbal_sql_insert_buffer_test extends phpbb_database_test_case +{ +	protected $db; +	protected $buffer; + +	public function setUp() +	{ +		parent::setUp(); + +		$this->db = $this->new_dbal(); +		$this->buffer = new phpbb_db_sql_insert_buffer($this->db, 'phpbb_config', 2); +		$this->assert_config_count(2); +	} + +	public function getDataSet() +	{ +		return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/config.xml'); +	} + +	public function test_multi_insert_disabled_insert_and_flush() +	{ +		$this->db->multi_insert = false; +		$this->assertTrue($this->buffer->insert($this->get_row(1))); +		$this->assert_config_count(3); +		$this->assertFalse($this->buffer->flush()); +		$this->assert_config_count(3); +	} + +	public function test_multi_insert_enabled_insert_and_flush() +	{ +		$this->check_multi_insert_support(); +		$this->assertFalse($this->buffer->insert($this->get_row(1))); +		$this->assert_config_count(2); +		$this->assertTrue($this->buffer->flush()); +		$this->assert_config_count(3); +	} + +	public function test_multi_insert_disabled_insert_with_flush() +	{ +		$this->db->multi_insert = false; +		$this->assertTrue($this->buffer->insert($this->get_row(1))); +		$this->assert_config_count(3); +		$this->assertTrue($this->buffer->insert($this->get_row(2))); +		$this->assert_config_count(4); +	} + +	public function test_multi_insert_enabled_insert_with_flush() +	{ +		$this->check_multi_insert_support(); +		$this->assertFalse($this->buffer->insert($this->get_row(1))); +		$this->assert_config_count(2); +		$this->assertTrue($this->buffer->insert($this->get_row(2))); +		$this->assert_config_count(4); +	} + +	public function test_multi_insert_disabled_insert_all_and_flush() +	{ +		$this->db->multi_insert = false; +		$this->assertTrue($this->buffer->insert_all($this->get_rows(3))); +		$this->assert_config_count(5); +	} + +	public function test_multi_insert_enabled_insert_all_and_flush() +	{ +		$this->check_multi_insert_support(); +		$this->assertTrue($this->buffer->insert_all($this->get_rows(3))); +		$this->assert_config_count(4); +		$this->assertTrue($this->buffer->flush()); +		$this->assert_config_count(5); +	} + +	protected function assert_config_count($num_configs) +	{ +		$sql = 'SELECT COUNT(*) AS num_configs +			FROM phpbb_config'; +		$result = $this->db->sql_query($sql); +		$this->assertEquals($num_configs, $this->db->sql_fetchfield('num_configs')); +		$this->db->sql_freeresult($result); +	} + +	protected function check_multi_insert_support() +	{ +		if (!$this->db->multi_insert) +		{ +			$this->markTestSkipped('Database does not support multi_insert'); +		} +	} + +	protected function get_row($rownum) +	{ +		return array( +			'config_name'	=> "name$rownum", +			'config_value'	=> "value$rownum", +			'is_dynamic'	=> '0', +		); +	} + +	protected function get_rows($n) +	{ +		$result = array(); +		for ($i = 0; $i < $n; ++$i) +		{ +			$result[] = $this->get_row($i); +		} +		return $result; +	} +} diff --git a/tests/functional/notification_test.php b/tests/functional/notification_test.php new file mode 100644 index 0000000000..ec495da602 --- /dev/null +++ b/tests/functional/notification_test.php @@ -0,0 +1,56 @@ +<?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_notification_test extends phpbb_functional_test_case +{ +	static public function user_subscription_data() +	{ +		return array( +			// Rows inserted by phpBB/install/schemas/schema_data.sql +			// Also see PHPBB3-11460 +			array('post_notification', true), +			array('topic_notification', true), +			array('post_email', true), +			array('topic_email', true), + +			// Default behaviour for in-board notifications: +			// If user did not opt-out, in-board notifications are on. +			array('bookmark_notification', true), +			array('quote_notification', true), + +			// Default behaviour for email notifications: +			// If user did not opt-in, email notifications are off. +			array('bookmark_email', false), +			array('quote_email', false), +		); +	} + +	/** +	* @dataProvider user_subscription_data +	*/ +	public function test_user_subscriptions($checkbox_name, $expected_status) +	{ +		$this->login(); +		$crawler = $this->request('GET', 'ucp.php?i=ucp_notifications&mode=notification_options'); +		$this->assert_response_success(); + +		$cplist = $crawler->filter('.cplist'); +		if ($expected_status) +		{ +			$this->assert_checkbox_is_checked($cplist, $checkbox_name); +		} +		else +		{ +			$this->assert_checkbox_is_unchecked($cplist, $checkbox_name); +		} +	} +} diff --git a/tests/test_framework/phpbb_functional_test_case.php b/tests/test_framework/phpbb_functional_test_case.php index 887dfea3b5..a411d9c98a 100644 --- a/tests/test_framework/phpbb_functional_test_case.php +++ b/tests/test_framework/phpbb_functional_test_case.php @@ -196,12 +196,12 @@ class phpbb_functional_test_case extends phpbb_test_case  		$parseURL = parse_url(self::$config['phpbb_functional_url']);  		$data = array_merge($data, array( -			'email_enable'		=> false, -			'smtp_delivery'		=> false, -			'smtp_host'		=> '', -			'smtp_auth'		=> '', -			'smtp_user'		=> '', -			'smtp_pass'		=> '', +			'email_enable'		=> true, +			'smtp_delivery'		=> true, +			'smtp_host'			=> 'nxdomain.phpbb.com', +			'smtp_auth'			=> '', +			'smtp_user'			=> 'nxuser', +			'smtp_pass'			=> 'nxpass',  			'cookie_secure'		=> false,  			'force_server_vars'	=> false,  			'server_protocol'	=> $parseURL['scheme'] . '://', @@ -463,4 +463,68 @@ class phpbb_functional_test_case extends phpbb_test_case  		$this->assertGreaterThan(0, count($nodes), $msg);  		return $nodes;  	} + +	/** +	* Asserts that exactly one checkbox with name $name exists within the scope +	* of $crawler and that the checkbox is checked. +	* +	* @param Symfony\Component\DomCrawler\Crawler $crawler +	* @param string $name +	* @param string $message +	* +	* @return null +	*/ +	public function assert_checkbox_is_checked($crawler, $name, $message = '') +	{ +		$this->assertSame( +			'checked', +			$this->assert_find_one_checkbox($crawler, $name)->attr('checked'), +			$message ?: "Failed asserting that checkbox $name is checked." +		); +	} + +	/** +	* Asserts that exactly one checkbox with name $name exists within the scope +	* of $crawler and that the checkbox is unchecked. +	* +	* @param Symfony\Component\DomCrawler\Crawler $crawler +	* @param string $name +	* @param string $message +	* +	* @return null +	*/ +	public function assert_checkbox_is_unchecked($crawler, $name, $message = '') +	{ +		$this->assertSame( +			'', +			$this->assert_find_one_checkbox($crawler, $name)->attr('checked'), +			$message ?: "Failed asserting that checkbox $name is unchecked." +		); +	} + +	/** +	* Searches for an input element of type checkbox with the name $name using +	* $crawler. Contains an assertion that only one such checkbox exists within +	* the scope of $crawler. +	* +	* @param Symfony\Component\DomCrawler\Crawler $crawler +	* @param string $name +	* @param string $message +	* +	* @return Symfony\Component\DomCrawler\Crawler +	*/ +	public function assert_find_one_checkbox($crawler, $name, $message = '') +	{ +		$query = sprintf('//input[@type="checkbox" and @name="%s"]', $name); +		$result = $crawler->filterXPath($query); + +		$this->assertEquals( +			1, +			sizeof($result), +			$message ?: 'Failed asserting that exactly one checkbox with name' . +				" $name exists in crawler scope." +		); + +		return $result; +	}  } | 
