mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-25 05:36:13 +02:00 
			
		
		
		
	[ticket/12150] Add file and caller for pruning shadow topics
PHPBB3-12150
This commit is contained in:
		| @@ -23,6 +23,18 @@ services: | |||||||
|         tags: |         tags: | ||||||
|             - { name: cron.task } |             - { name: cron.task } | ||||||
|  |  | ||||||
|  |     cron.task.core.prune_shadow_topics: | ||||||
|  |         class: phpbb\cron\task\core\prune_shadow_topics | ||||||
|  |         arguments: | ||||||
|  |             - %core.root_path% | ||||||
|  |             - %core.php_ext% | ||||||
|  |             - @config | ||||||
|  |             - @dbal.conn | ||||||
|  |         calls: | ||||||
|  |             - [set_name, [cron.task.core.prune_shadow_topics]] | ||||||
|  |         tags: | ||||||
|  |             - { name: cron.task } | ||||||
|  |  | ||||||
|     cron.task.core.prune_notifications: |     cron.task.core.prune_notifications: | ||||||
|         class: phpbb\cron\task\core\prune_notifications |         class: phpbb\cron\task\core\prune_notifications | ||||||
|         arguments: |         arguments: | ||||||
|   | |||||||
| @@ -2326,6 +2326,11 @@ function prune($forum_id, $prune_mode, $prune_date, $prune_flags = 0, $auto_sync | |||||||
| 		$sql_and .= " AND topic_last_view_time < $prune_date"; | 		$sql_and .= " AND topic_last_view_time < $prune_date"; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	if ($prune_mode == 'shadow') | ||||||
|  | 	{ | ||||||
|  | 		$sql_and .= ' AND topic_type = ' . ITEM_MOVED . "AND topic_last_post_time < $prune_date"; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	$sql = 'SELECT topic_id | 	$sql = 'SELECT topic_id | ||||||
| 		FROM ' . TOPICS_TABLE . ' | 		FROM ' . TOPICS_TABLE . ' | ||||||
| 		WHERE ' . $db->sql_in_set('forum_id', $forum_id) . " | 		WHERE ' . $db->sql_in_set('forum_id', $forum_id) . " | ||||||
|   | |||||||
| @@ -676,6 +676,7 @@ $lang = array_merge($lang, array( | |||||||
|  |  | ||||||
| 	'LOG_PRUNE'					=> '<strong>Pruned forums</strong><br />» %s', | 	'LOG_PRUNE'					=> '<strong>Pruned forums</strong><br />» %s', | ||||||
| 	'LOG_AUTO_PRUNE'			=> '<strong>Auto-pruned forums</strong><br />» %s', | 	'LOG_AUTO_PRUNE'			=> '<strong>Auto-pruned forums</strong><br />» %s', | ||||||
|  | 	'LOG_PRUNE_SHADOW_TOPIC'	=> '<strong>Auto-pruned shadow topics</strong><br />» %s', | ||||||
| 	'LOG_PRUNE_USER_DEAC'		=> '<strong>Users deactivated</strong><br />» %s', | 	'LOG_PRUNE_USER_DEAC'		=> '<strong>Users deactivated</strong><br />» %s', | ||||||
| 	'LOG_PRUNE_USER_DEL_DEL'	=> '<strong>Users pruned and posts deleted</strong><br />» %s', | 	'LOG_PRUNE_USER_DEL_DEL'	=> '<strong>Users pruned and posts deleted</strong><br />» %s', | ||||||
| 	'LOG_PRUNE_USER_DEL_ANON'	=> '<strong>Users pruned and posts retained</strong><br />» %s', | 	'LOG_PRUNE_USER_DEL_ANON'	=> '<strong>Users pruned and posts retained</strong><br />» %s', | ||||||
|   | |||||||
							
								
								
									
										188
									
								
								phpBB/phpbb/cron/task/core/prune_shadow_topics.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								phpBB/phpbb/cron/task/core/prune_shadow_topics.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,188 @@ | |||||||
|  | <?php | ||||||
|  | /** | ||||||
|  | * | ||||||
|  | * @package phpBB3 | ||||||
|  | * @copyright (c) 2014 phpBB Group | ||||||
|  | * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 | ||||||
|  | * | ||||||
|  | */ | ||||||
|  |  | ||||||
|  | namespace phpbb\cron\task\core; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  | * Prune one forum of its shadow topics cron task. | ||||||
|  | * | ||||||
|  | * It is intended to be used when cron is invoked via web. | ||||||
|  | * This task can decide whether it should be run using data obtained by viewforum | ||||||
|  | * code, without making additional database queries. | ||||||
|  | * | ||||||
|  | * @package phpBB3 | ||||||
|  | */ | ||||||
|  | class prune_shadow_topics extends \phpbb\cron\task\base implements \phpbb\cron\task\parametrized | ||||||
|  | { | ||||||
|  | 	protected $phpbb_root_path; | ||||||
|  | 	protected $php_ext; | ||||||
|  | 	protected $config; | ||||||
|  | 	protected $db; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* If $forum_data is given, it is assumed to contain necessary information | ||||||
|  | 	* about a single forum that is to be pruned. | ||||||
|  | 	* | ||||||
|  | 	* If $forum_data is not given, forum id will be retrieved via request_var | ||||||
|  | 	* and a database query will be performed to load the necessary information | ||||||
|  | 	* about the forum. | ||||||
|  | 	*/ | ||||||
|  | 	protected $forum_data; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Constructor. | ||||||
|  | 	* | ||||||
|  | 	* @param string $phpbb_root_path The root path | ||||||
|  | 	* @param string $php_ext The PHP extension | ||||||
|  | 	* @param \phpbb\config\config $config The config | ||||||
|  | 	* @param \phpbb\db\driver\driver $db The db connection | ||||||
|  | 	*/ | ||||||
|  | 	public function __construct($phpbb_root_path, $php_ext, \phpbb\config\config $config, \phpbb\db\driver\driver $db) | ||||||
|  | 	{ | ||||||
|  | 		$this->phpbb_root_path = $phpbb_root_path; | ||||||
|  | 		$this->php_ext = $php_ext; | ||||||
|  | 		$this->config = $config; | ||||||
|  | 		$this->db = $db; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Manually set forum data. | ||||||
|  | 	* | ||||||
|  | 	* @param array $forum_data Information about a forum to be pruned. | ||||||
|  | 	*/ | ||||||
|  | 	public function set_forum_data($forum_data) | ||||||
|  | 	{ | ||||||
|  | 		$this->forum_data = $forum_data; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Runs this cron task. | ||||||
|  | 	* | ||||||
|  | 	* @return null | ||||||
|  | 	*/ | ||||||
|  | 	public function run() | ||||||
|  | 	{ | ||||||
|  | 		if (!function_exists('auto_prune')) | ||||||
|  | 		{ | ||||||
|  | 			include($this->phpbb_root_path . 'includes/functions_admin.' . $this->php_ext); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if ($this->forum_data['prune_shadow_topic_days']) | ||||||
|  | 		{ | ||||||
|  | 			auto_prune($this->forum_data['forum_id'], 'shadow', $this->forum_data['forum_flags'], $this->forum_data['prune_shadow_topic_days'], $this->forum_data['prune_shadow_topic_freq']); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Returns whether this cron task can run, given current board configuration. | ||||||
|  | 	* | ||||||
|  | 	* This cron task will not run when system cron is utilised, as in | ||||||
|  | 	* such cases prune_all_forums task would run instead. | ||||||
|  | 	* | ||||||
|  | 	* Additionally, this task must be given the forum data, either via | ||||||
|  | 	* the constructor or parse_parameters method. | ||||||
|  | 	* | ||||||
|  | 	* @return bool | ||||||
|  | 	*/ | ||||||
|  | 	public function is_runnable() | ||||||
|  | 	{ | ||||||
|  | 		return !$this->config['use_system_cron'] && $this->forum_data; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Returns whether this cron task should run now, because enough time | ||||||
|  | 	* has passed since it was last run. | ||||||
|  | 	* | ||||||
|  | 	* Forum pruning interval is specified in the forum data. | ||||||
|  | 	* | ||||||
|  | 	* @return bool | ||||||
|  | 	*/ | ||||||
|  | 	public function should_run() | ||||||
|  | 	{ | ||||||
|  | 		return $this->forum_data['enable_shadow_topic_prune'] && $this->forum_data['prune_shadow_topic_next'] < time(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Returns parameters of this cron task as an array. | ||||||
|  | 	* The array has one key, f, whose value is id of the forum to be pruned. | ||||||
|  | 	* | ||||||
|  | 	* @return array | ||||||
|  | 	*/ | ||||||
|  | 	public function get_parameters() | ||||||
|  | 	{ | ||||||
|  | 		return array('f' => $this->forum_data['forum_id']); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Parses parameters found in $request, which is an instance of | ||||||
|  | 	* \phpbb\request\request_interface. | ||||||
|  | 	* | ||||||
|  | 	* It is expected to have a key f whose value is id of the forum to be pruned. | ||||||
|  | 	* | ||||||
|  | 	* @param \phpbb\request\request_interface $request Request object. | ||||||
|  | 	* | ||||||
|  | 	* @return null | ||||||
|  | 	*/ | ||||||
|  | 	public function parse_parameters(\phpbb\request\request_interface $request) | ||||||
|  | 	{ | ||||||
|  | 		$this->forum_data = null; | ||||||
|  | 		if ($request->is_set('f')) | ||||||
|  | 		{ | ||||||
|  | 			$forum_id = $request->variable('f', 0); | ||||||
|  |  | ||||||
|  | 			$sql = 'SELECT forum_id, prune_shadow_topic_next, enable_shadow_topic_prune, prune_shadow_topic_days, forum_flags, prune_shadow_topic_freq | ||||||
|  | 				FROM ' . FORUMS_TABLE . " | ||||||
|  | 				WHERE forum_id = $forum_id"; | ||||||
|  | 			$result = $this->db->sql_query($sql); | ||||||
|  | 			$row = $this->db->sql_fetchrow($result); | ||||||
|  | 			$this->db->sql_freeresult($result); | ||||||
|  |  | ||||||
|  | 			if ($row) | ||||||
|  | 			{ | ||||||
|  | 				$this->forum_data = $row; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	* Automatically prune shadow topics | ||||||
|  | 	* Based on fuunction auto_prune() | ||||||
|  | 	* @param int $forum_id Forum ID of forum that should be pruned | ||||||
|  | 	* @param string $prune_mode Prune mode | ||||||
|  | 	* @param int $prune_flags Prune flags | ||||||
|  | 	* @param int $prune_freq Prune frequency | ||||||
|  | 	* @return null | ||||||
|  | 	*/ | ||||||
|  | 	protected function auto_prune_shadow_topics($forum_id, $prune_mode, $prune_flags, $prune_days, $prune_freq) | ||||||
|  | 	{ | ||||||
|  | 		$sql = 'SELECT forum_name | ||||||
|  | 			FROM ' . FORUMS_TABLE . " | ||||||
|  | 			WHERE forum_id = $forum_id"; | ||||||
|  | 		$result = $this->db->sql_query($sql, 3600); | ||||||
|  | 		$row = $this->db->sql_fetchrow($result); | ||||||
|  | 		$this->db->sql_freeresult($result); | ||||||
|  |  | ||||||
|  | 		if ($row) | ||||||
|  | 		{ | ||||||
|  | 			$prune_date = time() - ($prune_days * 86400); | ||||||
|  | 			$next_prune = time() + ($prune_freq * 86400); | ||||||
|  |  | ||||||
|  | 			prune($forum_id, $prune_mode, $prune_date, $prune_flags, true); | ||||||
|  |  | ||||||
|  | 			$sql = 'UPDATE ' . FORUMS_TABLE . " | ||||||
|  | 				SET prune_shadow_topic_next = $next_prune | ||||||
|  | 				WHERE forum_id = $forum_id"; | ||||||
|  | 			$this->db->sql_query($sql); | ||||||
|  |  | ||||||
|  | 			add_log('admin', 'LOG_PRUNE_SHADOW_TOPIC', $row['forum_name']); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -224,6 +224,18 @@ if (!$config['use_system_cron']) | |||||||
| 		$url = $task->get_url(); | 		$url = $task->get_url(); | ||||||
| 		$template->assign_var('RUN_CRON_TASK', '<img src="' . $url . '" width="1" height="1" alt="cron" />'); | 		$template->assign_var('RUN_CRON_TASK', '<img src="' . $url . '" width="1" height="1" alt="cron" />'); | ||||||
| 	} | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		// See if we should prune the shadow topics instead | ||||||
|  | 		$task = $cron->find_task('cron.task.core.prune_shadow_topics'); | ||||||
|  | 		$task->set_forum_data($forum_data); | ||||||
|  |  | ||||||
|  | 		if ($task->is_ready()) | ||||||
|  | 		{ | ||||||
|  | 			$url = $task->get_url(); | ||||||
|  | 			$template->assign_var('RUN_CRON_TASK', '<img src="' . $url . '" width="1" height="1" alt="cron" />'); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| // Forum rules and subscription info | // Forum rules and subscription info | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user