diff options
Diffstat (limited to 'phpBB/phpbb/attachment/resync.php')
| -rw-r--r-- | phpBB/phpbb/attachment/resync.php | 124 | 
1 files changed, 124 insertions, 0 deletions
| diff --git a/phpBB/phpbb/attachment/resync.php b/phpBB/phpbb/attachment/resync.php new file mode 100644 index 0000000000..6c2e0a8b0d --- /dev/null +++ b/phpBB/phpbb/attachment/resync.php @@ -0,0 +1,124 @@ +<?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. + * + */ + +namespace phpbb\attachment; + +use \phpbb\db\driver\driver_interface; + +/** + * Attachment resync class + */ +class resync +{ +	/** @var driver_interface */ +	protected $db; + +	/** @var string Attachment table SQL ID */ +	private $attach_sql_id; + +	/** @var string Resync table SQL ID  */ +	private $resync_sql_id; + +	/** @var string Resync SQL table */ +	private $resync_table; + +	/** @var string SQL where statement */ +	private $sql_where; + +	/** +	 * Constructor for attachment resync class +	 * +	 * @param driver_interface $db Database driver +	 */ +	public function __construct(driver_interface $db) +	{ +		$this->db = $db; +	} + +	/** +	 * Set type constraints for attachment resync +	 * +	 * @param string $type Type of resync; can be: message|post|topic +	 */ +	protected function set_type_constraints($type) +	{ +		switch ($type) +		{ +			case 'message': +				$this->attach_sql_id = 'post_msg_id'; +				$this->sql_where = ' AND in_message = 1 +					AND is_orphan = 0'; +				$this->resync_table = PRIVMSGS_TABLE; +				$this->resync_sql_id = 'msg_id'; +			break; + +			case 'post': +				$this->attach_sql_id = 'post_msg_id'; +				$this->sql_where = ' AND in_message = 0 +					AND is_orphan = 0'; +				$this->resync_table = POSTS_TABLE; +				$this->resync_sql_id = 'post_id'; +			break; + +			case 'topic': +				$this->attach_sql_id = 'topic_id'; +				$this->sql_where = ' AND is_orphan = 0'; +				$this->resync_table = TOPICS_TABLE; +				$this->resync_sql_id = 'topic_id'; +			break; +		} +	} + +	/** +	 * Resync specified type +	 * +	 * @param string $type Type of resync +	 * @param array $ids IDs to resync +	 */ +	public function resync($type, $ids) +	{ +		if (empty($type) || !is_array($ids) || !sizeof($ids) || !in_array($type, array('post', 'topic', 'message'))) +		{ +			return; +		} + +		$this->set_type_constraints($type); + +		// Just check which elements are still having an assigned attachment +		// not orphaned by querying the attachments table +		$sql = 'SELECT ' . $this->attach_sql_id . ' +			FROM ' . ATTACHMENTS_TABLE . ' +			WHERE ' . $this->db->sql_in_set($this->attach_sql_id, $ids) +				. $this->sql_where; +		$result = $this->db->sql_query($sql); + +		$remaining_ids = array(); +		while ($row = $this->db->sql_fetchrow($result)) +		{ +			$remaining_ids[] = $row[$this->attach_sql_id]; +		} +		$this->db->sql_freeresult($result); + +		// Now only unset those ids remaining +		$ids = array_diff($ids, $remaining_ids); + +		if (sizeof($ids)) +		{ +			$sql = 'UPDATE ' . $this->resync_table . ' +				SET ' . $type . '_attachment = 0 +				WHERE ' . $this->db->sql_in_set($this->resync_sql_id, $ids); +			$this->db->sql_query($sql); +		} +	} + +} | 
