|
|
@@ -16,52 +16,91 @@ |
|
|
|
// Wrap functions in a class so they don't interfere with normal Tinyboard operations |
|
|
|
class RSSRecentPosts { |
|
|
|
public function build($action, $settings) { |
|
|
|
global $config, $_theme; |
|
|
|
global $config, $_theme,$board; |
|
|
|
|
|
|
|
/*if ($action == 'all') { |
|
|
|
copy('templates/themes/recent/' . $settings['basecss'], $config['dir']['home'] . $settings['css']); |
|
|
|
}*/ |
|
|
|
|
|
|
|
$this->excluded = explode(' ', $settings['exclude']); |
|
|
|
|
|
|
|
if ($action == 'all' || $action == 'post' || $action == 'post-thread' || $action == 'post-delete') |
|
|
|
file_write($config['dir']['home'] . $settings['xml'], $this->homepage($settings)); |
|
|
|
if ($settings['show_threads_only'] == 'true'){ |
|
|
|
if ($action == 'all' || $action == 'post-thread' || $action == 'post-delete') |
|
|
|
file_write($config['dir']['home'] . $settings['xml'], $this->site_rsspage($settings)); |
|
|
|
} |
|
|
|
else { |
|
|
|
if ($action == 'all' || $action == 'post' || $action == 'post-thread' || $action == 'post-delete') |
|
|
|
file_write($config['dir']['home'] . $settings['xml'], $this->site_rsspage($settings)); |
|
|
|
} |
|
|
|
|
|
|
|
if ($settings['enable_per_board'] == 'true'){ |
|
|
|
$boards = listBoards(); |
|
|
|
foreach ($boards as &$_board) { |
|
|
|
if (in_array($_board['uri'], $this->excluded)) |
|
|
|
continue; |
|
|
|
|
|
|
|
openBoard($_board['uri']); |
|
|
|
if ($settings['show_threads_only'] == 'true'){ |
|
|
|
if ($action == 'all' || $action == 'post-thread' || $action == 'post-delete') |
|
|
|
file_write($config['dir']['home'] . 'debug.xml', $board['dir']); |
|
|
|
file_write($config['dir']['home'] . $board['dir'] . $settings['xml'], $this->board_rsspage($settings,$_board)); |
|
|
|
} |
|
|
|
else { |
|
|
|
if ($action == 'all' || $action == 'post' || $action == 'post-thread' || $action == 'post-delete') |
|
|
|
file_write($config['dir']['home'] . $board['dir'] . $settings['xml'], $this->board_rsspage($settings,$_board)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
// Build news page |
|
|
|
public function homepage($settings) { |
|
|
|
public function site_rsspage($settings) { |
|
|
|
global $config, $board; |
|
|
|
|
|
|
|
//$recent_images = Array(); |
|
|
|
$recent_posts = Array(); |
|
|
|
//$stats = Array(); |
|
|
|
|
|
|
|
$boards = listBoards(); |
|
|
|
|
|
|
|
/*$query = ''; |
|
|
|
$query = ''; |
|
|
|
foreach ($boards as &$_board) { |
|
|
|
if (in_array($_board['uri'], $this->excluded)) |
|
|
|
continue; |
|
|
|
$query .= sprintf("SELECT *, '%s' AS `board` FROM ``posts_%s`` WHERE `file` IS NOT NULL AND `file` != 'deleted' AND `thumb` != 'spoiler' UNION ALL ", $_board['uri'], $_board['uri']); |
|
|
|
if ($settings['show_threads_only'] == 'true'){ |
|
|
|
$query .= sprintf("SELECT *, '%s' AS `board` FROM ``posts_%s`` WHERE `thread` is null UNION ALL ", $_board['uri'], $_board['uri']); |
|
|
|
} |
|
|
|
else { |
|
|
|
$query .= sprintf("SELECT *, '%s' AS `board` FROM ``posts_%s`` UNION ALL ", $_board['uri'], $_board['uri']); |
|
|
|
} |
|
|
|
} |
|
|
|
$query = preg_replace('/UNION ALL $/', 'ORDER BY `time` DESC LIMIT ' . (int)$settings['limit_images'], $query); |
|
|
|
$query = preg_replace('/UNION ALL $/', 'ORDER BY `time` DESC LIMIT ' . (int)$settings['limit_posts'], $query); |
|
|
|
$query = query($query) or error(db_error()); |
|
|
|
|
|
|
|
while ($post = $query->fetch(PDO::FETCH_ASSOC)) { |
|
|
|
openBoard($post['board']); |
|
|
|
|
|
|
|
// board settings won't be available in the template file, so generate links now |
|
|
|
$post['link'] = $config['root'] . $board['dir'] . $config['dir']['res'] . sprintf($config['file_page'], ($post['thread'] ? $post['thread'] : $post['id'])) . '#' . $post['id']; |
|
|
|
$post['src'] = $config['uri_thumb'] . $post['thumb']; |
|
|
|
$post['snippet'] = pm_snippet($post['body'], 30); |
|
|
|
$post['board_name'] = $board['name']; |
|
|
|
|
|
|
|
//$recent_images[] = $post; |
|
|
|
}*/ |
|
|
|
$recent_posts[] = $post; |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return Element('themes/rss/rss.xml', Array( |
|
|
|
'settings' => $settings, |
|
|
|
'config' => $config, |
|
|
|
'recent_posts' => $recent_posts, |
|
|
|
)); |
|
|
|
} |
|
|
|
|
|
|
|
// Build news page |
|
|
|
public function board_rsspage($settings,$_board) { |
|
|
|
global $config, $board; |
|
|
|
|
|
|
|
$recent_posts = Array(); |
|
|
|
|
|
|
|
$query = ''; |
|
|
|
foreach ($boards as &$_board) { |
|
|
|
if (in_array($_board['uri'], $this->excluded)) |
|
|
|
continue; |
|
|
|
if ($settings['show_threads_only'] == 'true'){ |
|
|
|
$query .= sprintf("SELECT *, '%s' AS `board` FROM ``posts_%s`` WHERE `thread` is null UNION ALL ", $_board['uri'], $_board['uri']); |
|
|
|
} |
|
|
|
else { |
|
|
|
$query .= sprintf("SELECT *, '%s' AS `board` FROM ``posts_%s`` UNION ALL ", $_board['uri'], $_board['uri']); |
|
|
|
} |
|
|
|
$query = preg_replace('/UNION ALL $/', 'ORDER BY `time` DESC LIMIT ' . (int)$settings['limit_posts'], $query); |
|
|
@@ -77,46 +116,11 @@ |
|
|
|
$recent_posts[] = $post; |
|
|
|
} |
|
|
|
|
|
|
|
// Total posts |
|
|
|
/*$query = 'SELECT SUM(`top`) FROM ('; |
|
|
|
foreach ($boards as &$_board) { |
|
|
|
if (in_array($_board['uri'], $this->excluded)) |
|
|
|
continue; |
|
|
|
$query .= sprintf("SELECT MAX(`id`) AS `top` FROM ``posts_%s`` UNION ALL ", $_board['uri']); |
|
|
|
} |
|
|
|
$query = preg_replace('/UNION ALL $/', ') AS `posts_all`', $query); |
|
|
|
$query = query($query) or error(db_error());*/ |
|
|
|
//$stats['total_posts'] = number_format($query->fetchColumn()); |
|
|
|
|
|
|
|
// Unique IPs |
|
|
|
/*$query = 'SELECT COUNT(DISTINCT(`ip`)) FROM ('; |
|
|
|
foreach ($boards as &$_board) { |
|
|
|
if (in_array($_board['uri'], $this->excluded)) |
|
|
|
continue; |
|
|
|
$query .= sprintf("SELECT `ip` FROM ``posts_%s`` UNION ALL ", $_board['uri']); |
|
|
|
} |
|
|
|
$query = preg_replace('/UNION ALL $/', ') AS `posts_all`', $query); |
|
|
|
$query = query($query) or error(db_error()); |
|
|
|
//$stats['unique_posters'] = number_format($query->fetchColumn());*/ |
|
|
|
|
|
|
|
// Active content |
|
|
|
/*$query = 'SELECT SUM(`filesize`) FROM ('; |
|
|
|
foreach ($boards as &$_board) { |
|
|
|
if (in_array($_board['uri'], $this->excluded)) |
|
|
|
continue; |
|
|
|
$query .= sprintf("SELECT `filesize` FROM ``posts_%s`` UNION ALL ", $_board['uri']); |
|
|
|
} |
|
|
|
$query = preg_replace('/UNION ALL $/', ') AS `posts_all`', $query); |
|
|
|
$query = query($query) or error(db_error()); |
|
|
|
//$stats['active_content'] = $query->fetchColumn();*/ |
|
|
|
|
|
|
|
return Element('themes/rss/rss.xml', Array( |
|
|
|
'settings' => $settings, |
|
|
|
'config' => $config, |
|
|
|
//'boardlist' => createBoardlist(), |
|
|
|
//'recent_images' => $recent_images, |
|
|
|
'recent_posts' => $recent_posts, |
|
|
|
//'stats' => $stats |
|
|
|
)); |
|
|
|
} |
|
|
|
}; |
|
|
|