diff options
Diffstat (limited to 'phpBB/includes')
| -rw-r--r-- | phpBB/includes/acp/acp_jabber.php | 25 | ||||
| -rw-r--r-- | phpBB/includes/functions_content.php | 4 | ||||
| -rw-r--r-- | phpBB/includes/functions_jabber.php | 53 | ||||
| -rw-r--r-- | phpBB/includes/functions_messenger.php | 38 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_main.php | 8 | 
5 files changed, 104 insertions, 24 deletions
| diff --git a/phpBB/includes/acp/acp_jabber.php b/phpBB/includes/acp/acp_jabber.php index a482b41e1d..3b958c0ea1 100644 --- a/phpBB/includes/acp/acp_jabber.php +++ b/phpBB/includes/acp/acp_jabber.php @@ -50,13 +50,16 @@ class acp_jabber  		$this->tpl_name = 'acp_jabber';  		$this->page_title = 'ACP_JABBER_SETTINGS'; -		$jab_enable			= request_var('jab_enable',			(bool) $config['jab_enable']); -		$jab_host			= request_var('jab_host',			(string) $config['jab_host']); -		$jab_port			= request_var('jab_port',			(int) $config['jab_port']); -		$jab_username		= request_var('jab_username',		(string) $config['jab_username']); -		$jab_password		= request_var('jab_password',		(string) $config['jab_password']); -		$jab_package_size	= request_var('jab_package_size',	(int) $config['jab_package_size']); -		$jab_use_ssl		= request_var('jab_use_ssl',		(bool) $config['jab_use_ssl']); +		$jab_enable				= request_var('jab_enable',				(bool) $config['jab_enable']); +		$jab_host				= request_var('jab_host',				(string) $config['jab_host']); +		$jab_port				= request_var('jab_port',				(int) $config['jab_port']); +		$jab_username			= request_var('jab_username',			(string) $config['jab_username']); +		$jab_password			= request_var('jab_password',			(string) $config['jab_password']); +		$jab_package_size		= request_var('jab_package_size',		(int) $config['jab_package_size']); +		$jab_use_ssl			= request_var('jab_use_ssl',			(bool) $config['jab_use_ssl']); +		$jab_verify_peer		= request_var('jab_verify_peer',		(bool) $config['jab_verify_peer']); +		$jab_verify_peer_name	= request_var('jab_verify_peer_name',	(bool) $config['jab_verify_peer_name']); +		$jab_allow_self_signed	= request_var('jab_allow_self_signed',	(bool) $config['jab_allow_self_signed']);  		$form_name = 'acp_jabber';  		add_form_key($form_name); @@ -76,7 +79,7 @@ class acp_jabber  			// Is this feature enabled? Then try to establish a connection  			if ($jab_enable)  			{ -				$jabber = new jabber($jab_host, $jab_port, $jab_username, $jab_password, $jab_use_ssl); +				$jabber = new jabber($jab_host, $jab_port, $jab_username, $jab_password, $jab_use_ssl, $jab_verify_peer, $jab_verify_peer_name, $jab_allow_self_signed);  				if (!$jabber->connect())  				{ @@ -116,6 +119,9 @@ class acp_jabber  			}  			set_config('jab_package_size', $jab_package_size);  			set_config('jab_use_ssl', $jab_use_ssl); +			set_config('jab_verify_peer', $jab_verify_peer); +			set_config('jab_verify_peer_name', $jab_verify_peer_name); +			set_config('jab_allow_self_signed', $jab_allow_self_signed);  			add_log('admin', 'LOG_' . $log);  			trigger_error($message . adm_back_link($this->u_action)); @@ -131,6 +137,9 @@ class acp_jabber  			'JAB_PASSWORD'			=> $jab_password !== '' ? '********' : '',  			'JAB_PACKAGE_SIZE'		=> $jab_package_size,  			'JAB_USE_SSL'			=> $jab_use_ssl, +			'JAB_VERIFY_PEER'		=> $jab_verify_peer, +			'JAB_VERIFY_PEER_NAME'	=> $jab_verify_peer_name, +			'JAB_ALLOW_SELF_SIGNED'	=> $jab_allow_self_signed,  			'S_CAN_USE_SSL'			=> jabber::can_use_ssl(),  			'S_GTALK_NOTE'			=> (!@function_exists('dns_get_record')) ? true : false,  		)); diff --git a/phpBB/includes/functions_content.php b/phpBB/includes/functions_content.php index 8858d1a307..f671f33ed0 100644 --- a/phpBB/includes/functions_content.php +++ b/phpBB/includes/functions_content.php @@ -679,9 +679,11 @@ function generate_text_for_storage(&$text, &$uid, &$bitfield, &$flags, $allow_bb  	* @var string	uid				The BBCode UID  	* @var string	bitfield		The BBCode Bitfield  	* @var int		flags			The BBCode Flags +	* @var string	message_parser	The message_parser object  	* @since 3.1.0-a1 +	* @changed 3.1.11-RC1			Added message_parser to vars  	*/ -	$vars = array('text', 'uid', 'bitfield', 'flags'); +	$vars = array('text', 'uid', 'bitfield', 'flags', 'message_parser');  	extract($phpbb_dispatcher->trigger_event('core.modify_text_for_storage_after', compact($vars)));  	return $message_parser->warn_msg; diff --git a/phpBB/includes/functions_jabber.php b/phpBB/includes/functions_jabber.php index bd2e9e93ac..c9ec6fea61 100644 --- a/phpBB/includes/functions_jabber.php +++ b/phpBB/includes/functions_jabber.php @@ -41,6 +41,9 @@ class jabber  	var $username;  	var $password;  	var $use_ssl; +	var $verify_peer; +	var $verify_peer_name; +	var $allow_self_signed;  	var $resource = 'functions_jabber.phpbb.php';  	var $enable_logging; @@ -49,8 +52,18 @@ class jabber  	var $features = array();  	/** +	* Constructor +	* +	* @param string $server Jabber server +	* @param int $port Jabber server port +	* @param string $username Jabber username or JID +	* @param string $password Jabber password +	* @param boold $use_ssl Use ssl +	* @param bool $verify_peer Verify SSL certificate +	* @param bool $verify_peer_name Verify Jabber peer name +	* @param bool $allow_self_signed Allow self signed certificates  	*/ -	function jabber($server, $port, $username, $password, $use_ssl = false) +	function __construct($server, $port, $username, $password, $use_ssl = false, $verify_peer = true, $verify_peer_name = true, $allow_self_signed = false)  	{  		$this->connect_server		= ($server) ? $server : 'localhost';  		$this->port					= ($port) ? $port : 5222; @@ -71,6 +84,9 @@ class jabber  		$this->password				= $password;  		$this->use_ssl				= ($use_ssl && self::can_use_ssl()) ? true : false; +		$this->verify_peer			= $verify_peer; +		$this->verify_peer_name		= $verify_peer_name; +		$this->allow_self_signed	= $allow_self_signed;  		// Change port if we use SSL  		if ($this->port == 5222 && $this->use_ssl) @@ -96,7 +112,7 @@ class jabber  	*/  	static public function can_use_tls()  	{ -		if (!@extension_loaded('openssl') || !function_exists('stream_socket_enable_crypto') || !function_exists('stream_get_meta_data') || !function_exists('socket_set_blocking') || !function_exists('stream_get_wrappers')) +		if (!@extension_loaded('openssl') || !function_exists('stream_socket_enable_crypto') || !function_exists('stream_get_meta_data') || !function_exists('stream_set_blocking') || !function_exists('stream_get_wrappers'))  		{  			return false;  		} @@ -139,7 +155,7 @@ class jabber  		$this->session['ssl'] = $this->use_ssl; -		if ($this->open_socket($this->connect_server, $this->port, $this->use_ssl)) +		if ($this->open_socket($this->connect_server, $this->port, $this->use_ssl, $this->verify_peer, $this->verify_peer_name, $this->allow_self_signed))  		{  			$this->send("<?xml version='1.0' encoding='UTF-8' ?" . ">\n");  			$this->send("<stream:stream to='{$this->server}' xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' version='1.0'>\n"); @@ -227,10 +243,13 @@ class jabber  	* @param string $server host to connect to  	* @param int $port port number  	* @param bool $use_ssl use ssl or not +	* @param bool $verify_peer verify ssl certificate +	* @param bool $verify_peer_name verify peer name +	* @param bool $allow_self_signed allow self-signed ssl certificates  	* @access public  	* @return bool  	*/ -	function open_socket($server, $port, $use_ssl = false) +	function open_socket($server, $port, $use_ssl, $verify_peer, $verify_peer_name, $allow_self_signed)  	{  		if (@function_exists('dns_get_record'))  		{ @@ -241,12 +260,26 @@ class jabber  			}  		} -		$server = $use_ssl ? 'ssl://' . $server : $server; +		$options = array(); -		if ($this->connection = @fsockopen($server, $port, $errorno, $errorstr, $this->timeout)) +		if ($use_ssl)  		{ -			socket_set_blocking($this->connection, 0); -			socket_set_timeout($this->connection, 60); +			$remote_socket = 'ssl://' . $server . ':' . $port; + +			// Set ssl context options, see http://php.net/manual/en/context.ssl.php +			$options['ssl'] = array('verify_peer' => $verify_peer, 'verify_peer_name' => $verify_peer_name, 'allow_self_signed' => $allow_self_signed); +		} +		else +		{ +			$remote_socket = $server . ':' . $port; +		} + +		$socket_context = stream_context_create($options); + +		if ($this->connection = @stream_socket_client($remote_socket, $errorno, $errorstr, $this->timeout, STREAM_CLIENT_CONNECT, $socket_context)) +		{ +			stream_set_blocking($this->connection, 0); +			stream_set_timeout($this->connection, 60);  			return true;  		} @@ -563,7 +596,7 @@ class jabber  			case 'proceed':  				// continue switching to TLS  				$meta = stream_get_meta_data($this->connection); -				socket_set_blocking($this->connection, 1); +				stream_set_blocking($this->connection, 1);  				if (!stream_socket_enable_crypto($this->connection, true, STREAM_CRYPTO_METHOD_TLS_CLIENT))  				{ @@ -571,7 +604,7 @@ class jabber  					return false;  				} -				socket_set_blocking($this->connection, $meta['blocked']); +				stream_set_blocking($this->connection, $meta['blocked']);  				$this->session['tls'] = true;  				// new stream diff --git a/phpBB/includes/functions_messenger.php b/phpBB/includes/functions_messenger.php index a6e4cb0679..98975b9d8f 100644 --- a/phpBB/includes/functions_messenger.php +++ b/phpBB/includes/functions_messenger.php @@ -312,10 +312,16 @@ class messenger  	/**  	* Send the mail out to the recipients set previously in var $this->addresses +	* +	* @param int	$method	User notification method NOTIFY_EMAIL|NOTIFY_IM|NOTIFY_BOTH +	* @param bool	$break	Flag indicating if the function only formats the subject +	*						and the message without sending it +	* +	* @return bool  	*/  	function send($method = NOTIFY_EMAIL, $break = false)  	{ -		global $config, $user; +		global $config, $user, $phpbb_dispatcher;  		// We add some standard variables we always use, no need to specify them always  		$this->assign_vars(array( @@ -324,6 +330,30 @@ class messenger  			'SITENAME'	=> htmlspecialchars_decode($config['sitename']),  		)); +		$subject = $this->subject; +		$message = $this->msg; +		/** +		* Event to modify notification message text before parsing +		* +		* @event core.modify_notification_message +		* @var	int		method	User notification method NOTIFY_EMAIL|NOTIFY_IM|NOTIFY_BOTH +		* @var	bool	break	Flag indicating if the function only formats the subject +		*						and the message without sending it +		* @var	string	subject	The message subject +		* @var	string	message	The message text +		* @since 3.1.11-RC1 +		*/ +		$vars = array( +			'method', +			'break', +			'subject', +			'message', +		); +		extract($phpbb_dispatcher->trigger_event('core.modify_notification_message', compact($vars))); +		$this->subject = $subject; +		$this->msg = $message; +		unset($subject, $message); +  		// Parse message through template  		$this->msg = trim($this->template->assign_display('body')); @@ -625,7 +655,7 @@ class messenger  		if (!$use_queue)  		{  			include_once($phpbb_root_path . 'includes/functions_jabber.' . $phpEx); -			$this->jabber = new jabber($config['jab_host'], $config['jab_port'], $config['jab_username'], htmlspecialchars_decode($config['jab_password']), $config['jab_use_ssl']); +			$this->jabber = new jabber($config['jab_host'], $config['jab_port'], $config['jab_username'], htmlspecialchars_decode($config['jab_password']), $config['jab_use_ssl'], $config['jab_verify_peer'], $config['jab_verify_peer_name'], $config['jab_allow_self_signed']);  			if (!$this->jabber->connect())  			{ @@ -800,7 +830,7 @@ class queue  					}  					include_once($phpbb_root_path . 'includes/functions_jabber.' . $phpEx); -					$this->jabber = new jabber($config['jab_host'], $config['jab_port'], $config['jab_username'], htmlspecialchars_decode($config['jab_password']), $config['jab_use_ssl']); +					$this->jabber = new jabber($config['jab_host'], $config['jab_port'], $config['jab_username'], htmlspecialchars_decode($config['jab_password']), $config['jab_use_ssl'], $config['jab_verify_peer'], $config['jab_verify_peer_name'], $config['jab_allow_self_signed']);  					if (!$this->jabber->connect())  					{ @@ -1057,7 +1087,7 @@ function smtpmail($addresses, $subject, $message, &$err_msg, $headers = false)  	$options['ssl'] = array('verify_peer' => $verify_peer, 'verify_peer_name' => $verify_peer_name, 'allow_self_signed' => $allow_self_signed);  	$socket_context = stream_context_create($options); -	$smtp->socket = stream_socket_client($remote_socket, $errno, $errstr, 20, STREAM_CLIENT_CONNECT, $socket_context); +	$smtp->socket = @stream_socket_client($remote_socket, $errno, $errstr, 20, STREAM_CLIENT_CONNECT, $socket_context);  	$collector->uninstall();  	$error_contents = $collector->format_errors(); diff --git a/phpBB/includes/mcp/mcp_main.php b/phpBB/includes/mcp/mcp_main.php index 491697d2e9..69c66639df 100644 --- a/phpBB/includes/mcp/mcp_main.php +++ b/phpBB/includes/mcp/mcp_main.php @@ -630,10 +630,13 @@ function mcp_move_topic($topic_ids)  				*  				* @event core.mcp_main_modify_shadow_sql  				* @var	array	shadow	SQL array to be used by $db->sql_build_array +				* @var	array	row		Topic data  				* @since 3.1.11-RC1 +				* @changed 3.1.11-RC1 Added variable: row  				*/  				$vars = array(  					'shadow', +					'row',  				);  				extract($phpbb_dispatcher->trigger_event('core.mcp_main_modify_shadow_sql', compact($vars))); @@ -1297,11 +1300,14 @@ function mcp_fork_topic($topic_ids)  			* Perform actions before forked topic is created.  			*  			* @event core.mcp_main_modify_fork_sql -			* @var	array	sql_ary	SQL array to be used by $db->sql_build_array +			* @var	array	sql_ary		SQL array to be used by $db->sql_build_array +			* @var	array	topic_row	Topic data  			* @since 3.1.11-RC1 +			* @changed 3.1.11-RC1 Added variable: topic_row  			*/  			$vars = array(  				'sql_ary', +				'topic_row',  			);  			extract($phpbb_dispatcher->trigger_event('core.mcp_main_modify_fork_sql', compact($vars))); | 
