mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-24 21:26:24 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			413 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			413 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
| *
 | |
| * This file is part of the phpBB Forum Software package.
 | |
| *
 | |
| * @copyright (c) phpBB Limited <https://www.phpbb.com>
 | |
| * @license GNU General Public License, version 2 (GPL-2.0)
 | |
| *
 | |
| * For full copyright and license information, please see
 | |
| * the docs/CREDITS.txt file.
 | |
| *
 | |
| */
 | |
| 
 | |
| /**
 | |
| * @ignore
 | |
| */
 | |
| if (!defined('IN_PHPBB'))
 | |
| {
 | |
| 	exit;
 | |
| }
 | |
| 
 | |
| /**
 | |
| * Private Message Class
 | |
| *
 | |
| * $_REQUEST['folder'] display folder with the id used
 | |
| * $_REQUEST['folder'] inbox|outbox|sentbox display folder with the associated name
 | |
| *
 | |
| *	Display Messages (default to inbox) - mode=view
 | |
| *	Display single message - mode=view&p=[msg_id] or &p=[msg_id] (short linkage)
 | |
| *
 | |
| *	if the folder id with (&f=[folder_id]) is used when displaying messages, one query will be saved. If it is not used, phpBB needs to grab
 | |
| *	the folder id first in order to display the input boxes and folder names and such things. ;) phpBB always checks this against the database to make
 | |
| *	sure the user is able to view the message.
 | |
| *
 | |
| *	Composing Messages (mode=compose):
 | |
| *		To specific user (u=[user_id])
 | |
| *		To specific group (g=[group_id])
 | |
| *		Quoting a post (action=quotepost&p=[post_id])
 | |
| *		Quoting a PM (action=quote&p=[msg_id])
 | |
| *		Forwarding a PM (action=forward&p=[msg_id])
 | |
| */
 | |
| class ucp_pm
 | |
