mirror of
https://github.com/phpbb/phpbb.git
synced 2025-10-24 13:16:16 +02:00
125 lines
2.8 KiB
PHP
125 lines
2.8 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.
|
|
*
|
|
*/
|
|
|
|
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) || !count($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 (count($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);
|
|
}
|
|
}
|
|
|
|
}
|