diff options
| author | Josh Woody <a_jelly_doughnut@phpbb.com> | 2010-06-17 23:58:18 -0500 | 
|---|---|---|
| committer | Joas Schilling <nickvergessen@gmx.de> | 2012-08-29 17:49:37 +0200 | 
| commit | b8c55291ed7ed86565be2bc651bf20eb1a9ed4dd (patch) | |
| tree | 1fc8b7f01084dc64243476683de5587278406110 /phpBB/includes | |
| parent | 1128ff1e580361db7f7ecc72d496fdd347cbe0f2 (diff) | |
| download | forums-b8c55291.tar forums-b8c55291.tar.gz forums-b8c55291.tar.bz2 forums-b8c55291.tar.xz forums-b8c55291.zip | |
[feature/soft-delete] Lay the groundwork for a soft-delete feature
So far, I've added no new functionality.  The biggest change here is adjusting the DB column names to "visibility" rather than "approved".  Some things here are pretty likely to change, for example the name and location of the topic_visibility class. Happy birthday phpBB :)
PHPBB3-9657
Diffstat (limited to 'phpBB/includes')
| -rw-r--r-- | phpBB/includes/acp/acp_forums.php | 8 | ||||
| -rw-r--r-- | phpBB/includes/acp/acp_main.php | 6 | ||||
| -rw-r--r-- | phpBB/includes/acp/acp_users.php | 4 | ||||
| -rw-r--r-- | phpBB/includes/constants.php | 4 | ||||
| -rw-r--r-- | phpBB/includes/functions_admin.php | 77 | ||||
| -rw-r--r-- | phpBB/includes/functions_convert.php | 6 | ||||
| -rw-r--r-- | phpBB/includes/functions_posting.php | 64 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_forum.php | 10 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_front.php | 4 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_main.php | 12 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_post.php | 4 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_queue.php | 12 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_reports.php | 2 | ||||
| -rw-r--r-- | phpBB/includes/mcp/mcp_topic.php | 22 | ||||
| -rw-r--r-- | phpBB/includes/search/fulltext_mysql.php | 14 | ||||
| -rw-r--r-- | phpBB/includes/search/fulltext_native.php | 15 | 
16 files changed, 142 insertions, 122 deletions
| diff --git a/phpBB/includes/acp/acp_forums.php b/phpBB/includes/acp/acp_forums.php index c6dbf5eb9c..622d84d15e 100644 --- a/phpBB/includes/acp/acp_forums.php +++ b/phpBB/includes/acp/acp_forums.php @@ -314,7 +314,7 @@ class acp_forums  					$end = $start + $batch_size;  					// Sync all topics in batch mode... -					sync('topic_approved', 'range', 'topic_id BETWEEN ' . $start . ' AND ' . $end, true, false); +					sync('topic_visibility', 'range', 'topic_id BETWEEN ' . $start . ' AND ' . $end, true, false);  					sync('topic', 'range', 'topic_id BETWEEN ' . $start . ' AND ' . $end, true, true);  					if ($end < $row2['max_topic_id']) @@ -1793,7 +1793,7 @@ class acp_forums  			FROM ' . POSTS_TABLE . '  			WHERE forum_id = ' . $forum_id . '  				AND post_postcount = 1 -				AND post_approved = 1'; +				AND post_visibility = ' . ITEM_APPROVED;  		$result = $db->sql_query($sql);  		$post_counts = array(); @@ -1931,7 +1931,7 @@ class acp_forums  		// Make sure the overall post/topic count is correct...  		$sql = 'SELECT COUNT(post_id) AS stat  			FROM ' . POSTS_TABLE . ' -			WHERE post_approved = 1'; +			WHERE post_visibility = ' . ITEM_APPROVED;  		$result = $db->sql_query($sql);  		$row = $db->sql_fetchrow($result);  		$db->sql_freeresult($result); @@ -1940,7 +1940,7 @@ class acp_forums  		$sql = 'SELECT COUNT(topic_id) AS stat  			FROM ' . TOPICS_TABLE . ' -			WHERE topic_approved = 1'; +			WHERE topic_visibility = ' . ITEM_APPROVED;  		$result = $db->sql_query($sql);  		$row = $db->sql_fetchrow($result);  		$db->sql_freeresult($result); diff --git a/phpBB/includes/acp/acp_main.php b/phpBB/includes/acp/acp_main.php index eb613535bf..0584bb510e 100644 --- a/phpBB/includes/acp/acp_main.php +++ b/phpBB/includes/acp/acp_main.php @@ -144,14 +144,14 @@ class acp_main  						$sql = 'SELECT COUNT(post_id) AS stat  							FROM ' . POSTS_TABLE . ' -							WHERE post_approved = 1'; +							WHERE post_visibility = ' . ITEM_APPROVED;  						$result = $db->sql_query($sql);  						set_config('num_posts', (int) $db->sql_fetchfield('stat'), true);  						$db->sql_freeresult($result);  						$sql = 'SELECT COUNT(topic_id) AS stat  							FROM ' . TOPICS_TABLE . ' -							WHERE topic_approved = 1'; +							WHERE topic_visibility = ' . ITEM_APPROVED;  						$result = $db->sql_query($sql);  						set_config('num_topics', (int) $db->sql_fetchfield('stat'), true);  						$db->sql_freeresult($result); @@ -232,7 +232,7 @@ class acp_main  							$sql = 'SELECT COUNT(post_id) AS num_posts, poster_id  								FROM ' . POSTS_TABLE . '  								WHERE post_id BETWEEN ' . ($start + 1) . ' AND ' . ($start + $step) . ' -									AND post_postcount = 1 AND post_approved = 1 +									AND post_postcount = 1 AND post_visibility = ' . ITEM_APPROVED . '  								GROUP BY poster_id';  							$result = $db->sql_query($sql); diff --git a/phpBB/includes/acp/acp_users.php b/phpBB/includes/acp/acp_users.php index b54257b04a..304027df45 100644 --- a/phpBB/includes/acp/acp_users.php +++ b/phpBB/includes/acp/acp_users.php @@ -676,7 +676,7 @@ class acp_users  										'topic_time'				=> time(),  										'forum_id' 					=> $new_forum_id,  										'icon_id'					=> 0, -										'topic_approved'			=> 1, +										'topic_visibility'			=> ITEM_APPROVED,  										'topic_title' 				=> $post_ary['title'],  										'topic_first_poster_name'	=> $user_row['username'],  										'topic_type'				=> POST_NORMAL, @@ -1033,7 +1033,7 @@ class acp_users  				$sql = 'SELECT COUNT(post_id) as posts_in_queue  					FROM ' . POSTS_TABLE . '  					WHERE poster_id = ' . $user_id . ' -						AND post_approved = 0'; +						AND post_visibility = ' . ITEM_UNAPPROVED;  				$result = $db->sql_query($sql);  				$user_row['posts_in_queue'] = (int) $db->sql_fetchfield('posts_in_queue');  				$db->sql_freeresult($result); diff --git a/phpBB/includes/constants.php b/phpBB/includes/constants.php index 68af41ab20..62c06dc1d0 100644 --- a/phpBB/includes/constants.php +++ b/phpBB/includes/constants.php @@ -87,6 +87,10 @@ define('ITEM_UNLOCKED', 0);  define('ITEM_LOCKED', 1);  define('ITEM_MOVED', 2); +define('ITEM_UNAPPROVED', 0); // => has not yet been approved +define('ITEM_APPROVED', 1); // => has been approved, and has not been soft deleted +define('ITEM_DELETED', 2); // => has been soft deleted +  // Forum Flags  define('FORUM_FLAG_LINK_TRACK', 1);  define('FORUM_FLAG_PRUNE_POLL', 2); diff --git a/phpBB/includes/functions_admin.php b/phpBB/includes/functions_admin.php index 5e2ee8c8f6..328c8e9778 100644 --- a/phpBB/includes/functions_admin.php +++ b/phpBB/includes/functions_admin.php @@ -644,7 +644,7 @@ function delete_topics($where_type, $where_ids, $auto_sync = true, $post_count_s  		'posts' => ($call_delete_posts) ? delete_posts($where_type, $where_ids, false, true, $post_count_sync, false) : 0,  	); -	$sql = 'SELECT topic_id, forum_id, topic_approved, topic_moved_id +	$sql = 'SELECT topic_id, forum_id, topic_visibility, topic_moved_id  		FROM ' . TOPICS_TABLE . '  		WHERE ' . $where_clause;  	$result = $db->sql_query($sql); @@ -654,7 +654,7 @@ function delete_topics($where_type, $where_ids, $auto_sync = true, $post_count_s  		$forum_ids[] = $row['forum_id'];  		$topic_ids[] = $row['topic_id']; -		if ($row['topic_approved'] && !$row['topic_moved_id']) +		if ($row['topic_visibility'] == ITEM_APPROVED && !$row['topic_moved_id'])  		{  			$approved_topics++;  		} @@ -767,7 +767,7 @@ function delete_posts($where_type, $where_ids, $auto_sync = true, $posted_sync =  	$approved_posts = 0;  	$post_ids = $topic_ids = $forum_ids = $post_counts = $remove_topics = array(); -	$sql = 'SELECT post_id, poster_id, post_approved, post_postcount, topic_id, forum_id +	$sql = 'SELECT post_id, poster_id, post_visibility, post_postcount, topic_id, forum_id  		FROM ' . POSTS_TABLE . '  		WHERE ' . $where_clause;  	$result = $db->sql_query($sql); @@ -779,12 +779,12 @@ function delete_posts($where_type, $where_ids, $auto_sync = true, $posted_sync =  		$topic_ids[] = (int) $row['topic_id'];  		$forum_ids[] = (int) $row['forum_id']; -		if ($row['post_postcount'] && $post_count_sync && $row['post_approved']) +		if ($row['post_postcount'] && $post_count_sync && $row['post_visibility'] == ITEM_APPROVED)  		{  			$post_counts[$row['poster_id']] = (!empty($post_counts[$row['poster_id']])) ? $post_counts[$row['poster_id']] + 1 : 1;  		} -		if ($row['post_approved']) +		if ($row['post_visibility'] == ITEM_APPROVED)  		{  			$approved_posts++;  		} @@ -1274,7 +1274,7 @@ function phpbb_unlink($filename, $mode = 'file', $entry_removed = false)  * - forum				Resync complete forum  * - topic				Resync topics  * - topic_moved			Removes topic shadows that would be in the same forum as the topic they link to -* - topic_approved		Resyncs the topic_approved flag according to the status of the first post +* - topic_visibility	Resyncs the topic_visibility flag according to the status of the first post  * - post_reported		Resyncs the post_reported flag, relying on actual reports  * - topic_reported		Resyncs the topic_reported flag, relying on post_reported flags  * - post_attachement	Same as post_reported, but with attachment flags @@ -1294,7 +1294,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  		$where_ids = ($where_ids) ? array((int) $where_ids) : array();  	} -	if ($mode == 'forum' || $mode == 'topic' || $mode == 'topic_approved' || $mode == 'topic_reported' || $mode == 'post_reported') +	if ($mode == 'forum' || $mode == 'topic' || $mode == 'topic_visibility' || $mode == 'topic_reported' || $mode == 'post_reported')  	{  		if (!$where_type)  		{ @@ -1380,7 +1380,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  			$db->sql_transaction('commit');  			break; -		case 'topic_approved': +		case 'topic_visibility':  			$db->sql_transaction('begin');  			switch ($db->sql_layer) @@ -1388,22 +1388,22 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  				case 'mysql4':  				case 'mysqli':  					$sql = 'UPDATE ' . TOPICS_TABLE . ' t, ' . POSTS_TABLE . " p -						SET t.topic_approved = p.post_approved +						SET t.topic_visibility = p.post_visibility  						$where_sql_and t.topic_first_post_id = p.post_id";  					$db->sql_query($sql);  				break;  				default: -					$sql = 'SELECT t.topic_id, p.post_approved +					$sql = 'SELECT t.topic_id, p.post_visibility  						FROM ' . TOPICS_TABLE . ' t, ' . POSTS_TABLE . " p  						$where_sql_and p.post_id = t.topic_first_post_id -							AND p.post_approved <> t.topic_approved"; +							AND p.post_visibility <> t.topic_visibility";  					$result = $db->sql_query($sql);  					$topic_ids = array();  					while ($row = $db->sql_fetchrow($result))  					{ -						$topic_ids[] = $row['topic_id']; +						$topic_ids[$row['topic_id']] = $row['post_visibility'];  					}  					$db->sql_freeresult($result); @@ -1412,10 +1412,13 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  						return;  					} -					$sql = 'UPDATE ' . TOPICS_TABLE . ' -						SET topic_approved = 1 - topic_approved -						WHERE ' . $db->sql_in_set('topic_id', $topic_ids); -					$db->sql_query($sql); +					foreach ($topic_ids as $topic_id => $visibility) +					{ +						$sql = 'UPDATE ' . TOPICS_TABLE . ' +							SET topic_visibility = ' . $visibility . ' +							WHERE topic_id' . $topic_id; +						$db->sql_query($sql); +					}  				break;  			} @@ -1680,10 +1683,10 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  			// 2: Get topic counts for each forum (optional)  			if ($sync_extra)  			{ -				$sql = 'SELECT forum_id, topic_approved, COUNT(topic_id) AS forum_topics +				$sql = 'SELECT forum_id, topic_visibility, COUNT(topic_id) AS forum_topics  					FROM ' . TOPICS_TABLE . '  					WHERE ' . $db->sql_in_set('forum_id', $forum_ids) . ' -					GROUP BY forum_id, topic_approved'; +					GROUP BY forum_id, topic_visibility';  				$result = $db->sql_query($sql);  				while ($row = $db->sql_fetchrow($result)) @@ -1691,7 +1694,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  					$forum_id = (int) $row['forum_id'];  					$forum_data[$forum_id]['topics_real'] += $row['forum_topics']; -					if ($row['topic_approved']) +					if ($row['topic_visibility'] == ITEM_APPROVED)  					{  						$forum_data[$forum_id]['topics'] = $row['forum_topics'];  					} @@ -1707,7 +1710,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  					$sql = 'SELECT SUM(t.topic_replies + 1) AS forum_posts  						FROM ' . TOPICS_TABLE . ' t  						WHERE ' . $db->sql_in_set('t.forum_id', $forum_ids) . ' -							AND t.topic_approved = 1 +							AND t.topic_visibility = ' . ITEM_APPROVED . '  							AND t.topic_status <> ' . ITEM_MOVED;  				}  				else @@ -1715,7 +1718,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  					$sql = 'SELECT t.forum_id, SUM(t.topic_replies + 1) AS forum_posts  						FROM ' . TOPICS_TABLE . ' t  						WHERE ' . $db->sql_in_set('t.forum_id', $forum_ids) . ' -							AND t.topic_approved = 1 +							AND t.topic_visibility = ' . ITEM_APPROVED . '  							AND t.topic_status <> ' . ITEM_MOVED . '  						GROUP BY t.forum_id';  				} @@ -1737,14 +1740,14 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  				$sql = 'SELECT MAX(t.topic_last_post_id) as last_post_id  					FROM ' . TOPICS_TABLE . ' t  					WHERE ' . $db->sql_in_set('t.forum_id', $forum_ids) . ' -						AND t.topic_approved = 1'; +						AND t.topic_visibility = ' . ITEM_APPROVED;  			}  			else  			{  				$sql = 'SELECT t.forum_id, MAX(t.topic_last_post_id) as last_post_id  					FROM ' . TOPICS_TABLE . ' t  					WHERE ' . $db->sql_in_set('t.forum_id', $forum_ids) . ' -						AND t.topic_approved = 1 +						AND t.topic_visibility = ' . ITEM_APPROVED . '  					GROUP BY t.forum_id';  			} @@ -1846,7 +1849,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  			$db->sql_transaction('begin'); -			$sql = 'SELECT t.topic_id, t.forum_id, t.topic_moved_id, t.topic_approved, ' . (($sync_extra) ? 't.topic_attachment, t.topic_reported, ' : '') . 't.topic_poster, t.topic_time, t.topic_replies, t.topic_replies_real, t.topic_first_post_id, t.topic_first_poster_name, t.topic_first_poster_colour, t.topic_last_post_id, t.topic_last_post_subject, t.topic_last_poster_id, t.topic_last_poster_name, t.topic_last_poster_colour, t.topic_last_post_time +			$sql = 'SELECT t.topic_id, t.forum_id, t.topic_moved_id, t.topic_visibility, ' . (($sync_extra) ? 't.topic_attachment, t.topic_reported, ' : '') . 't.topic_poster, t.topic_time, t.topic_replies, t.topic_replies_real, t.topic_first_post_id, t.topic_first_poster_name, t.topic_first_poster_colour, t.topic_last_post_id, t.topic_last_post_subject, t.topic_last_poster_id, t.topic_last_poster_name, t.topic_last_poster_colour, t.topic_last_post_time  				FROM ' . TOPICS_TABLE . " t  				$where_sql";  			$result = $db->sql_query($sql); @@ -1880,10 +1883,10 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  			// Use "t" as table alias because of the $where_sql clause  			// NOTE: 't.post_approved' in the GROUP BY is causing a major slowdown. -			$sql = 'SELECT t.topic_id, t.post_approved, COUNT(t.post_id) AS total_posts, MIN(t.post_id) AS first_post_id, MAX(t.post_id) AS last_post_id +			$sql = 'SELECT t.topic_id, t.post_visibility, COUNT(t.post_id) AS total_posts, MIN(t.post_id) AS first_post_id, MAX(t.post_id) AS last_post_id  				FROM ' . POSTS_TABLE . " t  				$where_sql -				GROUP BY t.topic_id, t.post_approved"; +				GROUP BY t.topic_id, t.post_visibility";  			$result = $db->sql_query($sql);  			while ($row = $db->sql_fetchrow($result)) @@ -1907,7 +1910,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  					$topic_data[$topic_id]['replies_real'] += $row['total_posts'];  					$topic_data[$topic_id]['first_post_id'] = (!$topic_data[$topic_id]['first_post_id']) ? $row['first_post_id'] : min($topic_data[$topic_id]['first_post_id'], $row['first_post_id']); -					if ($row['post_approved'] || !$topic_data[$topic_id]['last_post_id']) +					if ($row['post_visibility'] || !$topic_data[$topic_id]['last_post_id'])  					{  						$topic_data[$topic_id]['replies'] = $row['total_posts'] - 1;  						$topic_data[$topic_id]['last_post_id'] = $row['last_post_id']; @@ -1952,7 +1955,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  				unset($delete_topics, $delete_topic_ids);  			} -			$sql = 'SELECT p.post_id, p.topic_id, p.post_approved, p.poster_id, p.post_subject, p.post_username, p.post_time, u.username, u.user_colour +			$sql = 'SELECT p.post_id, p.topic_id, p.post_visibility, p.poster_id, p.post_subject, p.post_username, p.post_time, u.username, u.user_colour  				FROM ' . POSTS_TABLE . ' p, ' . USERS_TABLE . ' u  				WHERE ' . $db->sql_in_set('p.post_id', $post_ids) . '  					AND u.user_id = p.poster_id'; @@ -1965,9 +1968,9 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  				if ($row['post_id'] == $topic_data[$topic_id]['first_post_id'])  				{ -					if ($topic_data[$topic_id]['topic_approved'] != $row['post_approved']) +					if ($topic_data[$topic_id]['topic_visibility'] != $row['post_visibility'])  					{ -						$approved_unapproved_ids[] = $topic_id; +						$approved_unapproved_ids[$topic_id] = $row['post_visibility'];  					}  					$topic_data[$topic_id]['time'] = $row['post_time'];  					$topic_data[$topic_id]['poster'] = $row['poster_id']; @@ -2029,7 +2032,7 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  				$sync_shadow_topics = array();  				if (sizeof($post_ids))  				{ -					$sql = 'SELECT p.post_id, p.topic_id, p.post_approved, p.poster_id, p.post_subject, p.post_username, p.post_time, u.username, u.user_colour +					$sql = 'SELECT p.post_id, p.topic_id, p.post_visibility, p.poster_id, p.post_subject, p.post_username, p.post_time, u.username, u.user_colour  						FROM ' . POSTS_TABLE . ' p, ' . USERS_TABLE . ' u  						WHERE ' . $db->sql_in_set('p.post_id', $post_ids) . '  							AND u.user_id = p.poster_id'; @@ -2099,10 +2102,14 @@ function sync($mode, $where_type = '', $where_ids = '', $resync_parents = false,  			// approved becomes unapproved, and vice-versa  			if (sizeof($approved_unapproved_ids))  			{ -				$sql = 'UPDATE ' . TOPICS_TABLE . ' -					SET topic_approved = 1 - topic_approved -					WHERE ' . $db->sql_in_set('topic_id', $approved_unapproved_ids); -				$db->sql_query($sql); +				foreach ($approved_unapproved_ids as $update_topic_id => $status) +				{ +					// @TODO: Consider grouping by $status and only running 3 queries +    				$sql = 'UPDATE ' . TOPICS_TABLE . ' +						SET topic_visibility = ' . $status . ' +						WHERE topic_id = ' . $update_topic_id; +					$db->sql_query($sql); +				}  			}  			unset($approved_unapproved_ids); diff --git a/phpBB/includes/functions_convert.php b/phpBB/includes/functions_convert.php index ac791e0d9b..a34a193f60 100644 --- a/phpBB/includes/functions_convert.php +++ b/phpBB/includes/functions_convert.php @@ -1768,7 +1768,7 @@ function sync_post_count($offset, $limit)  	$sql = 'SELECT COUNT(post_id) AS num_posts, poster_id  			FROM ' . POSTS_TABLE . '  			WHERE post_postcount = 1 -				AND post_approved = 1 +				AND post_visibility = ' . ITEM_APPROVED . '  			GROUP BY poster_id  			ORDER BY poster_id';  	$result = $db->sql_query_limit($sql, $limit, $offset); @@ -1941,7 +1941,7 @@ function update_dynamic_config()  	$sql = 'SELECT COUNT(post_id) AS stat  		FROM ' . POSTS_TABLE . ' -		WHERE post_approved = 1'; +		WHERE post_visibility = ' . ITEM_APPROVED;  	$result = $db->sql_query($sql);  	$row = $db->sql_fetchrow($result);  	$db->sql_freeresult($result); @@ -1950,7 +1950,7 @@ function update_dynamic_config()  	$sql = 'SELECT COUNT(topic_id) AS stat  		FROM ' . TOPICS_TABLE . ' -		WHERE topic_approved = 1'; +		WHERE topic_visibility = ' . ITEM_APPROVED;  	$result = $db->sql_query($sql);  	$row = $db->sql_fetchrow($result);  	$db->sql_freeresult($result); diff --git a/phpBB/includes/functions_posting.php b/phpBB/includes/functions_posting.php index c50395a5df..2f51200b48 100644 --- a/phpBB/includes/functions_posting.php +++ b/phpBB/includes/functions_posting.php @@ -176,7 +176,7 @@ function update_post_information($type, $ids, $return_update_sql = false)  	if ($type != 'topic')  	{  		$topic_join = ', ' . TOPICS_TABLE . ' t'; -		$topic_condition = 'AND t.topic_id = p.topic_id AND t.topic_approved = 1'; +		$topic_condition = 'AND t.topic_id = p.topic_id AND t.topic_visibility = ' . ITEM_APPROVED;  	}  	else  	{ @@ -190,7 +190,7 @@ function update_post_information($type, $ids, $return_update_sql = false)  			FROM ' . POSTS_TABLE . " p $topic_join  			WHERE " . $db->sql_in_set('p.' . $type . '_id', $ids) . "  				$topic_condition -				AND p.post_approved = 1"; +				AND p.post_visibility = " . ITEM_APPROVED;  	}  	else  	{ @@ -198,7 +198,7 @@ function update_post_information($type, $ids, $return_update_sql = false)  			FROM ' . POSTS_TABLE . " p $topic_join  			WHERE " . $db->sql_in_set('p.' . $type . '_id', $ids) . "  				$topic_condition -				AND p.post_approved = 1 +				AND p.post_visibility = " . ITEM_APPROVED . "  			GROUP BY p.{$type}_id";  	}  	$result = $db->sql_query($sql); @@ -993,7 +993,7 @@ function topic_review($topic_id, $forum_id, $mode = 'topic_review', $cur_post_id  	$sql = 'SELECT p.post_id  		FROM ' . POSTS_TABLE . ' p' . "  		WHERE p.topic_id = $topic_id -			" . ((!$auth->acl_get('m_approve', $forum_id)) ? 'AND p.post_approved = 1' : '') . ' +			AND " . topic_visibility::get_visibility_sql('post', $forum_id, 'p.') . '  			' . (($mode == 'post_review') ? " AND p.post_id > $cur_post_id" : '') . '  			' . (($mode == 'post_review_edit') ? " AND p.post_id = $cur_post_id" : '') . '  		ORDER BY p.post_time '; @@ -1489,7 +1489,7 @@ function delete_post($forum_id, $topic_id, $post_id, &$data)  			delete_topics('topic_id', array($topic_id), false);  			$sql_data[FORUMS_TABLE] .= 'forum_topics_real = forum_topics_real - 1'; -			$sql_data[FORUMS_TABLE] .= ($data['topic_approved']) ? ', forum_posts = forum_posts - 1, forum_topics = forum_topics - 1' : ''; +			$sql_data[FORUMS_TABLE] .= ($data['topic_visibility'] == ITEM_APPROVED) ? ', forum_posts = forum_posts - 1, forum_topics = forum_topics - 1' : '';  			$update_sql = update_post_information('forum', $forum_id, true);  			if (sizeof($update_sql)) @@ -1509,18 +1509,18 @@ function delete_post($forum_id, $topic_id, $post_id, &$data)  			$row = $db->sql_fetchrow($result);  			$db->sql_freeresult($result); -			$sql_data[FORUMS_TABLE] = ($data['post_approved']) ? 'forum_posts = forum_posts - 1' : ''; +			$sql_data[FORUMS_TABLE] = ($data['post_visibility'] == ITEM_APPROVED) ? 'forum_posts = forum_posts - 1' : '';  			$sql_data[TOPICS_TABLE] = 'topic_poster = ' . intval($row['poster_id']) . ', topic_first_post_id = ' . intval($row['post_id']) . ", topic_first_poster_colour = '" . $db->sql_escape($row['user_colour']) . "', topic_first_poster_name = '" . (($row['poster_id'] == ANONYMOUS) ? $db->sql_escape($row['post_username']) : $db->sql_escape($row['username'])) . "', topic_time = " . (int) $row['post_time'];  			// Decrementing topic_replies here is fine because this case only happens if there is more than one post within the topic - basically removing one "reply" -			$sql_data[TOPICS_TABLE] .= ', topic_replies_real = topic_replies_real - 1' . (($data['post_approved']) ? ', topic_replies = topic_replies - 1' : ''); +			$sql_data[TOPICS_TABLE] .= ', topic_replies_real = topic_replies_real - 1' . (($data['post_visibility'] == ITEM_APPROVED) ? ', topic_replies = topic_replies - 1' : '');  			$next_post_id = (int) $row['post_id'];  		break;  		case 'delete_last_post': -			$sql_data[FORUMS_TABLE] = ($data['post_approved']) ? 'forum_posts = forum_posts - 1' : ''; +			$sql_data[FORUMS_TABLE] = ($data['post_visibility'] == ITEM_APPROVED) ? 'forum_posts = forum_posts - 1' : '';  			$update_sql = update_post_information('forum', $forum_id, true);  			if (sizeof($update_sql)) @@ -1529,7 +1529,7 @@ function delete_post($forum_id, $topic_id, $post_id, &$data)  				$sql_data[FORUMS_TABLE] .= implode(', ', $update_sql[$forum_id]);  			} -			$sql_data[TOPICS_TABLE] = 'topic_bumped = 0, topic_bumper = 0, topic_replies_real = topic_replies_real - 1' . (($data['post_approved']) ? ', topic_replies = topic_replies - 1' : ''); +			$sql_data[TOPICS_TABLE] = 'topic_bumped = 0, topic_bumper = 0, topic_replies_real = topic_replies_real - 1' . (($data['post_visibility'] == ITEM_APPROVED) ? ', topic_replies = topic_replies - 1' : '');  			$update_sql = update_post_information('topic', $topic_id, true);  			if (sizeof($update_sql)) @@ -1541,8 +1541,8 @@ function delete_post($forum_id, $topic_id, $post_id, &$data)  			{  				$sql = 'SELECT MAX(post_id) as last_post_id  					FROM ' . POSTS_TABLE . " -					WHERE topic_id = $topic_id " . -						((!$auth->acl_get('m_approve', $forum_id)) ? 'AND post_approved = 1' : ''); +					WHERE topic_id = $topic_id +						AND " . topic_visibility::get_visibility_sql('post', $forum_id);  				$result = $db->sql_query($sql);  				$row = $db->sql_fetchrow($result);  				$db->sql_freeresult($result); @@ -1554,17 +1554,17 @@ function delete_post($forum_id, $topic_id, $post_id, &$data)  		case 'delete':  			$sql = 'SELECT post_id  				FROM ' . POSTS_TABLE . " -				WHERE topic_id = $topic_id " . -					((!$auth->acl_get('m_approve', $forum_id)) ? 'AND post_approved = 1' : '') . ' +				WHERE topic_id = $topic_id +					AND " . topic_visibility::get_visibility_sql('post', $forum_id) . '  					AND post_time > ' . $data['post_time'] . '  				ORDER BY post_time ASC';  			$result = $db->sql_query_limit($sql, 1);  			$row = $db->sql_fetchrow($result);  			$db->sql_freeresult($result); -			$sql_data[FORUMS_TABLE] = ($data['post_approved']) ? 'forum_posts = forum_posts - 1' : ''; +			$sql_data[FORUMS_TABLE] = ($data['post_visibility'] == ITEM_APPROVED) ? 'forum_posts = forum_posts - 1' : ''; -			$sql_data[TOPICS_TABLE] = 'topic_replies_real = topic_replies_real - 1' . (($data['post_approved']) ? ', topic_replies = topic_replies - 1' : ''); +			$sql_data[TOPICS_TABLE] = 'topic_replies_real = topic_replies_real - 1' . (($data['post_visibility'] == ITEM_APPROVED) ? ', topic_replies = topic_replies - 1' : '');  			$next_post_id = (int) $row['post_id'];  		break;  	} @@ -1674,9 +1674,9 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  	$poster_id = ($mode == 'edit') ? $data['poster_id'] : (int) $user->data['user_id'];  	// Retrieve some additional information if not present -	if ($mode == 'edit' && (!isset($data['post_approved']) || !isset($data['topic_approved']) || $data['post_approved'] === false || $data['topic_approved'] === false)) +	if ($mode == 'edit' && (!isset($data['post_visibility']) || !isset($data['topic_visibility']) || $data['post_visibility'] === false || $data['topic_visibility'] === false))  	{ -		$sql = 'SELECT p.post_approved, t.topic_type, t.topic_replies, t.topic_replies_real, t.topic_approved +		$sql = 'SELECT p.post_visibility, t.topic_type, t.topic_replies, t.topic_replies_real, t.topic_visibility  			FROM ' . TOPICS_TABLE . ' t, ' . POSTS_TABLE . ' p  			WHERE t.topic_id = p.topic_id  				AND p.post_id = ' . $data['post_id']; @@ -1684,8 +1684,8 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  		$topic_row = $db->sql_fetchrow($result);  		$db->sql_freeresult($result); -		$data['topic_approved'] = $topic_row['topic_approved']; -		$data['post_approved'] = $topic_row['post_approved']; +		$data['topic_visibility'] = $topic_row['topic_visibility']; +		$data['post_visibility'] = $topic_row['post_visibility'];  	}  	// This variable indicates if the user is able to post or put into the queue - it is used later for all code decisions regarding approval @@ -1719,7 +1719,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  				'icon_id'			=> $data['icon_id'],  				'poster_ip'			=> $user->ip,  				'post_time'			=> $current_time, -				'post_approved'		=> $post_approval, +				'post_visibility'	=> $post_approval,  				'enable_bbcode'		=> $data['enable_bbcode'],  				'enable_smilies'	=> $data['enable_smilies'],  				'enable_magic_url'	=> $data['enable_urls'], @@ -1785,7 +1785,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  				'forum_id'			=> $data['forum_id'],  				'poster_id'			=> $data['poster_id'],  				'icon_id'			=> $data['icon_id'], -				'post_approved'		=> (!$post_approval) ? 0 : $data['post_approved'], +				'post_visibility'	=> (!$post_approval) ? 0 : $data['post_visibility'],  				'enable_bbcode'		=> $data['enable_bbcode'],  				'enable_smilies'	=> $data['enable_smilies'],  				'enable_magic_url'	=> $data['enable_urls'], @@ -1807,7 +1807,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  		break;  	} -	$post_approved = $sql_data[POSTS_TABLE]['sql']['post_approved']; +	$post_approved = $sql_data[POSTS_TABLE]['sql']['post_visibility'];  	$topic_row = array();  	// And the topic ladies and gentlemen @@ -1820,7 +1820,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  				'topic_last_view_time'		=> $current_time,  				'forum_id'					=> $data['forum_id'],  				'icon_id'					=> $data['icon_id'], -				'topic_approved'			=> $post_approval, +				'topic_visibility'			=> $post_approval,  				'topic_title'				=> $subject,  				'topic_first_poster_name'	=> (!$user->data['is_registered'] && $username) ? $username : (($user->data['user_id'] != ANONYMOUS) ? $user->data['username'] : ''),  				'topic_first_poster_colour'	=> $user->data['user_colour'], @@ -1897,7 +1897,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  			$sql_data[TOPICS_TABLE]['sql'] = array(  				'forum_id'					=> $data['forum_id'],  				'icon_id'					=> $data['icon_id'], -				'topic_approved'			=> (!$post_approval) ? 0 : $data['topic_approved'], +				'topic_visibility'			=> (!$post_approval) ? 0 : $data['topic_visibility'],  				'topic_title'				=> $subject,  				'topic_first_poster_name'	=> $username,  				'topic_type'				=> $topic_type, @@ -1913,12 +1913,12 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  			);  			// Correctly set back the topic replies and forum posts... only if the topic was approved before and now gets disapproved -			if (!$post_approval && $data['topic_approved']) +			if (!$post_approval && $data['topic_visibility'] == ITEM_APPROVED)  			{  				// Do we need to grab some topic informations?  				if (!sizeof($topic_row))  				{ -					$sql = 'SELECT topic_type, topic_replies, topic_replies_real, topic_approved +					$sql = 'SELECT topic_type, topic_replies, topic_replies_real, topic_visibility  						FROM ' . TOPICS_TABLE . '  						WHERE topic_id = ' . $data['topic_id'];  					$result = $db->sql_query($sql); @@ -1949,7 +1949,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  		case 'edit_last_post':  			// Correctly set back the topic replies and forum posts... but only if the post was approved before. -			if (!$post_approval && $data['post_approved']) +			if (!$post_approval && $data['post_visibility'] == ITEM_APPROVED)  			{  				$sql_data[TOPICS_TABLE]['stat'][] = 'topic_replies = topic_replies - 1, topic_last_view_time = ' . $current_time;  				$sql_data[FORUMS_TABLE]['stat'][] = 'forum_posts = forum_posts - 1'; @@ -2173,7 +2173,7 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  	// we need to update the last forum information  	// only applicable if the topic is approved -	if ($post_approved || !$data['post_approved']) +	if ($post_approved || $data['post_visibility'] != ITEM_APPROVED)  	{  		// the last post makes us update the forum table. This can happen if...  		// We make a new topic @@ -2219,13 +2219,13 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  						$sql_data[FORUMS_TABLE]['stat'][] = "forum_last_poster_name = '" . $db->sql_escape($username) . "'";  					}  				} -				else if ($data['post_approved'] !== $post_approved) +				else if ($data['post_visibility'] !== $post_approved)  				{  					// we need a fresh change of socks, everything has become invalidated  					$sql = 'SELECT MAX(topic_last_post_id) as last_post_id  						FROM ' . TOPICS_TABLE . '  						WHERE forum_id = ' . (int) $data['forum_id'] . ' -							AND topic_approved = 1'; +							AND topic_visibility = ' . ITEM_APPROVED;  					$result = $db->sql_query($sql);  					$row = $db->sql_fetchrow($result);  					$db->sql_freeresult($result); @@ -2290,13 +2290,13 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  			}  		}  	} -	else if (!$data['post_approved'] && ($post_mode == 'edit_last_post' || $post_mode == 'edit_topic' || ($post_mode == 'edit_first_post' && !$data['topic_replies']))) +	else if (!$data['post_visibility'] == ITEM_APPROVED && ($post_mode == 'edit_last_post' || $post_mode == 'edit_topic' || ($post_mode == 'edit_first_post' && !$data['topic_replies'])))  	{  		// like having the rug pulled from under us  		$sql = 'SELECT MAX(post_id) as last_post_id  			FROM ' . POSTS_TABLE . '  			WHERE topic_id = ' . (int) $data['topic_id'] . ' -				AND post_approved = 1'; +				AND post_visibility = ' . ITEM_APPROVED;  		$result = $db->sql_query($sql);  		$row = $db->sql_fetchrow($result);  		$db->sql_freeresult($result); diff --git a/phpBB/includes/mcp/mcp_forum.php b/phpBB/includes/mcp/mcp_forum.php index 7b3bc82093..48b9c7c2d3 100644 --- a/phpBB/includes/mcp/mcp_forum.php +++ b/phpBB/includes/mcp/mcp_forum.php @@ -154,7 +154,7 @@ function mcp_forum_view($id, $mode, $action, $forum_info)  	$sql = 'SELECT t.topic_id  		FROM ' . TOPICS_TABLE . ' t  		WHERE t.forum_id = ' . $forum_id . ' -			' . (($auth->acl_get('m_approve', $forum_id)) ? '' : 'AND t.topic_approved = 1') . " +			' . topic_visibility::get_visibility_sql('topic', $forum_id, 't.') . "  			$limit_time_sql  		ORDER BY t.topic_type DESC, $sort_order_sql";  	$result = $db->sql_query_limit($sql, $topics_per_page, $start); @@ -220,9 +220,10 @@ function mcp_forum_view($id, $mode, $action, $forum_info)  		$topic_title = censor_text($row['topic_title']); -		$topic_unapproved = (!$row['topic_approved'] && $auth->acl_get('m_approve', $row['forum_id'])) ? true : false; -		$posts_unapproved = ($row['topic_approved'] && $row['topic_replies'] < $row['topic_replies_real'] && $auth->acl_get('m_approve', $row['forum_id'])) ? true : false; +		$topic_unapproved = ($row['topic_visibility'] == ITEM_UNAPPROVED  && $auth->acl_get('m_approve', $row['forum_id'])) ? true : false; +		$posts_unapproved = ($row['topic_visibility'] == ITEM_APPROVED && $row['topic_replies'] < $row['topic_replies_real'] && $auth->acl_get('m_approve', $row['forum_id'])) ? true : false;  		$u_mcp_queue = ($topic_unapproved || $posts_unapproved) ? $url . '&i=queue&mode=' . (($topic_unapproved) ? 'approve_details' : 'unapproved_posts') . '&t=' . $row['topic_id'] : ''; +		$topic_deleted = ($row['topic_visibility'] == ITEM_DELETED) ? true : false;  		$topic_row = array(  			'ATTACH_ICON_IMG'		=> ($auth->acl_get('u_download') && $auth->acl_get('f_download', $row['forum_id']) && $row['topic_attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '', @@ -232,6 +233,7 @@ function mcp_forum_view($id, $mode, $action, $forum_info)  			'TOPIC_ICON_IMG_WIDTH'	=> (!empty($icons[$row['icon_id']])) ? $icons[$row['icon_id']]['width'] : '',  			'TOPIC_ICON_IMG_HEIGHT'	=> (!empty($icons[$row['icon_id']])) ? $icons[$row['icon_id']]['height'] : '',  			'UNAPPROVED_IMG'		=> ($topic_unapproved || $posts_unapproved) ? $user->img('icon_topic_unapproved', ($topic_unapproved) ? 'TOPIC_UNAPPROVED' : 'POSTS_UNAPPROVED') : '', +			'DELETED_IMG'           => ($topic_deleted) ? $user->img(/*TODO*/) : '',  			'TOPIC_AUTHOR'				=> get_username_string('username', $row['topic_poster'], $row['topic_first_poster_name'], $row['topic_first_poster_colour']),  			'TOPIC_AUTHOR_COLOUR'		=> get_username_string('colour', $row['topic_poster'], $row['topic_first_poster_name'], $row['topic_first_poster_colour']), @@ -254,7 +256,9 @@ function mcp_forum_view($id, $mode, $action, $forum_info)  			'S_TOPIC_REPORTED'		=> (!empty($row['topic_reported']) && empty($row['topic_moved_id']) && $auth->acl_get('m_report', $row['forum_id'])) ? true : false,  			'S_TOPIC_UNAPPROVED'	=> $topic_unapproved,  			'S_POSTS_UNAPPROVED'	=> $posts_unapproved, +			'S_TOPIC_DELETED'       => $topic_deleted,  			'S_UNREAD_TOPIC'		=> $unread_topic, +  		);  		if ($row['topic_status'] == ITEM_MOVED) diff --git a/phpBB/includes/mcp/mcp_front.php b/phpBB/includes/mcp/mcp_front.php index 13398e62bc..1b9521674d 100644 --- a/phpBB/includes/mcp/mcp_front.php +++ b/phpBB/includes/mcp/mcp_front.php @@ -39,7 +39,7 @@ function mcp_front_view($id, $mode, $action)  			$sql = 'SELECT COUNT(post_id) AS total  				FROM ' . POSTS_TABLE . '  				WHERE ' . $db->sql_in_set('forum_id', $forum_list) . ' -					AND post_approved = 0'; +					AND post_visibility = ' . ITEM_UNAPPROVED;  			$result = $db->sql_query($sql);  			$total = (int) $db->sql_fetchfield('total');  			$db->sql_freeresult($result); @@ -60,7 +60,7 @@ function mcp_front_view($id, $mode, $action)  				$sql = 'SELECT post_id  					FROM ' . POSTS_TABLE . '  					WHERE ' . $db->sql_in_set('forum_id', $forum_list) . ' -						AND post_approved = 0 +						AND post_visibility = ' . ITEM_UNAPPROVED . '  					ORDER BY post_time DESC';  				$result = $db->sql_query_limit($sql, 5); diff --git a/phpBB/includes/mcp/mcp_main.php b/phpBB/includes/mcp/mcp_main.php index 95ca7c2e1b..db9872e04e 100644 --- a/phpBB/includes/mcp/mcp_main.php +++ b/phpBB/includes/mcp/mcp_main.php @@ -475,7 +475,7 @@ function mcp_move_topic($topic_ids)  		foreach ($topic_data as $topic_id => $topic_info)  		{ -			if ($topic_info['topic_approved']) +			if ($topic_info['topic_visibility'] == ITEM_APPROVED)  			{  				$topics_authed_moved++;  				$topic_posts_added++; @@ -486,7 +486,7 @@ function mcp_move_topic($topic_ids)  			$topics_removed++;  			$topic_posts_removed += $topic_info['topic_replies']; -			if ($topic_info['topic_approved']) +			if ($topic_info['topic_visibility'] == ITEM_APPROVED)  			{  				$topics_authed_removed++;  				$topic_posts_removed++; @@ -528,13 +528,13 @@ function mcp_move_topic($topic_ids)  			add_log('mod', $to_forum_id, $topic_id, 'LOG_MOVE', $row['forum_name'], $forum_data['forum_name']);  			// Leave a redirection if required and only if the topic is visible to users -			if ($leave_shadow && $row['topic_approved'] && $row['topic_type'] != POST_GLOBAL) +			if ($leave_shadow && $row['topic_visibility'] == ITEM_APPROVED && $row['topic_type'] != POST_GLOBAL)  			{  				$shadow = array(  					'forum_id'				=>	(int) $row['forum_id'],  					'icon_id'				=>	(int) $row['icon_id'],  					'topic_attachment'		=>	(int) $row['topic_attachment'], -					'topic_approved'		=>	1, // a shadow topic is always approved +					'topic_visibliity'		=>	ITEM_APPROVED, // a shadow topic is always approved  					'topic_reported'		=>	0, // a shadow topic is never reported  					'topic_title'			=>	(string) $row['topic_title'],  					'topic_poster'			=>	(int) $row['topic_poster'], @@ -932,7 +932,7 @@ function mcp_fork_topic($topic_ids)  				'forum_id'					=> (int) $to_forum_id,  				'icon_id'					=> (int) $topic_row['icon_id'],  				'topic_attachment'			=> (int) $topic_row['topic_attachment'], -				'topic_approved'			=> 1, +				'topic_visibility'			=> ITEM_APPROVED,  				'topic_reported'			=> 0,  				'topic_title'				=> (string) $topic_row['topic_title'],  				'topic_poster'				=> (int) $topic_row['topic_poster'], @@ -1009,7 +1009,7 @@ function mcp_fork_topic($topic_ids)  					'icon_id'			=> (int) $row['icon_id'],  					'poster_ip'			=> (string) $row['poster_ip'],  					'post_time'			=> (int) $row['post_time'], -					'post_approved'		=> 1, +					'post_visibility'	=> ITEM_APPROVED,  					'post_reported'		=> 0,  					'enable_bbcode'		=> (int) $row['enable_bbcode'],  					'enable_smilies'	=> (int) $row['enable_smilies'], diff --git a/phpBB/includes/mcp/mcp_post.php b/phpBB/includes/mcp/mcp_post.php index 520c964228..90ce18de4e 100644 --- a/phpBB/includes/mcp/mcp_post.php +++ b/phpBB/includes/mcp/mcp_post.php @@ -185,7 +185,7 @@ function mcp_post_details($id, $mode, $action)  		'S_CAN_DELETE_POST'		=> $auth->acl_get('m_delete', $post_info['forum_id']),  		'S_POST_REPORTED'		=> ($post_info['post_reported']) ? true : false, -		'S_POST_UNAPPROVED'		=> (!$post_info['post_approved']) ? true : false, +		'S_POST_UNAPPROVED'		=> ($post_info['post_visibility'] == ITEM_UNAPPROVED) ? true : false,  		'S_POST_LOCKED'			=> ($post_info['post_edit_locked']) ? true : false,  		'S_USER_NOTES'			=> true,  		'S_CLEAR_ALLOWED'		=> ($auth->acl_get('a_clearlogs')) ? true : false, @@ -415,7 +415,7 @@ function change_poster(&$post_info, $userdata)  	}  	// Adjust post counts... only if the post is approved (else, it was not added the users post count anyway) -	if ($post_info['post_postcount'] && $post_info['post_approved']) +	if ($post_info['post_postcount'] && $post_info['post_visibility'] == ITEM_APPROVED)  	{  		$sql = 'UPDATE ' . USERS_TABLE . '  			SET user_posts = user_posts - 1 diff --git a/phpBB/includes/mcp/mcp_queue.php b/phpBB/includes/mcp/mcp_queue.php index b44685b8a3..833f924efc 100644 --- a/phpBB/includes/mcp/mcp_queue.php +++ b/phpBB/includes/mcp/mcp_queue.php @@ -183,7 +183,7 @@ class mcp_queue  					'U_APPROVE_ACTION'		=> append_sid("{$phpbb_root_path}mcp.$phpEx", "i=queue&p=$post_id&f=$forum_id"),  					'S_CAN_VIEWIP'			=> $auth->acl_get('m_info', $post_info['forum_id']),  					'S_POST_REPORTED'		=> $post_info['post_reported'], -					'S_POST_UNAPPROVED'		=> !$post_info['post_approved'], +					'S_POST_UNAPPROVED'		=> ($post_info['post_visibility'] == ITEM_UNAPPROVED) ,  					'S_POST_LOCKED'			=> $post_info['post_edit_locked'],  					'S_USER_NOTES'			=> true, @@ -309,7 +309,7 @@ class mcp_queue  					$sql = 'SELECT p.post_id  						FROM ' . POSTS_TABLE . ' p, ' . TOPICS_TABLE . ' t' . (($sort_order_sql[0] == 'u') ? ', ' . USERS_TABLE . ' u' : '') . '  						WHERE ' . $db->sql_in_set('p.forum_id', $forum_list) . ' -							AND p.post_approved = 0 +							AND p.post_visibility = ' . ITEM_UNAPPROVED . '  							' . (($sort_order_sql[0] == 'u') ? 'AND u.user_id = p.poster_id' : '') . '  							' . (($topic_id) ? 'AND p.topic_id = ' . $topic_id : '') . "  							AND t.topic_id = p.topic_id @@ -361,7 +361,7 @@ class mcp_queue  					$sql = 'SELECT t.forum_id, t.topic_id, t.topic_title, t.topic_title AS post_subject, t.topic_time AS post_time, t.topic_poster AS poster_id, t.topic_first_post_id AS post_id, t.topic_attachment AS post_attachment, t.topic_first_poster_name AS username, t.topic_first_poster_colour AS user_colour  						FROM ' . TOPICS_TABLE . " t  						WHERE " . $db->sql_in_set('forum_id', $forum_list) . " -							AND topic_approved = 0 +							AND topic_visibility = " . ITEM_UNAPPROVED . "  							$limit_time_sql  						ORDER BY $sort_order_sql";  					$result = $db->sql_query_limit($sql, $config['topics_per_page'], $start); @@ -484,7 +484,7 @@ function approve_post($post_id_list, $id, $mode)  		foreach ($post_info as $post_id => $post_data)  		{ -			if ($post_data['post_approved']) +			if ($post_data['post_visibility'] == ITEM_APPROVED)  			{  				$post_approved_list[] = $post_id;  				continue; @@ -544,7 +544,7 @@ function approve_post($post_id_list, $id, $mode)  		if (sizeof($topic_approve_sql))  		{  			$sql = 'UPDATE ' . TOPICS_TABLE . ' -				SET topic_approved = 1 +				SET topic_visibility = ' . ITEM_APPROVED . '  				WHERE ' . $db->sql_in_set('topic_id', $topic_approve_sql);  			$db->sql_query($sql);  		} @@ -552,7 +552,7 @@ function approve_post($post_id_list, $id, $mode)  		if (sizeof($post_approve_sql))  		{  			$sql = 'UPDATE ' . POSTS_TABLE . ' -				SET post_approved = 1 +				SET post_visibility = ' . ITEM_APPROVED . '  				WHERE ' . $db->sql_in_set('post_id', $post_approve_sql);  			$db->sql_query($sql);  		} diff --git a/phpBB/includes/mcp/mcp_reports.php b/phpBB/includes/mcp/mcp_reports.php index 2890cd56e2..dc917a25e0 100644 --- a/phpBB/includes/mcp/mcp_reports.php +++ b/phpBB/includes/mcp/mcp_reports.php @@ -190,7 +190,7 @@ class mcp_reports  					'S_CLOSE_ACTION'		=> append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=reports&mode=report_details&f=' . $post_info['forum_id'] . '&p=' . $post_id),  					'S_CAN_VIEWIP'			=> $auth->acl_get('m_info', $post_info['forum_id']),  					'S_POST_REPORTED'		=> $post_info['post_reported'], -					'S_POST_UNAPPROVED'		=> !$post_info['post_approved'], +					'S_POST_UNAPPROVED'		=> ($post_info['post_visibility'] == POST_UNAPPROVED),  					'S_POST_LOCKED'			=> $post_info['post_edit_locked'],  					'S_USER_NOTES'			=> true, diff --git a/phpBB/includes/mcp/mcp_topic.php b/phpBB/includes/mcp/mcp_topic.php index e39e553ab6..f6fd12f0c4 100644 --- a/phpBB/includes/mcp/mcp_topic.php +++ b/phpBB/includes/mcp/mcp_topic.php @@ -145,8 +145,8 @@ function mcp_topic_view($id, $mode, $action)  	$sql = 'SELECT u.username, u.username_clean, u.user_colour, p.*  		FROM ' . POSTS_TABLE . ' p, ' . USERS_TABLE . ' u  		WHERE ' . (($action == 'reports') ? 'p.post_reported = 1 AND ' : '') . ' -			p.topic_id = ' . $topic_id . ' ' . -			((!$auth->acl_get('m_approve', $topic_info['forum_id'])) ? ' AND p.post_approved = 1 ' : '') . ' +			p.topic_id = ' . $topic_id . ' +			AND ' .	topic_visibility::get_visibility_sql('post', $topic_info['forum_id'], 'p.') . '  			AND p.poster_id = u.user_id ' .  			$limit_time_sql . '  		ORDER BY ' . $sort_order_sql; @@ -227,7 +227,7 @@ function mcp_topic_view($id, $mode, $action)  			parse_attachments($topic_info['forum_id'], $message, $attachments[$row['post_id']], $update_count);  		} -		if (!$row['post_approved']) +		if ($row['post_visibility'] == ITEM_UNAPPROVED)  		{  			$has_unapproved_posts = true;  		} @@ -249,7 +249,7 @@ function mcp_topic_view($id, $mode, $action)  			'MINI_POST_IMG'			=> ($post_unread) ? $user->img('icon_post_target_unread', 'UNREAD_POST') : $user->img('icon_post_target', 'POST'),  			'S_POST_REPORTED'	=> ($row['post_reported'] && $auth->acl_get('m_report', $topic_info['forum_id'])), -			'S_POST_UNAPPROVED'	=> (!$row['post_approved'] && $auth->acl_get('m_approve', $topic_info['forum_id'])), +			'S_POST_UNAPPROVED'	=> ($row['post_visibility'] != ITEM_APPROVED && $auth->acl_get('m_approve', $topic_info['forum_id'])),  			'S_CHECKED'			=> (($submitted_id_list && !in_array(intval($row['post_id']), $submitted_id_list)) || in_array(intval($row['post_id']), $checked_ids)) ? true : false,  			'S_HAS_ATTACHMENTS'	=> (!empty($attachments[$row['post_id']])) ? true : false, @@ -448,7 +448,7 @@ function split_topic($action, $topic_id, $to_forum_id, $subject)  			if ($sort_order_sql[0] == 'u')  			{ -				$sql = 'SELECT p.post_id, p.forum_id, p.post_approved +				$sql = 'SELECT p.post_id, p.forum_id, p.post_visibility  					FROM ' . POSTS_TABLE . ' p, ' . USERS_TABLE . " u  					WHERE p.topic_id = $topic_id  						AND p.poster_id = u.user_id @@ -457,7 +457,7 @@ function split_topic($action, $topic_id, $to_forum_id, $subject)  			}  			else  			{ -				$sql = 'SELECT p.post_id, p.forum_id, p.post_approved +				$sql = 'SELECT p.post_id, p.forum_id, p.post_visibility  					FROM ' . POSTS_TABLE . " p  					WHERE p.topic_id = $topic_id  						$limit_time_sql @@ -470,7 +470,7 @@ function split_topic($action, $topic_id, $to_forum_id, $subject)  			while ($row = $db->sql_fetchrow($result))  			{  				// If split from selected post (split_beyond), we split the unapproved items too. -				if (!$row['post_approved'] && !$auth->acl_get('m_approve', $row['forum_id'])) +				if ($row['post_visibility'] == ITEM_UNAPPROVED && !$auth->acl_get('m_approve', $row['forum_id']))  				{  //					continue;  				} @@ -497,10 +497,10 @@ function split_topic($action, $topic_id, $to_forum_id, $subject)  		$icon_id = request_var('icon', 0);  		$sql_ary = array( -			'forum_id'		=> $to_forum_id, -			'topic_title'	=> $subject, -			'icon_id'		=> $icon_id, -			'topic_approved'=> 1 +			'forum_id'			=> $to_forum_id, +			'topic_title'		=> $subject, +			'icon_id'			=> $icon_id, +			'topic_visibility'	=> 1  		);  		$sql = 'INSERT INTO ' . TOPICS_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary); diff --git a/phpBB/includes/search/fulltext_mysql.php b/phpBB/includes/search/fulltext_mysql.php index cf89ab1c24..73bf5c52f2 100644 --- a/phpBB/includes/search/fulltext_mysql.php +++ b/phpBB/includes/search/fulltext_mysql.php @@ -265,7 +265,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  	* @param	string		$sort_dir			is either a or d representing ASC and DESC  	* @param	string		$sort_days			specifies the maximum amount of days a post may be old  	* @param	array		$ex_fid_ary			specifies an array of forum ids which should not be searched -	* @param	array		$m_approve_fid_ary	specifies an array of forum ids in which the searcher is allowed to view unapproved posts +	* @param	array		$m_approve_fid_sql	specifies which types of posts a user may view, based on permissions  	* @param	int			$topic_id			is set to 0 or a topic id, if it is not 0 then only posts in this topic should be searched  	* @param	array		$author_ary			an array of author ids if the author should be ignored during the search the array is empty  	* @param	string		$author_name		specifies the author match, when ANONYMOUS is also a search-match @@ -292,7 +292,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  			$sort_key,  			$topic_id,  			implode(',', $ex_fid_ary), -			implode(',', $m_approve_fid_ary), +// @TODO			implode(',', $m_approve_fid_ary),  			implode(',', $author_ary)  		))); @@ -354,7 +354,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  			break;  		} -		if (!sizeof($m_approve_fid_ary)) +/*		if (!sizeof($m_approve_fid_ary))  		{  			$m_approve_fid_sql = ' AND p.post_approved = 1';  		} @@ -366,6 +366,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  		{  			$m_approve_fid_sql = ' AND (p.post_approved = 1 OR ' . $this->db->sql_in_set('p.forum_id', $m_approve_fid_ary, true) . ')';  		} +*/  		$sql_select			= (!$result_count) ? 'SQL_CALC_FOUND_ROWS ' : '';  		$sql_select			= ($type == 'posts') ? $sql_select . 'p.post_id' : 'DISTINCT ' . $sql_select . 't.topic_id'; @@ -445,7 +446,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  	* @param	string		$sort_dir			is either a or d representing ASC and DESC  	* @param	string		$sort_days			specifies the maximum amount of days a post may be old  	* @param	array		$ex_fid_ary			specifies an array of forum ids which should not be searched -	* @param	array		$m_approve_fid_ary	specifies an array of forum ids in which the searcher is allowed to view unapproved posts +	* @param	array		$m_approve_fid_sql	specifies which types of posts a user may view, based on permissions  	* @param	int			$topic_id			is set to 0 or a topic id, if it is not 0 then only posts in this topic should be searched  	* @param	array		$author_ary			an array of author ids  	* @param	string		$author_name		specifies the author match, when ANONYMOUS is also a search-match @@ -473,7 +474,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  			$sort_key,  			$topic_id,  			implode(',', $ex_fid_ary), -			implode(',', $m_approve_fid_ary), +// @TODO			implode(',', $m_approve_fid_ary),  			implode(',', $author_ary),  			$author_name,  		))); @@ -523,7 +524,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  			break;  		} -		if (!sizeof($m_approve_fid_ary)) +/*		if (!sizeof($m_approve_fid_ary))  		{  			$m_approve_fid_sql = ' AND p.post_approved = 1';  		} @@ -535,6 +536,7 @@ class phpbb_search_fulltext_mysql extends phpbb_search_base  		{  			$m_approve_fid_sql = ' AND (p.post_approved = 1 OR ' . $this->db->sql_in_set('p.forum_id', $m_approve_fid_ary, true) . ')';  		} +*/  		// If the cache was completely empty count the results  		$calc_results = ($result_count) ? '' : 'SQL_CALC_FOUND_ROWS '; diff --git a/phpBB/includes/search/fulltext_native.php b/phpBB/includes/search/fulltext_native.php index 96b3f02ec6..c7e7a451e4 100644 --- a/phpBB/includes/search/fulltext_native.php +++ b/phpBB/includes/search/fulltext_native.php @@ -414,7 +414,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  	* @param	string		$sort_dir			is either a or d representing ASC and DESC  	* @param	string		$sort_days			specifies the maximum amount of days a post may be old  	* @param	array		$ex_fid_ary			specifies an array of forum ids which should not be searched -	* @param	array		$m_approve_fid_ary	specifies an array of forum ids in which the searcher is allowed to view unapproved posts +	* @param	array		$m_approve_fid_sql	specifies which types of posts the user can view  	* @param	int			$topic_id			is set to 0 or a topic id, if it is not 0 then only posts in this topic should be searched  	* @param	array		$author_ary			an array of author ids if the author should be ignored during the search the array is empty  	* @param	string		$author_name		specifies the author match, when ANONYMOUS is also a search-match @@ -451,7 +451,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  			$sort_key,  			$topic_id,  			implode(',', $ex_fid_ary), -			implode(',', $m_approve_fid_ary), +// @TODO			implode(',', $m_approve_fid_ary),  			implode(',', $author_ary),  			$author_name,  		))); @@ -628,7 +628,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  			$sql_where[] = '(' . implode(' OR ', $is_null_joins) . ')';  		} -		if (!sizeof($m_approve_fid_ary)) +/*		if (!sizeof($m_approve_fid_ary))  		{  			$sql_where[] = 'p.post_approved = 1';  		} @@ -636,6 +636,8 @@ class phpbb_search_fulltext_native extends phpbb_search_base  		{  			$sql_where[] = '(p.post_approved = 1 OR ' . $this->db->sql_in_set('p.forum_id', $m_approve_fid_ary, true) . ')';  		} +*/ +		$sql_where[] = $m_approve_fid_sql;  		if ($topic_id)  		{ @@ -808,7 +810,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  	* @param	string		$sort_dir			is either a or d representing ASC and DESC  	* @param	string		$sort_days			specifies the maximum amount of days a post may be old  	* @param	array		$ex_fid_ary			specifies an array of forum ids which should not be searched -	* @param	array		$m_approve_fid_ary	specifies an array of forum ids in which the searcher is allowed to view unapproved posts +	* @param	array		$m_approve_fid_sql	specifies which posts a user can view, based on permissions  	* @param	int			$topic_id			is set to 0 or a topic id, if it is not 0 then only posts in this topic should be searched  	* @param	array		$author_ary			an array of author ids  	* @param	string		$author_name		specifies the author match, when ANONYMOUS is also a search-match @@ -836,7 +838,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  			$sort_key,  			$topic_id,  			implode(',', $ex_fid_ary), -			implode(',', $m_approve_fid_ary), +// @TODO			implode(',', $m_approve_fid_ary),  			implode(',', $author_ary),  			$author_name,  		))); @@ -886,7 +888,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  			break;  		} -		if (!sizeof($m_approve_fid_ary)) +/*		if (!sizeof($m_approve_fid_ary))  		{  			$m_approve_fid_sql = ' AND p.post_approved = 1';  		} @@ -898,6 +900,7 @@ class phpbb_search_fulltext_native extends phpbb_search_base  		{  			$m_approve_fid_sql = ' AND (p.post_approved = 1 OR ' . $this->db->sql_in_set('p.forum_id', $m_approve_fid_ary, true) . ')';  		} +*/  		$select = ($type == 'posts') ? 'p.post_id' : 't.topic_id';  		$is_mysql = false; | 