| {
 | |
| 	var $u_action;
 | |
| 
 | |
| 	function main($id, $mode)
 | |
| 	{
 | |
| 		global $user, $template, $phpbb_root_path, $auth, $phpEx, $db, $config, $request;
 | |
| 
 | |
| 		if (!$user->data['is_registered'])
 | |
| 		{
 | |
| 			trigger_error('NO_MESSAGE');
 | |
| 		}
 | |
| 
 | |
| 		// Is PM disabled?
 | |
| 		if (!$config['allow_privmsg'])
 | |
| 		{
 | |
| 			trigger_error('PM_DISABLED');
 | |
| 		}
 | |
| 
 | |
| 		$user->add_lang('posting');
 | |
| 		$template->assign_var('S_PRIVMSGS', true);
 | |
| 
 | |
| 		// Folder directly specified?
 | |
| 		$folder_specified = $request->variable('folder', '');
 | |
| 
 | |
| 		if (!in_array($folder_specified, array('inbox', 'outbox', 'sentbox')))
 | |
| 		{
 | |
| 			$folder_specified = (int) $folder_specified;
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$folder_specified = ($folder_specified == 'inbox') ? PRIVMSGS_INBOX : (($folder_specified == 'outbox') ? PRIVMSGS_OUTBOX : PRIVMSGS_SENTBOX);
 | |
| 		}
 | |
| 
 | |
| 		if (!$folder_specified)
 | |
| 		{
 | |
| 			$mode = (!$mode) ? $request->variable('mode', 'view') : $mode;
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$mode = 'view';
 | |
| 		}
 | |
| 
 | |
| 		include($phpbb_root_path . 'includes/functions_privmsgs.' . $phpEx);
 | |
| 
 | |
| 		switch ($mode)
 | |
| 		{
 | |
| 			// Compose message
 | |
| 			case 'compose':
 | |
| 				$action = $request->variable('action', 'post');
 | |
| 
 | |
| 				$user_folders = get_folder($user->data['user_id']);
 | |
| 
 | |
| 				if ($action != 'delete' && !$auth->acl_get('u_sendpm'))
 | |
| 				{
 | |
| 					// trigger_error('NO_AUTH_SEND_MESSAGE');
 | |
| 					$template->assign_vars(array(
 | |
| 						'S_NO_AUTH_SEND_MESSAGE'	=> true,
 | |
| 						'S_COMPOSE_PM_VIEW'			=> true,
 | |
| 					));
 | |
| 
 | |
| 					$tpl_file = 'ucp_pm_viewfolder';
 | |
| 					break;
 | |
| 				}
 | |
| 
 | |
| 				include($phpbb_root_path . 'includes/ucp/ucp_pm_compose.' . $phpEx);
 | |
| 				compose_pm($id, $mode, $action, $user_folders);
 | |
| 
 | |
| 				$tpl_file = 'posting_body';
 | |
| 			break;
 | |
| 
 | |
| 			case 'options':
 | |
| 				set_user_message_limit();
 | |
| 				get_folder($user->data['user_id']);
 | |
| 
 | |
| 				include($phpbb_root_path . 'includes/ucp/ucp_pm_options.' . $phpEx);
 | |
| 				message_options($id, $mode, $global_privmsgs_rules, $global_rule_conditions);
 | |
| 
 | |
| 				$tpl_file = 'ucp_pm_options';
 | |
| 			break;
 | |
| 
 | |
| 			case 'drafts':
 | |
| 
 | |
| 				get_folder($user->data['user_id']);
 | |
| 				$this->p_name = 'pm';
 | |
| 
 | |
| 				// Call another module... please do not try this at home... Hoochie Coochie Man
 | |
| 				include($phpbb_root_path . 'includes/ucp/ucp_main.' . $phpEx);
 | |
| 
 | |
| 				$module = new ucp_main($this);
 | |
| 				$module->u_action = $this->u_action;
 | |
| 				$module->main($id, $mode);
 | |
| 
 | |
| 				$this->tpl_name = $module->tpl_name;
 | |
| 				$this->page_title = 'UCP_PM_DRAFTS';
 | |
| 
 | |
| 				unset($module);
 | |
| 				return;
 | |
| 
 | |
| 			break;
 | |
| 
 | |
| 			case 'view':
 | |
| 
 | |
| 				set_user_message_limit();
 | |
| 
 | |
| 				if ($folder_specified)
 | |
| 				{
 | |
| 					$folder_id = $folder_specified;
 | |
| 					$action = 'view_folder';
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					$folder_id = $request->variable('f', PRIVMSGS_NO_BOX);
 | |
| 					$action = $request->variable('action', 'view_folder');
 | |
| 				}
 | |
| 
 | |
| 				$msg_id = $request->variable('p', 0);
 | |
| 				$view	= $request->variable('view', '');
 | |
| 
 | |
| 				// View message if specified
 | |
| 				if ($msg_id)
 | |
| 				{
 | |
| 					$action = 'view_message';
 | |
| 				}
 | |
| 
 | |
| 				if (!$auth->acl_get('u_readpm'))
 | |
| 				{
 | |
| 					send_status_line(403, 'Forbidden');
 | |
| 					trigger_error('NO_AUTH_READ_MESSAGE');
 | |
| 				}
 | |
| 
 | |
| 				// Do not allow hold messages to be seen
 | |
| 				if ($folder_id == PRIVMSGS_HOLD_BOX)
 | |
| 				{
 | |
| 					trigger_error('NO_AUTH_READ_HOLD_MESSAGE');
 | |
| 				}
 | |
| 
 | |
| 				// First Handle Mark actions and moving messages
 | |
| 				$submit_mark	= (isset($_POST['submit_mark'])) ? true : false;
 | |
| 				$move_pm		= (isset($_POST['move_pm'])) ? true : false;
 | |
| 				$mark_option	= $request->variable('mark_option', '');
 | |
| 				$dest_folder	= $request->variable('dest_folder', PRIVMSGS_NO_BOX);
 | |
| 
 | |
| 				// Is moving PM triggered through mark options?
 | |
| 				if (!in_array($mark_option, array('mark_important', 'delete_marked')) && $submit_mark)
 | |
| 				{
 | |
| 					$move_pm = true;
 | |
| 					$dest_folder = (int) $mark_option;
 | |
| 					$submit_mark = false;
 | |
| 				}
 | |
| 
 | |
| 				// Move PM
 | |
| 				if ($move_pm)
 | |
| 				{
 | |
| 					$move_msg_ids	= (isset($_POST['marked_msg_id'])) ? $request->variable('marked_msg_id', array(0)) : array();
 | |
| 					$cur_folder_id	= $request->variable('cur_folder_id', PRIVMSGS_NO_BOX);
 | |
| 
 | |
| 					if (move_pm($user->data['user_id'], $user->data['message_limit'], $move_msg_ids, $dest_folder, $cur_folder_id))
 | |
| 					{
 | |
| 						// Return to folder view if single message moved
 | |
| 						if ($action == 'view_message')
 | |
| 						{
 | |
| 							$msg_id		= 0;
 | |
| 							$folder_id	= $request->variable('cur_folder_id', PRIVMSGS_NO_BOX);
 | |
| 							$action		= 'view_folder';
 | |
| 						}
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				// Message Mark Options
 | |
| 				if ($submit_mark)
 | |
| 				{
 | |
| 					handle_mark_actions($user->data['user_id'], $mark_option);
 | |
| 				}
 | |
| 
 | |
| 				// If new messages arrived, place them into the appropriate folder
 | |
| 				$num_not_moved = $num_removed = 0;
 | |
| 				$release = $request->variable('release', 0);
 | |
| 
 | |
| 				if ($user->data['user_new_privmsg'] && ($action == 'view_folder' || $action == 'view_message'))
 | |
| 				{
 | |
| 					$return = place_pm_into_folder($global_privmsgs_rules, $release);
 | |
| 					$num_not_moved = $return['not_moved'];
 | |
| 					$num_removed = $return['removed'];
 | |
| 				}
 | |
| 
 | |
| 				if (!$msg_id && $folder_id == PRIVMSGS_NO_BOX)
 | |
| 				{
 | |
| 					$folder_id = PRIVMSGS_INBOX;
 | |
| 				}
 | |
| 				else if ($msg_id && $folder_id == PRIVMSGS_NO_BOX)
 | |
| 				{
 | |
| 					$sql = 'SELECT folder_id
 | |
| 						FROM ' . PRIVMSGS_TO_TABLE . "
 | |
| 						WHERE msg_id = $msg_id
 | |
| 							AND folder_id <> " . PRIVMSGS_NO_BOX . '
 | |
| 							AND user_id = ' . $user->data['user_id'];
 | |
| 					$result = $db->sql_query($sql);
 | |
| 					$row = $db->sql_fetchrow($result);
 | |
| 					$db->sql_freeresult($result);
 | |
| 
 | |
| 					if (!$row)
 | |
| 					{
 | |
| 						trigger_error('NO_MESSAGE');
 | |
| 					}
 | |
| 					$folder_id = (int) $row['folder_id'];
 | |
| 				}
 | |
| 
 | |
| 				if ($request->variable('mark', '') == 'all' && check_link_hash($request->variable('token', ''), 'mark_all_pms_read'))
 | |
| 				{
 | |
| 					mark_folder_read($user->data['user_id'], $folder_id);
 | |
| 
 | |
| 					meta_refresh(3, $this->u_action);
 | |
| 					$message = $user->lang['PM_MARK_ALL_READ_SUCCESS'];
 | |
| 
 | |
| 					if ($request->is_ajax())
 | |
| 					{
 | |
| 						$json_response = new \phpbb\json_response();
 | |
| 						$json_response->send(array(
 | |
| 							'MESSAGE_TITLE'	=> $user->lang['INFORMATION'],
 | |
| 							'MESSAGE_TEXT'	=> $message,
 | |
| 							'success'		=> true,
 | |
| 						));
 | |
| 					}
 | |
| 					$message .= '<br /><br />' . $user->lang('RETURN_UCP', '<a href="' . $this->u_action . '">', '</a>');
 | |
| 
 | |
| 					trigger_error($message);
 | |
| 				}
 | |
| 
 | |
| 				$message_row = array();
 | |
| 				if ($action == 'view_message' && $msg_id)
 | |
| 				{
 | |
| 					// Get Message user want to see
 | |
| 					if ($view == 'next' || $view == 'previous')
 | |
| 					{
 | |
| 						$sql_condition = ($view == 'next') ? '>' : '<';
 | |
| 						$sql_ordering = ($view == 'next') ? 'ASC' : 'DESC';
 | |
| 
 | |
| 						$sql = 'SELECT t.msg_id
 | |
| 							FROM ' . PRIVMSGS_TO_TABLE . ' t, ' . PRIVMSGS_TABLE . ' p, ' . PRIVMSGS_TABLE . " p2
 | |
| 							WHERE p2.msg_id = $msg_id
 | |
| 								AND t.folder_id = $folder_id
 | |
| 								AND t.user_id = " . $user->data['user_id'] . "
 | |
| 								AND t.msg_id = p.msg_id
 | |
| 								AND p.message_time $sql_condition p2.message_time
 | |
| 							ORDER BY p.message_time $sql_ordering";
 | |
| 						$result = $db->sql_query_limit($sql, 1);
 | |
| 						$row = $db->sql_fetchrow($result);
 | |
| 						$db->sql_freeresult($result);
 | |
| 
 | |
| 						if (!$row)
 | |
| 						{
 | |
| 							$message = ($view == 'next') ? 'NO_NEWER_PM' : 'NO_OLDER_PM';
 | |
| 							trigger_error($message);
 | |
| 						}
 | |
| 						else
 | |
| 						{
 | |
| 							$msg_id = $row['msg_id'];
 | |
| 						}
 | |
| 					}
 | |
| 
 | |
| 					$sql = 'SELECT t.*, p.*, u.*
 | |
| 						FROM ' . PRIVMSGS_TO_TABLE . ' t, ' . PRIVMSGS_TABLE . ' p, ' . USERS_TABLE . ' u
 | |
| 						WHERE t.user_id = ' . $user->data['user_id'] . "
 | |
| 							AND p.author_id = u.user_id
 | |
| 							AND t.folder_id = $folder_id
 | |
| 							AND t.msg_id = p.msg_id
 | |
| 							AND p.msg_id = $msg_id";
 | |
| 					$result = $db->sql_query($sql);
 | |
| 					$message_row = $db->sql_fetchrow($result);
 | |
| 					$db->sql_freeresult($result);
 | |
| 
 | |
| 					if (!$message_row)
 | |
| 					{
 | |
| 						trigger_error('NO_MESSAGE');
 | |
| 					}
 | |
| 
 | |
| 					// Update unread status
 | |
| 					update_unread_status($message_row['pm_unread'], $message_row['msg_id'], $user->data['user_id'], $folder_id);
 | |
| 				}
 | |
| 
 | |
| 				$folder = get_folder($user->data['user_id'], $folder_id);
 | |
| 
 | |
| 				$s_folder_options = $s_to_folder_options = '';
 | |
| 				foreach ($folder as $f_id => $folder_ary)
 | |
| 				{
 | |
| 					$option = '<option' . ((!in_array($f_id, array(PRIVMSGS_INBOX, PRIVMSGS_OUTBOX, PRIVMSGS_SENTBOX))) ? ' class="sep"' : '') . ' value="' . $f_id . '"' . (($f_id == $folder_id) ? ' selected="selected"' : '') . '>' . $folder_ary['folder_name'] . (($folder_ary['unread_messages']) ? ' [' . $folder_ary['unread_messages'] . '] ' : '') . '</option>';
 | |
| 
 | |
| 					$s_to_folder_options .= ($f_id != PRIVMSGS_OUTBOX && $f_id != PRIVMSGS_SENTBOX) ? $option : '';
 | |
| 					$s_folder_options .= $option;
 | |
| 				}
 | |
| 				clean_sentbox($folder[PRIVMSGS_SENTBOX]['num_messages']);
 | |
| 
 | |
| 				// Header for message view - folder and so on
 | |
| 				$folder_status = get_folder_status($folder_id, $folder);
 | |
| 
 | |
| 				$template->assign_vars(array(
 | |
| 					'CUR_FOLDER_ID'			=> $folder_id,
 | |
| 					'CUR_FOLDER_NAME'		=> $folder_status['folder_name'],
 | |
| 					'NUM_NOT_MOVED'			=> $num_not_moved,
 | |
| 					'NUM_REMOVED'			=> $num_removed,
 | |
| 					'RELEASE_MESSAGE_INFO'	=> sprintf($user->lang['RELEASE_MESSAGES'], '<a href="' . $this->u_action . '&folder=' . $folder_id . '&release=1">', '</a>'),
 | |
| 					'NOT_MOVED_MESSAGES'	=> $user->lang('NOT_MOVED_MESSAGES', (int) $num_not_moved),
 | |
| 					'RULE_REMOVED_MESSAGES'	=> $user->lang('RULE_REMOVED_MESSAGES', (int) $num_removed),
 | |
| 
 | |
| 					'S_FOLDER_OPTIONS'		=> $s_folder_options,
 | |
| 					'S_TO_FOLDER_OPTIONS'	=> $s_to_folder_options,
 | |
| 					'S_FOLDER_ACTION'		=> $this->u_action . '&action=view_folder',
 | |
| 					'S_PM_ACTION'			=> $this->u_action . '&action=' . $action,
 | |
| 
 | |
| 					'U_INBOX'				=> $this->u_action . '&folder=inbox',
 | |
| 					'U_OUTBOX'				=> $this->u_action . '&folder=outbox',
 | |
| 					'U_SENTBOX'				=> $this->u_action . '&folder=sentbox',
 | |
| 					'U_CREATE_FOLDER'		=> $this->u_action . '&mode=options',
 | |
| 					'U_CURRENT_FOLDER'		=> $this->u_action . '&folder=' . $folder_id,
 | |
| 					'U_MARK_ALL'			=> $this->u_action . '&folder=' . $folder_id . '&mark=all&token=' . generate_link_hash('mark_all_pms_read'),
 | |
| 
 | |
| 					'S_IN_INBOX'			=> ($folder_id == PRIVMSGS_INBOX) ? true : false,
 | |
| 					'S_IN_OUTBOX'			=> ($folder_id == PRIVMSGS_OUTBOX) ? true : false,
 | |
| 					'S_IN_SENTBOX'			=> ($folder_id == PRIVMSGS_SENTBOX) ? true : false,
 | |
| 
 | |
| 					'FOLDER_STATUS'				=> $folder_status['message'],
 | |
| 					'FOLDER_MAX_MESSAGES'		=> $folder_status['max'],
 | |
| 					'FOLDER_CUR_MESSAGES'		=> $folder_status['cur'],
 | |
| 					'FOLDER_REMAINING_MESSAGES'	=> $folder_status['remaining'],
 | |
| 					'FOLDER_PERCENT'			=> $folder_status['percent'])
 | |
| 				);
 | |
| 
 | |
| 				if ($action == 'view_folder')
 | |
| 				{
 | |
| 					include($phpbb_root_path . 'includes/ucp/ucp_pm_viewfolder.' . $phpEx);
 | |
| 					view_folder($id, $mode, $folder_id, $folder);
 | |
| 
 | |
| 					$tpl_file = 'ucp_pm_viewfolder';
 | |
| 				}
 | |
| 				else if ($action == 'view_message')
 | |
| 				{
 | |
| 					$template->assign_vars(array(
 | |
| 						'S_VIEW_MESSAGE'		=> true,
 | |
| 						'L_RETURN_TO_FOLDER'	=> $user->lang('RETURN_TO', $folder_status['folder_name']),
 | |
| 						'MSG_ID'				=> $msg_id,
 | |
| 					));
 | |
| 
 | |
| 					if (!$msg_id)
 | |
| 					{
 | |
| 						trigger_error('NO_MESSAGE');
 | |
| 					}
 | |
| 
 | |
| 					include($phpbb_root_path . 'includes/ucp/ucp_pm_viewmessage.' . $phpEx);
 | |
| 					view_message($id, $mode, $folder_id, $msg_id, $folder, $message_row);
 | |
| 
 | |
| 					$tpl_file = ($view == 'print') ? 'ucp_pm_viewmessage_print' : 'ucp_pm_viewmessage';
 | |
| 				}
 | |
| 
 | |
| 			break;
 | |
| 
 | |
| 			default:
 | |
| 				trigger_error('NO_ACTION_MODE', E_USER_ERROR);
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		$template->assign_vars(array(
 | |
| 			'L_TITLE'			=> $user->lang['UCP_PM_' . strtoupper($mode)],
 | |
| 			'S_UCP_ACTION'		=> $this->u_action . ((isset($action)) ? "&action=$action" : ''))
 | |
| 		);
 | |
| 
 | |
| 		// Set desired template
 | |
| 		$this->tpl_name = $tpl_file;
 | |
| 		$this->page_title = 'UCP_PM_' . strtoupper($mode);
 | |
| 	}
 | |
| }
 |