1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2025-01-10 05:21:44 +01:00

99 lines
3.4 KiB
PHP
Raw Normal View History

2013-07-18 11:30:00 -04:00
<?php
require 'info.php';
function catalog_build($action, $settings, $board) {
global $config;
2013-07-18 11:30:00 -04:00
// Possible values for $action:
// - all (rebuild everything, initialization)
// - news (news has been updated)
// - boards (board list changed)
// - post (a reply has been made)
// - post-thread (a thread has been made)
2013-07-18 11:30:00 -04:00
2014-04-05 21:04:46 +00:00
if ($settings['all']) {
2014-04-23 21:59:41 +00:00
$boards = listBoards(TRUE);
2014-04-05 21:04:46 +00:00
} else {
$boards = explode(' ', $settings['boards']);
}
2014-12-03 00:10:28 -08:00
if ($action == 'all') {
foreach ($boards as $board) {
$b = new Catalog();
$b->build($settings, $board);
if (php_sapi_name() === "cli") echo "Rebuilding $board catalog...\n";
2013-07-18 11:30:00 -04:00
}
2014-12-03 00:10:28 -08:00
} elseif ($action == 'post-thread' || ($settings['update_on_posts'] && $action == 'post') || ($settings['update_on_posts'] && $action == 'post-delete') && (in_array($board, $boards) | $settings['all'])) {
2014-11-21 04:05:20 -08:00
$b = new Catalog();
2014-12-03 00:10:28 -08:00
$b->build($settings, $board);
2013-07-18 11:30:00 -04:00
}
}
// Wrap functions in a class so they don't interfere with normal Tinyboard operations
class Catalog {
2014-12-03 00:10:28 -08:00
public function build($settings, $board_name) {
2013-07-18 11:30:00 -04:00
global $config, $board;
openBoard($board_name);
2013-07-18 11:30:00 -04:00
$recent_images = array();
$recent_posts = array();
$stats = array();
$query = query(sprintf("SELECT *, `id` AS `thread_id`,
2014-08-08 22:48:38 +02:00
(SELECT COUNT(`id`) FROM ``posts_%s`` WHERE `thread` = `thread_id`) AS `reply_count`,
(SELECT SUM(`num_files`) FROM ``posts_%s`` WHERE `thread` = `thread_id` AND `num_files` IS NOT NULL) AS `image_count`,
'%s' AS `board` FROM ``posts_%s`` WHERE `thread` IS NULL ORDER BY `bump` DESC",
$board_name, $board_name, $board_name, $board_name, $board_name)) or error(db_error());
2013-07-18 11:30:00 -04:00
2013-07-31 20:51:43 -04:00
while ($post = $query->fetch(PDO::FETCH_ASSOC)) {
2013-07-18 11:30:00 -04:00
$post['link'] = $config['root'] . $board['dir'] . $config['dir']['res'] . sprintf($config['file_page'], ($post['thread'] ? $post['thread'] : $post['id']));
$post['board_name'] = $board['name'];
if ($post['embed'] && preg_match('/^https?:\/\/(\w+\.)?(?:youtube\.com\/watch\?v=|youtu\.be\/)([a-zA-Z0-9\-_]{10,11})(&.+)?$/i', $post['embed'], $matches)) {
$post['youtube'] = $matches[2];
}
if (isset($post['files']) && $post['files']) {
2014-04-27 15:48:47 +02:00
$files = json_decode($post['files']);
if ($files[0]) {
if ($files[0]->file == 'deleted') {
$post['file'] = $config['image_deleted'];
}
else if($files[0]->thumb == 'spoiler') {
$post['file'] = '/' . $config['spoiler_image'];
}
else {
$post['file'] = $config['uri_thumb'] . $files[0]->thumb;
$post['fullimage'] = $config['uri_img'] . $files[0]->file;
}
}
} else {
$post['file'] = $config['root'] . $config['no_file_image'];
}
if (empty($post['image_count'])) $post['image_count'] = 0;
2013-07-18 11:30:00 -04:00
$recent_posts[] = $post;
}
2014-08-08 22:48:38 +02:00
$required_scripts = array('js/jquery.min.js', 'js/jquery.mixitup.min.js', 'js/catalog.js');
2014-06-12 17:26:21 +00:00
foreach($required_scripts as $i => $s) {
if (!in_array($s, $config['additional_javascript']))
$config['additional_javascript'][] = $s;
}
2014-12-03 00:10:28 -08:00
file_write($config['dir']['home'] . $board_name . '/catalog.html', Element('themes/catalog/catalog.html', Array(
2013-07-18 11:30:00 -04:00
'settings' => $settings,
'config' => $config,
'boardlist' => createBoardlist(),
'recent_images' => $recent_images,
'recent_posts' => $recent_posts,
'stats' => $stats,
'board' => $board_name,
'link' => $config['root'] . $board['dir']
2014-12-03 00:10:28 -08:00
)));
2013-07-18 11:30:00 -04:00
}
};