diff options
Diffstat (limited to 'phpBB/includes')
| -rw-r--r-- | phpBB/includes/acp/acp_captcha.php | 65 | ||||
| -rw-r--r-- | phpBB/includes/constants.php | 2 | ||||
| -rw-r--r-- | phpBB/includes/functions_privmsgs.php | 2 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_post.php | 21 | 
4 files changed, 66 insertions, 24 deletions
| diff --git a/phpBB/includes/acp/acp_captcha.php b/phpBB/includes/acp/acp_captcha.php index 1f6fbc2cae..9a3b86a16a 100644 --- a/phpBB/includes/acp/acp_captcha.php +++ b/phpBB/includes/acp/acp_captcha.php @@ -25,7 +25,7 @@ class acp_captcha  	function main($id, $mode)  	{ -		global $db, $user, $auth, $template, $phpbb_log, $request; +		global $user, $auth, $template, $phpbb_log, $request;  		global $config, $phpbb_root_path, $phpbb_admin_path, $phpEx, $phpbb_container;  		$user->add_lang('acp/board'); @@ -53,11 +53,36 @@ class acp_captcha  		else  		{  			$config_vars = array( -				'enable_confirm'		=> array('tpl' => 'REG_ENABLE', 'default' => false), -				'enable_post_confirm'	=> array('tpl' => 'POST_ENABLE', 'default' => false), -				'confirm_refresh'		=> array('tpl' => 'CONFIRM_REFRESH', 'default' => false), -				'max_reg_attempts'		=> array('tpl' => 'REG_LIMIT', 'default' => 0), -				'max_login_attempts'		=> array('tpl' => 'MAX_LOGIN_ATTEMPTS', 'default' => 0), +				'enable_confirm'		=> array( +					'tpl'		=> 'REG_ENABLE', +					'default'	=> false, +					'validate'	=> 'bool', +					'lang'		=> 'VISUAL_CONFIRM_REG', +				), +				'enable_post_confirm'	=> array( +					'tpl'		=> 'POST_ENABLE', +					'default'	=> false, +					'validate'	=> 'bool', +					'lang'		=> 'VISUAL_CONFIRM_POST', +				), +				'confirm_refresh'		=> array( +					'tpl'		=> 'CONFIRM_REFRESH', +					'default'	=> false, +					'validate'	=> 'bool', +					'lang'		=> 'VISUAL_CONFIRM_REFRESH', +				), +				'max_reg_attempts'		=> array( +					'tpl'		=> 'REG_LIMIT', +					'default'	=> 0, +					'validate'	=> 'int:0:99999', +					'lang'		=> 'REG_LIMIT', +				), +				'max_login_attempts'	=> array( +					'tpl'		=> 'MAX_LOGIN_ATTEMPTS', +					'default'	=> 0, +					'validate'	=> 'int:0:99999', +					'lang'		=> 'MAX_LOGIN_ATTEMPTS', +				),  			);  			$this->tpl_name = 'acp_captcha'; @@ -66,12 +91,31 @@ class acp_captcha  			add_form_key($form_key);  			$submit = $request->variable('main_submit', false); +			$error = $cfg_array = array(); -			if ($submit && check_form_key($form_key)) +			if ($submit)  			{  				foreach ($config_vars as $config_var => $options)  				{ -					$config->set($config_var, $request->variable($config_var, $options['default'])); +					$cfg_array[$config_var] = $request->variable($config_var, $options['default']); +				} +				validate_config_vars($config_vars, $cfg_array, $error); + +				if (!check_form_key($form_key)) +				{ +					$error[] = $user->lang['FORM_INVALID']; +				} +				if ($error) +				{ +					$submit = false; +				} +			} + +			if ($submit) +			{ +				foreach ($cfg_array as $key => $value) +				{ +					$config->set($key, $value);  				}  				if ($selected !== $config['captcha_plugin']) @@ -95,10 +139,6 @@ class acp_captcha  				}  				trigger_error($user->lang['CONFIG_UPDATED'] . adm_back_link($this->u_action));  			} -			else if ($submit) -			{ -				trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING); -			}  			else  			{  				$captcha_select = ''; @@ -125,6 +165,7 @@ class acp_captcha  					'CAPTCHA_PREVIEW_TPL'	=> $demo_captcha->get_demo_template($id),  					'S_CAPTCHA_HAS_CONFIG'	=> $demo_captcha->has_config(),  					'CAPTCHA_SELECT'		=> $captcha_select, +					'ERROR_MSG'				=> implode('<br />', $error),  					'U_ACTION'				=> $this->u_action,  				)); diff --git a/phpBB/includes/constants.php b/phpBB/includes/constants.php index f6d62fcdf4..680d5a2b4e 100644 --- a/phpBB/includes/constants.php +++ b/phpBB/includes/constants.php @@ -28,7 +28,7 @@ if (!defined('IN_PHPBB'))  */  // phpBB Version -define('PHPBB_VERSION', '3.2.0-a1-dev'); +define('PHPBB_VERSION', '3.2.0-a2-dev');  // QA-related  // define('PHPBB_QA', 1); diff --git a/phpBB/includes/functions_privmsgs.php b/phpBB/includes/functions_privmsgs.php index b2928d5df8..a54770812e 100644 --- a/phpBB/includes/functions_privmsgs.php +++ b/phpBB/includes/functions_privmsgs.php @@ -1596,7 +1596,7 @@ function get_folder_status($folder_id, $folder)  		'percent'		=> ($user->data['message_limit']) ? (($user->data['message_limit'] > 0) ? floor(($folder['num_messages'] / $user->data['message_limit']) * 100) : 100) : 0,  	); -	$return['message']	= $user->lang('FOLDER_STATUS_MSG', $user->lang('MESSAGES_COUNT', (int) $return['max']), $return['cur'], $return['percent']); +	$return['message']	= $user->lang('FOLDER_STATUS_MSG', $user->lang('MESSAGES_COUNT', (int) $return['max']), (int) $return['cur'], $return['percent']);  	return $return;  } diff --git a/phpBB/includes/mcp/mcp_post.php b/phpBB/includes/mcp/mcp_post.php index e59f0abb04..33aebccb22 100644 --- a/phpBB/includes/mcp/mcp_post.php +++ b/phpBB/includes/mcp/mcp_post.php @@ -549,16 +549,6 @@ function change_poster(&$post_info, $userdata)  	$from_username = $post_info['username'];  	$to_username = $userdata['username']; -	// Renew post info -	$post_info = phpbb_get_post_data(array($post_id), false, true); - -	if (!sizeof($post_info)) -	{ -		trigger_error('POST_NOT_EXIST'); -	} - -	$post_info = $post_info[$post_id]; -  	/**  	* This event allows you to perform additional tasks after changing a post's poster  	* @@ -566,10 +556,21 @@ function change_poster(&$post_info, $userdata)  	* @var	array	userdata	Information on a post's new poster  	* @var	array	post_info	Information on the affected post  	* @since 3.1.6-RC1 +	* @changed 3.1.7-RC1		Change location to prevent post_info from being set to the new post information  	*/  	$vars = array('userdata', 'post_info');  	extract($phpbb_dispatcher->trigger_event('core.mcp_change_poster_after', compact($vars))); +	// Renew post info +	$post_info = phpbb_get_post_data(array($post_id), false, true); + +	if (!sizeof($post_info)) +	{ +		trigger_error('POST_NOT_EXIST'); +	} + +	$post_info = $post_info[$post_id]; +  	// Now add log entry  	$phpbb_log->add('mod', $user->data['user_id'], $user->ip, 'LOG_MCP_CHANGE_POSTER', false, array(  		'forum_id' => $post_info['forum_id'], | 
