mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 21:21:32 +01:00 
			
		
		
		
	git-svn-id: file:///svn/phpbb/trunk@7786 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
		| @@ -292,6 +292,7 @@ p a { | |||||||
| 		<li>[Fix] Writing directories/files with correct permissions using FTP for transfers on PHP4</li> | 		<li>[Fix] Writing directories/files with correct permissions using FTP for transfers on PHP4</li> | ||||||
| 		<li>[Fix] Oracle sequences during conversions are now corrected (Bug #12555)</li> | 		<li>[Fix] Oracle sequences during conversions are now corrected (Bug #12555)</li> | ||||||
| 		<li>[Fix] Allow users to continue after selecting "No" in the merge quickmod confirmation (Bug #12577)</li> | 		<li>[Fix] Allow users to continue after selecting "No" in the merge quickmod confirmation (Bug #12577)</li> | ||||||
|  | 		<li>[Fix] Correctly check permissions on the UCP subscription/bookmark pages (Bug #12595)</li> | ||||||
|  |  | ||||||
| 	</ul> | 	</ul> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -231,8 +231,13 @@ class ucp_main | |||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
|  | 				$forbidden_forums = array(); | ||||||
|  |  | ||||||
| 				if ($config['allow_forum_notify']) | 				if ($config['allow_forum_notify']) | ||||||
| 				{ | 				{ | ||||||
|  | 					$forbidden_forums = $forbidden_forums = $auth->acl_getf('!f_read', true); | ||||||
|  | 					$forbidden_forums = array_unique(array_keys($forbidden_forums)); | ||||||
|  | 					 | ||||||
| 					$sql_array = array( | 					$sql_array = array( | ||||||
| 						'SELECT'	=> 'f.*', | 						'SELECT'	=> 'f.*', | ||||||
|  |  | ||||||
| @@ -242,7 +247,8 @@ class ucp_main | |||||||
| 						), | 						), | ||||||
|  |  | ||||||
| 						'WHERE'		=> 'fw.user_id = ' . $user->data['user_id'] . '  | 						'WHERE'		=> 'fw.user_id = ' . $user->data['user_id'] . '  | ||||||
| 							AND f.forum_id = fw.forum_id', | 							AND f.forum_id = fw.forum_id | ||||||
|  | 							AND ' . $db->sql_in_set('f.forum_id', $forbidden_forums, true, true), | ||||||
|  |  | ||||||
| 						'ORDER_BY'	=> 'left_id' | 						'ORDER_BY'	=> 'left_id' | ||||||
| 					); | 					); | ||||||
| @@ -330,7 +336,12 @@ class ucp_main | |||||||
| 				// Subscribed Topics | 				// Subscribed Topics | ||||||
| 				if ($config['allow_topic_notify']) | 				if ($config['allow_topic_notify']) | ||||||
| 				{ | 				{ | ||||||
| 					$this->assign_topiclist('subscribed'); | 					if (empty($forbidden_forums)) | ||||||
|  | 					{ | ||||||
|  | 						$forbidden_forums = $auth->acl_getf('!f_read', true); | ||||||
|  | 						$forbidden_forums = array_unique(array_keys($forbidden_forums)); | ||||||
|  | 					} | ||||||
|  | 					$this->assign_topiclist('subscribed', $forbidden_forums); | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				$template->assign_vars(array( | 				$template->assign_vars(array( | ||||||
| @@ -386,8 +397,10 @@ class ucp_main | |||||||
| 						confirm_box(false, 'REMOVE_SELECTED_BOOKMARKS', build_hidden_fields($s_hidden_fields)); | 						confirm_box(false, 'REMOVE_SELECTED_BOOKMARKS', build_hidden_fields($s_hidden_fields)); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|  | 				$forbidden_forums = $auth->acl_getf('!f_read', true); | ||||||
| 				$this->assign_topiclist('bookmarks'); | 				$forbidden_forums = array_unique(array_keys($forbidden_forums)); | ||||||
|  | 				 | ||||||
|  | 				$this->assign_topiclist('bookmarks', $forbidden_forums); | ||||||
|  |  | ||||||
| 			break; | 			break; | ||||||
|  |  | ||||||
| @@ -584,16 +597,26 @@ class ucp_main | |||||||
| 	/** | 	/** | ||||||
| 	* Build and assign topiclist for bookmarks/subscribed topics | 	* Build and assign topiclist for bookmarks/subscribed topics | ||||||
| 	*/ | 	*/ | ||||||
| 	function assign_topiclist($mode = 'subscribed') | 	function assign_topiclist($mode = 'subscribed', $forbidden_forum_ary = array()) | ||||||
| 	{ | 	{ | ||||||
| 		global $user, $db, $template, $config, $auth, $phpbb_root_path, $phpEx; | 		global $user, $db, $template, $config, $auth, $phpbb_root_path, $phpEx; | ||||||
|  |  | ||||||
| 		$table = ($mode == 'subscribed') ? TOPICS_WATCH_TABLE : BOOKMARKS_TABLE; | 		$table = ($mode == 'subscribed') ? TOPICS_WATCH_TABLE : BOOKMARKS_TABLE; | ||||||
| 		$start = request_var('start', 0); | 		$start = request_var('start', 0); | ||||||
|  |  | ||||||
| 		$sql = 'SELECT COUNT(topic_id) as topics_count | 		$sql_array = array( | ||||||
| 			FROM ' . $table . ' | 			'SELECT'	=> 'COUNT(t.topic_id) as topics_count', | ||||||
| 			WHERE user_id = ' . $user->data['user_id']; |  | ||||||
|  | 			'FROM'		=> array( | ||||||
|  | 				$table			=> 'i', | ||||||
|  | 				TOPICS_TABLE	=> 't' | ||||||
|  | 			), | ||||||
|  |  | ||||||
|  | 			'WHERE'		=>	'i.topic_id = t.topic_id | ||||||
|  | 				AND i.user_id = ' . $user->data['user_id'] . ' | ||||||
|  | 				AND ' . $db->sql_in_set('t.forum_id', $forbidden_forum_ary, true, true), | ||||||
|  | 		); | ||||||
|  | 		$sql = $db->sql_build_query('SELECT', $sql_array); | ||||||
| 		$result = $db->sql_query($sql); | 		$result = $db->sql_query($sql); | ||||||
| 		$topics_count = (int) $db->sql_fetchfield('topics_count'); | 		$topics_count = (int) $db->sql_fetchfield('topics_count'); | ||||||
| 		$db->sql_freeresult($result); | 		$db->sql_freeresult($result); | ||||||
| @@ -618,7 +641,9 @@ class ucp_main | |||||||
| 				), | 				), | ||||||
|  |  | ||||||
| 				'WHERE'		=> 'tw.user_id = ' . $user->data['user_id'] . ' | 				'WHERE'		=> 'tw.user_id = ' . $user->data['user_id'] . ' | ||||||
| 					AND t.topic_id = tw.topic_id', | 					AND t.topic_id = tw.topic_id | ||||||
|  | 					AND ' . $db->sql_in_set('t.forum_id', $forbidden_forum_ary, true, true), | ||||||
|  | 					 | ||||||
|  |  | ||||||
| 				'ORDER_BY'	=> 't.topic_last_post_time DESC' | 				'ORDER_BY'	=> 't.topic_last_post_time DESC' | ||||||
| 			); | 			); | ||||||
| @@ -634,7 +659,8 @@ class ucp_main | |||||||
| 					BOOKMARKS_TABLE		=> 'b', | 					BOOKMARKS_TABLE		=> 'b', | ||||||
| 				), | 				), | ||||||
|  |  | ||||||
| 				'WHERE'		=> 'b.user_id = ' . $user->data['user_id'], | 				'WHERE'		=> 'b.user_id = ' . $user->data['user_id'] . ' | ||||||
|  | 					AND ' . $db->sql_in_set('f.forum_id', $forbidden_forum_ary, true, true), | ||||||
|  |  | ||||||
| 				'ORDER_BY'	=> 't.topic_last_post_time DESC' | 				'ORDER_BY'	=> 't.topic_last_post_time DESC' | ||||||
| 			); | 			); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user