Completed
Push — master ( 4f5aad...a0199d )
by Daniel
09:18
created

data::_get_post_data_where()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 17
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 12
CRAP Score 3

Importance

Changes 4
Bugs 1 Features 0
Metric Value
c 4
b 1
f 0
dl 0
loc 17
ccs 12
cts 12
cp 1
rs 9.4285
cc 3
eloc 8
nc 3
nop 2
crap 3
1
<?php
2
/**
3
 *
4
 * @package sitemaker
5
 * @copyright (c) 2013 Daniel A. (blitze)
6
 * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
7
 *
8
 */
9
10
namespace blitze\sitemaker\services\forum;
11
12
use blitze\sitemaker\services\forum\query_builder;
13
14
class data extends query_builder
15
{
16
	/** @var \phpbb\auth\auth */
17
	protected $auth;
18
19
	/** @var \phpbb\config\config */
20
	protected $config;
21
22
	/** @var \phpbb\content_visibility */
23
	protected $content_visibility;
24
25
	/** @var \phpbb\db\driver\driver_interface */
26
	protected $db;
27
28
	/** @var \phpbb\user */
29
	protected $user;
30
31
	/**
32
	 * Constructor
33
	 *
34
	 * @param \phpbb\auth\auth					$auth					Auth object
35
	 * @param \phpbb\config\config				$config					Config object
36
	 * @param \phpbb\content_visibility			$content_visibility		Content visibility
37
	 * @param \phpbb\db\driver\driver_interface	$db     				Database connection
38
	 * @param \phpbb\user						$user					User object
39
	 * @param integer							$cache_time				Cache results for 3 hours by default
40
	 */
41 26
	public function __construct(\phpbb\auth\auth $auth, \phpbb\config\config $config, \phpbb\content_visibility $content_visibility, \phpbb\db\driver\driver_interface $db, \phpbb\user $user, $cache_time = 10800)
42
	{
43 26
		parent::__construct($auth, $config, $content_visibility, $db, $user, $cache_time);
44
45 26
		$this->auth = $auth;
46 26
		$this->config = $config;
47 26
		$this->content_visibility = $content_visibility;
48 26
		$this->db = $db;
49 26
		$this->user = $user;
50 26
	}
51
52
	/**
53
	 * Get topic data
54
	 *
55
	 * @param mixed|false $limit
56
	 * @param int $start
57
	 * @return array
58
	 */
59 12
	public function get_topic_data($limit = false, $start = 0)
60
	{
61 12
		$sql = $this->db->sql_build_query('SELECT', $this->store['sql_array']);
62 12
		$result = $this->db->sql_query_limit($sql, $limit, $start, $this->cache_time);
63
64 12
		while ($row = $this->db->sql_fetchrow($result))
65
		{
66 10
			$this->store['topic'][$row['topic_id']] = $row;
67
68 10
			$this->store['tracking'][$row['forum_id']]['topic_list'][] = $row['topic_id'];
69 10
			$this->store['tracking'][$row['forum_id']]['mark_time'] =& $row['forum_mark_time'];
70 10
			$this->store['post_ids']['first'][] = $row['topic_first_post_id'];
71 10
			$this->store['post_ids']['last'][] = $row['topic_last_post_id'];
72 10
		}
73 12
		$this->db->sql_freeresult($result);
74
75 12
		return $this->store['topic'];
76
	}
77
78
	/**
79
	 * Get post data
80
	 *
81
	 * @param mixed|false $topic_first_or_last_post (first|last)
82
	 * @param array $post_ids
83
	 * @param bool|false $limit
84
	 * @param int $start
85
	 * @param array $sql_array
86
	 * @return array
87
	 */
88 10
	public function get_post_data($topic_first_or_last_post = false, $post_ids = array(), $limit = false, $start = 0, $sql_array = array())
89
	{
90 10
		$sql = $this->db->sql_build_query('SELECT_DISTINCT', $this->_get_posts_sql_array($topic_first_or_last_post, $post_ids, $sql_array));
91 10
		$result = $this->db->sql_query_limit($sql, $limit, $start, $this->cache_time);
92
93 10
		$post_data = array();
94 10
		while ($row = $this->db->sql_fetchrow($result))
95
		{
96 9
			$parse_flags = ($row['bbcode_bitfield'] ? OPTION_FLAG_BBCODE : 0) | OPTION_FLAG_SMILIES;
97 9
			$row['post_text'] = generate_text_for_display($row['post_text'], $row['bbcode_uid'], $row['bbcode_bitfield'], $parse_flags, true);
98
99 9
			$post_data[$row['topic_id']][$row['post_id']] = $row;
100 9
			$this->store['poster_ids'][] = $row['poster_id'];
101 9
			$this->store['poster_ids'][] = $row['post_edit_user'];
102 9
			$this->store['poster_ids'][] = $row['post_delete_user'];
103 9
			$this->store['attachments'][] = $row['post_id'];
104 9
		}
105 10
		$this->db->sql_freeresult($result);
106
107 10
		return $post_data;
108
	}
109
110
	/**
111
	 * Get attachments...
112
	 *
113
	 * @param int $forum_id
114
	 * @param array $allowed_extensions
115
	 * @param bool $exclude_in_message
116
	 * @param string $order_by
117
	 * @return array
118
	 */
119 7
	public function get_attachments($forum_id = 0, $allowed_extensions = array(), $exclude_in_message = true, $order_by = 'filetime DESC, post_msg_id ASC')
120
	{
121 7
		$this->store['attachments'] = array_filter($this->store['attachments']);
122
123 7
		$attachments = array();
124 7
		if ($this->_attachments_allowed($forum_id))
125 7
		{
126 6
			$sql = $this->_get_attachment_sql($allowed_extensions, $exclude_in_message, $order_by);
127 6
			$result = $this->db->sql_query($sql);
128
129 6
			while ($row = $this->db->sql_fetchrow($result))
130
			{
131 6
				$attachments[$row['post_msg_id']][] = $row;
132 6
			}
133 6
			$this->db->sql_freeresult($result);
134 6
		}
135 7
		$this->store['attachments'] = array();
136
137 7
		return $attachments;
138
	}
139
140
	/**
141
	 * Get topic tracking info
142
	 *
143
	 * @param int $forum_id
144
	 * @return array
145
	 */
146 5
	public function get_topic_tracking_info($forum_id = 0)
147
	{
148 5
		if (!sizeof($this->store['tracking']))
149 5
		{
150
			return array();
151
		}
152
153 5
		$tracking_info = $this->_get_tracking_info();
154
155 5
		return ($forum_id) ? (isset($tracking_info[$forum_id]) ? $tracking_info[$forum_id] : array()) : $tracking_info;
156
	}
157
158
	/**
159
	 * Returns an array of topic first post or last post ids
160
	 *
161
	 * @param string $first_or_last_post
162
	 * @return array
163
	 */
164 3
	public function get_topic_post_ids($first_or_last_post = 'first')
165
	{
166 3
		return (isset($this->store['post_ids'][$first_or_last_post])) ? $this->store['post_ids'][$first_or_last_post] : array();
167
	}
168
169
	/**
170
	 * @param mixed $topic_first_or_last_post
171
	 * @param array $post_ids
172
	 * @param array $sql_array
173
	 * @return array
174
	 */
175 10
	private function _get_posts_sql_array($topic_first_or_last_post, array $post_ids, array $sql_array)
176
	{
177 10
		$sql_array = array_merge_recursive(
178
			array(
179 10
				'SELECT'	=> array('p.*'),
180 10
				'FROM'		=> array(POSTS_TABLE => 'p'),
181 10
				'WHERE'		=> $this->_get_post_data_where($post_ids, $topic_first_or_last_post),
182 10
				'ORDER_BY'	=> 'p.topic_id, p.post_time ASC',
183 10
			),
184
			$sql_array
185 10
		);
186
187 10
		$sql_array['SELECT'] = join(', ', array_filter($sql_array['SELECT']));
188 10
		$sql_array['WHERE'] = join(' AND ', array_filter($sql_array['WHERE']));
189
190 10
		return $sql_array;
191
	}
192
193
	/**
194
	 * @param array $post_ids
195
	 * @param string $topic_first_or_last_post
196
	 * @return array
197
	 */
198 10
	private function _get_post_data_where(array $post_ids, $topic_first_or_last_post)
199
	{
200 10
		$sql_where = array();
201
202 10
		if (sizeof($post_ids))
203 10
		{
204 2
			$sql_where[] = $this->db->sql_in_set('p.post_id', $post_ids);
205 2
		}
206 8
		else if (sizeof($this->store['topic']))
207 8
		{
208 3
			$this->_limit_posts_by_topic($sql_where, $topic_first_or_last_post);
209 3
		}
210
211 10
		$sql_where[] = $this->content_visibility->get_global_visibility_sql('post', $this->ex_fid_ary, 'p.');
212
213 10
		return $sql_where;
214
	}
215
216
	/**
217
	 * @param array $sql_where
218
	 * @param string $first_or_last_post
0 ignored issues
show
Documentation introduced by
There is no parameter named $first_or_last_post. Did you maybe mean $topic_first_or_last_post?

This check looks for PHPDoc comments describing methods or function parameters that do not exist on the corresponding method or function. It has, however, found a similar but not annotated parameter which might be a good fit.

Consider the following example. The parameter $ireland is not defined by the method finale(...).

/**
 * @param array $germany
 * @param array $ireland
 */
function finale($germany, $island) {
    return "2:1";
}

The most likely cause is that the parameter was changed, but the annotation was not.

Loading history...
219
	 */
220 3
	private function _limit_posts_by_topic(array &$sql_where, $topic_first_or_last_post)
221
	{
222 3
		$sql_where[] = $this->db->sql_in_set('p.topic_id', array_keys($this->store['topic']));
223
224
		if ($topic_first_or_last_post)
225 3
		{
226 3
			$sql_where[] = $this->db->sql_in_set('p.post_id', $this->get_topic_post_ids($topic_first_or_last_post));
227 3
		}
228 3
	}
229
230
	/**
231
	 * @return array
232
	 */
233 5
	private function _get_tracking_info()
234
	{
235 5
		$info = array();
236 5
		if ($this->_can_track_by_lastread())
237 5
		{
238 4
			$info = $this->_build_tracking_info('get_topic_tracking');
239 4
		}
240 1
		else if ($this->_can_track_anonymous())
241 1
		{
242 1
			$info = $this->_build_tracking_info('get_complete_topic_tracking');
243 1
		}
244
245 5
		return $info;
246
	}
247
248
	/**
249
	 * @param string $function
250
	 * @return array
251
	 */
252 5
	private function _build_tracking_info($function)
253
	{
254 5
		$tracking_info = array();
255 5
		foreach ($this->store['tracking'] as $fid => $forum)
256
		{
257 5
			$tracking_info[$fid] = call_user_func_array($function, array($fid, $forum['topic_list'], &$this->store['topic'], array($fid => $forum['mark_time'])));
258 5
		}
259
260 5
		return $tracking_info;
261
	}
262
263
	/**
264
	 * @return bool
265
	 */
266 5
	private function _can_track_by_lastread()
267
	{
268 5
		return ($this->config['load_db_lastread'] && $this->user->data['is_registered']) ? true : false;
269
	}
270
271
	/**
272
	 * @return bool
273
	 */
274 1
	private function _can_track_anonymous()
275
	{
276 1
		return ($this->config['load_anon_lastread'] || $this->user->data['is_registered']) ? true : false;
277
	}
278
279
	/**
280
	 * @param int $forum_id
281
	 * @return bool
282
	 */
283 7
	private function _attachments_allowed($forum_id)
284
	{
285 7
		return ($this->store['attachments'] && $this->_user_can_download_attachments($forum_id)) ? true : false;
286
	}
287
288
	/**
289
	 * @param int $forum_id
290
	 * @return bool
291
	 */
292 6
	private function _user_can_download_attachments($forum_id)
293
	{
294 6
		return ($this->auth->acl_get('u_download') && (!$forum_id || $this->auth->acl_get('f_download', $forum_id))) ? true : false;
295
	}
296
297
	/**
298
	 * @param array $allowed_extensions
299
	 * @param bool $exclude_in_message
300
	 * @param string $order_by
301
	 * @return string
302
	 */
303 6
	private function _get_attachment_sql($allowed_extensions, $exclude_in_message, $order_by)
304
	{
305
		return 'SELECT *
306 6
			FROM ' . ATTACHMENTS_TABLE . '
307 6
			WHERE ' . $this->db->sql_in_set('post_msg_id', $this->store['attachments']) .
308 6
				(($exclude_in_message) ? ' AND in_message = 0' : '') .
309 6
				(sizeof($allowed_extensions) ? ' AND ' . $this->db->sql_in_set('extension', $allowed_extensions) : '') . '
310 6
			ORDER BY ' . $order_by;
311
	}
312
}
313