diff options
Diffstat (limited to 'phpBB/includes/ucp/ucp_pm_compose.php')
| -rw-r--r-- | phpBB/includes/ucp/ucp_pm_compose.php | 91 | 
1 files changed, 71 insertions, 20 deletions
| diff --git a/phpBB/includes/ucp/ucp_pm_compose.php b/phpBB/includes/ucp/ucp_pm_compose.php index 87dfdf902b..3219771c93 100644 --- a/phpBB/includes/ucp/ucp_pm_compose.php +++ b/phpBB/includes/ucp/ucp_pm_compose.php @@ -586,7 +586,6 @@ function compose_pm($id, $mode, $action, $user_folders = array())  				);  				$s_hidden_fields .= build_address_field($address_list); -  				confirm_box(false, 'SAVE_DRAFT', $s_hidden_fields);  			}  		} @@ -748,7 +747,6 @@ function compose_pm($id, $mode, $action, $user_folders = array())  			$return_box_url = ($action === 'post' || $action === 'edit') ? $outbox_folder_url : $inbox_folder_url;  			$return_box_lang = ($action === 'post' || $action === 'edit') ? 'PM_OUTBOX' : 'PM_INBOX'; -  			$save_message = ($action === 'edit') ? $user->lang['MESSAGE_EDITED'] : $user->lang['MESSAGE_STORED'];  			$message = $save_message . '<br /><br />' . $user->lang('VIEW_PRIVATE_MESSAGE', '<a href="' . $return_message_url . '">', '</a>'); @@ -1006,7 +1004,6 @@ function compose_pm($id, $mode, $action, $user_folders = array())  	// Build hidden address list  	$s_hidden_address_field = build_address_field($address_list); -  	$bbcode_checked		= (isset($enable_bbcode)) ? !$enable_bbcode : (($config['allow_bbcode'] && $auth->acl_get('u_pm_bbcode')) ? !$user->optionget('bbcode') : 1);  	$smilies_checked	= (isset($enable_smilies)) ? !$enable_smilies : (($config['allow_smilies'] && $auth->acl_get('u_pm_smilies')) ? !$user->optionget('smilies') : 1);  	$urls_checked		= (isset($enable_urls)) ? !$enable_urls : 0; @@ -1081,6 +1078,7 @@ function compose_pm($id, $mode, $action, $user_folders = array())  		'S_SAVE_ALLOWED'		=> ($auth->acl_get('u_savedrafts') && $action != 'edit') ? true : false,  		'S_HAS_DRAFTS'			=> ($auth->acl_get('u_savedrafts') && $drafts),  		'S_FORM_ENCTYPE'		=> $form_enctype, +		'S_ATTACH_DATA'			=> json_encode($message_parser->attachment_data),  		'S_BBCODE_IMG'			=> $img_status,  		'S_BBCODE_FLASH'		=> $flash_status, @@ -1104,7 +1102,8 @@ function compose_pm($id, $mode, $action, $user_folders = array())  	if ($allowed)  	{ -		$plupload->configure($cache, $template, $s_action, false); +		$max_files = ($auth->acl_gets('a_', 'm_')) ? 0 : (int) $config['max_attachments_pm']; +		$plupload->configure($cache, $template, $s_action, false, $max_files);  	}  	// Attachment entry @@ -1227,29 +1226,81 @@ function handle_message_list_actions(&$address_list, &$error, $remove_u, $remove  	// Check for disallowed recipients  	if (!empty($address_list['u']))  	{ -		// We need to check their PM status (do they want to receive PM's?) -		// Only check if not a moderator or admin, since they are allowed to override this user setting -		if (!$auth->acl_gets('a_', 'm_') && !$auth->acl_getf_global('m_')) +		// Administrator deactivated users check and we need to check their +		//		PM status (do they want to receive PM's?) +		// 		Only check PM status if not a moderator or admin, since they +		//		are allowed to override this user setting +		$sql = 'SELECT user_id, user_allow_pm +			FROM ' . USERS_TABLE . ' +			WHERE ' . $db->sql_in_set('user_id', array_keys($address_list['u'])) . ' +				AND (user_type = ' . USER_INACTIVE . ' +					AND user_inactive_reason = ' . INACTIVE_MANUAL . ')'; + +		$can_ignore_allow_pm = ($auth->acl_gets('a_', 'm_') || $auth->acl_getf_global('m_')); +		if (!$can_ignore_allow_pm)  		{ -			$sql = 'SELECT user_id -				FROM ' . USERS_TABLE . ' -				WHERE ' . $db->sql_in_set('user_id', array_keys($address_list['u'])) . ' -					AND user_allow_pm = 0'; -			$result = $db->sql_query($sql); +			$sql .= ' OR user_allow_pm = 0'; +		} -			$removed = false; -			while ($row = $db->sql_fetchrow($result)) +		$result = $db->sql_query($sql); + +		$removed_no_pm = $removed_no_permission = false; +		while ($row = $db->sql_fetchrow($result)) +		{ +			if (!$can_ignore_allow_pm && !$row['user_allow_pm'])  			{ -				$removed = true; -				unset($address_list['u'][$row['user_id']]); +				$removed_no_pm = true;  			} -			$db->sql_freeresult($result); +			else +			{ +				$removed_no_permission = true; +			} + +			unset($address_list['u'][$row['user_id']]); +		} +		$db->sql_freeresult($result); -			// print a notice about users not being added who do not want to receive pms -			if ($removed) +		// print a notice about users not being added who do not want to receive pms +		if ($removed_no_pm) +		{ +			$error[] = $user->lang['PM_USERS_REMOVED_NO_PM']; +		} + +		// print a notice about users not being added who do not have permission to receive PMs +		if ($removed_no_permission) +		{ +			$error[] = $user->lang['PM_USERS_REMOVED_NO_PERMISSION']; +		} + +		if (!sizeof(array_keys($address_list['u']))) +		{ +			return; +		} + +		// Check if users have permission to read PMs +		$can_read = $auth->acl_get_list(array_keys($address_list['u']), 'u_readpm'); +		$can_read = (empty($can_read) || !isset($can_read[0]['u_readpm'])) ? array() : $can_read[0]['u_readpm']; +		$cannot_read_list = array_diff(array_keys($address_list['u']), $can_read); +		if (!empty($cannot_read_list)) +		{ +			foreach ($cannot_read_list as $cannot_read) +			{ +				unset($address_list['u'][$cannot_read]); +			} + +			$error[] = $user->lang['PM_USERS_REMOVED_NO_PERMISSION']; +		} + +		// Check if users are banned +		$banned_user_list = phpbb_get_banned_user_ids(array_keys($address_list['u']), false); +		if (!empty($banned_user_list)) +		{ +			foreach ($banned_user_list as $banned_user)  			{ -				$error[] = $user->lang['PM_USERS_REMOVED_NO_PM']; +				unset($address_list['u'][$banned_user]);  			} + +			$error[] = $user->lang['PM_USERS_REMOVED_NO_PERMISSION'];  		}  	}  } | 
