mirror of
https://github.com/phpbb/phpbb.git
synced 2025-10-24 13:16:16 +02:00
98 lines
2.3 KiB
PHP
98 lines
2.3 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\feed;
|
|
|
|
/**
|
|
* Abstract class for feeds displaying attachments
|
|
*/
|
|
abstract class attachments_base extends base
|
|
{
|
|
/**
|
|
* Attachments that may be displayed
|
|
*/
|
|
protected $attachments = array();
|
|
|
|
/**
|
|
* Retrieve the list of attachments that may be displayed
|
|
*
|
|
* @param array $post_ids Specify for which post IDs to fetch the attachments (optional)
|
|
* @param array $topic_ids Specify for which topic IDs to fetch the attachments (optional)
|
|
*/
|
|
protected function fetch_attachments($post_ids = array(), $topic_ids = array())
|
|
{
|
|
$sql_array = array(
|
|
'SELECT' => 'a.*',
|
|
'FROM' => array(
|
|
ATTACHMENTS_TABLE => 'a'
|
|
),
|
|
'WHERE' => 'a.in_message = 0 ',
|
|
'ORDER_BY' => 'a.filetime DESC, a.post_msg_id ASC',
|
|
);
|
|
|
|
if (!empty($post_ids))
|
|
{
|
|
$sql_array['WHERE'] .= 'AND ' . $this->db->sql_in_set('a.post_msg_id', $post_ids);
|
|
}
|
|
else if (!empty($topic_ids))
|
|
{
|
|
if (isset($this->topic_id))
|
|
{
|
|
$topic_ids[] = $this->topic_id;
|
|
}
|
|
|
|
$sql_array['WHERE'] .= 'AND ' . $this->db->sql_in_set('a.topic_id', $topic_ids);
|
|
}
|
|
else if (isset($this->topic_id))
|
|
{
|
|
$sql_array['WHERE'] .= 'AND a.topic_id = ' . (int) $this->topic_id;
|
|
}
|
|
else if (isset($this->forum_id))
|
|
{
|
|
$sql_array['LEFT_JOIN'] = array(
|
|
array(
|
|
'FROM' => array(TOPICS_TABLE => 't'),
|
|
'ON' => 'a.topic_id = t.topic_id',
|
|
)
|
|
);
|
|
$sql_array['WHERE'] .= 'AND t.forum_id = ' . (int) $this->forum_id;
|
|
}
|
|
else
|
|
{
|
|
// Do not allow querying the full attachments table
|
|
throw new \RuntimeException($this->user->lang('INVALID_FEED_ATTACHMENTS'));
|
|
}
|
|
|
|
$sql = $this->db->sql_build_query('SELECT', $sql_array);
|
|
$result = $this->db->sql_query($sql);
|
|
|
|
// Set attachments in feed items
|
|
while ($row = $this->db->sql_fetchrow($result))
|
|
{
|
|
$this->attachments[$row['post_msg_id']][] = $row;
|
|
}
|
|
$this->db->sql_freeresult($result);
|
|
}
|
|
|
|
/**
|
|
* Get attachments related to a given post
|
|
*
|
|
* @param $post_id int Post id
|
|
* @return mixed Attachments related to $post_id
|
|
*/
|
|
public function get_attachments($post_id)
|
|
{
|
|
return $this->attachments[$post_id];
|
|
}
|
|
}
|