2010-12-01 21:53:11 +11:00
|
|
|
<?php
|
2012-04-12 02:49:22 +10:00
|
|
|
|
|
|
|
/*
|
2014-04-12 11:12:42 -07:00
|
|
|
* Copyright (c) 2010-2014 Tinyboard Development Group
|
2012-04-12 02:49:22 +10:00
|
|
|
*/
|
|
|
|
|
|
|
|
require 'inc/functions.php';
|
2012-04-13 02:11:41 +10:00
|
|
|
require 'inc/mod/pages.php';
|
2012-04-12 02:49:22 +10:00
|
|
|
|
2014-12-31 22:35:21 -08:00
|
|
|
check_login(true);
|
2012-04-12 02:49:22 +10:00
|
|
|
|
2013-08-04 22:49:38 -04:00
|
|
|
$query = isset($_SERVER['QUERY_STRING']) ? rawurldecode($_SERVER['QUERY_STRING']) : '';
|
2012-04-12 02:49:22 +10:00
|
|
|
|
2012-04-13 02:11:41 +10:00
|
|
|
$pages = array(
|
2013-09-23 16:48:56 +10:00
|
|
|
'' => ':?/', // redirect to dashboard
|
|
|
|
'/' => 'dashboard', // dashboard
|
|
|
|
'/confirm/(.+)' => 'confirm', // confirm action (if javascript didn't work)
|
|
|
|
'/logout' => 'secure logout', // logout
|
2012-04-16 16:40:24 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/users' => 'users', // manage users
|
|
|
|
'/users/(\d+)/(promote|demote)' => 'secure user_promote', // prmote/demote user
|
|
|
|
'/users/(\d+)' => 'secure_POST user', // edit user
|
|
|
|
'/users/new' => 'secure_POST user_new', // create a new user
|
2012-04-13 10:41:30 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/new_PM/([^/]+)' => 'secure_POST new_pm', // create a new pm
|
|
|
|
'/PM/(\d+)(/reply)?' => 'pm', // read a pm
|
|
|
|
'/inbox' => 'inbox', // pm inbox
|
2012-05-06 01:33:10 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/log' => 'log', // modlog
|
|
|
|
'/log/(\d+)' => 'log', // modlog
|
2015-02-16 16:28:22 -08:00
|
|
|
'/log:([^/:]+)' => 'user_log', // modlog
|
|
|
|
'/log:([^/:]+)/(\d+)' => 'user_log', // modlog
|
|
|
|
'/log:b:([^/]+)' => 'board_log', // modlog
|
|
|
|
'/log:b:([^/]+)/(\d+)' => 'board_log', // modlog
|
2014-12-14 03:27:26 -08:00
|
|
|
'/edit_news' => 'secure_POST news', // view news
|
|
|
|
'/edit_news/(\d+)' => 'secure_POST news', // view news
|
|
|
|
'/edit_news/delete/(\d+)' => 'secure news_delete', // delete from news
|
2015-03-29 09:18:14 +08:00
|
|
|
|
|
|
|
'/edit_pages(?:/?(\%b)?)' => 'secure_POST pages',
|
|
|
|
'/edit_page/(\d+)' => 'secure_POST edit_page',
|
|
|
|
'/edit_pages/delete/([a-z0-9]+)' => 'secure delete_page',
|
|
|
|
'/edit_pages/delete/([a-z0-9]+)/(\%b)' => 'secure delete_page_board',
|
2012-05-06 01:33:10 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/noticeboard' => 'secure_POST noticeboard', // view noticeboard
|
|
|
|
'/noticeboard/(\d+)' => 'secure_POST noticeboard', // view noticeboard
|
|
|
|
'/noticeboard/delete/(\d+)' => 'secure noticeboard_delete', // delete from noticeboard
|
2012-04-14 22:28:21 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/edit/(\%b)' => 'secure_POST edit_board', // edit board details
|
|
|
|
'/new-board' => 'secure_POST new_board', // create a new board
|
|
|
|
|
2014-10-19 00:07:16 -05:00
|
|
|
'/rebuild' => 'secure_POST rebuild', // rebuild static files
|
2014-10-19 11:07:07 -05:00
|
|
|
|
|
|
|
// Report management
|
|
|
|
// (global) denotes if the action is being carried out from the global dashboard,
|
|
|
|
// and if the return address should also be the global dashboard.
|
|
|
|
// Important to note that (?:global) will make no argument.
|
|
|
|
// (global)? will make argument 0 either "global" or "".
|
2014-10-21 07:50:25 -05:00
|
|
|
'/reports(?:/)?' => 'reports', // report queue
|
2015-03-30 07:13:57 +08:00
|
|
|
'/reports/(global)?(?:/)?(json)?' => 'reports', // global report queue
|
2014-10-21 07:50:25 -05:00
|
|
|
'/reports/(global)?(?:/)?(content)/(\%b)/(\d+)(?:/)?' => 'reports', // specific reported content (also historic)
|
|
|
|
'/reports/(global)?(?:/)?(content)/(\%b)/(\d+)/dismiss(?:/)?' => 'secure report_dismiss', // dismiss all reports on content
|
|
|
|
'/reports/(global)?(?:/)?(content)/(\%b)/(\d+)/demote(?:/)?' => 'secure report_demote', // demote all reports on content
|
|
|
|
'/reports/(global)?(?:/)?(content)/(\%b)/(\d+)/promote(?:/)?' => 'secure report_promote', // demote all reports on content
|
|
|
|
'/reports/(global)?(?:/)?(\d+)/dismiss(all)?(?:/)?' => 'secure report_dismiss', // dismiss a report
|
|
|
|
'/reports/(global)?(?:/)?(\d+)/demote(?:/)?' => 'secure report_demote', // demote a global report to a local report
|
|
|
|
'/reports/(global)?(?:/)?(\d+)/promote(?:/)?' => 'secure report_promote', // promote a local report to a global report
|
|
|
|
'/reports/(global)?(?:/)?(\%b)/(un)?clean/(\d+)/(global)?(?:\+)?(local)?' => 'secure report_clean', // protect/unprotect from reports
|
2013-09-23 16:48:56 +10:00
|
|
|
|
|
|
|
'/IP/([\w.:]+)' => 'secure_POST ip', // view ip address
|
|
|
|
'/IP/([\w.:]+)/remove_note/(\d+)' => 'secure ip_remove_note', // remove note from ip address
|
2014-10-09 21:39:37 -04:00
|
|
|
'/IP_less/(\%b)/(\d+)' => 'secure_POST ip_less', // view ip address (limited for user privacy)
|
|
|
|
'/IP_less/([\w.:]+)/remove_note/(\d+)' => 'secure ip_remove_note', // remove note from ip address
|
2013-07-20 07:50:33 -04:00
|
|
|
|
2013-08-03 21:04:45 -04:00
|
|
|
'/ban' => 'secure_POST ban', // new ban
|
2013-09-23 16:48:56 +10:00
|
|
|
'/bans' => 'secure_POST bans', // ban list
|
2014-10-08 23:23:59 +02:00
|
|
|
'/bans.json' => 'secure bans_json', // ban list JSON
|
2013-09-23 16:48:56 +10:00
|
|
|
'/ban-appeals' => 'secure_POST ban_appeals', // view ban appeals
|
|
|
|
|
2014-03-17 19:11:16 -03:00
|
|
|
'/recent/(\d+)' => 'recent_posts', // view recent posts
|
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/search' => 'search_redirect', // search
|
|
|
|
'/search/(posts|IP_notes|bans|log)/(.+)/(\d+)' => 'search', // search
|
|
|
|
'/search/(posts|IP_notes|bans|log)/(.+)' => 'search', // search
|
2014-10-20 10:17:19 -05:00
|
|
|
|
|
|
|
// Content management
|
|
|
|
'/(\%b)/ban(&delete)?/(\d+)' => 'secure_POST ban_post', // ban poster
|
|
|
|
'/(\%b)/move/(\d+)' => 'secure_POST move', // move thread
|
|
|
|
'/(\%b)/move_reply/(\d+)' => 'secure_POST move_reply', // move reply
|
|
|
|
'/(\%b)/edit(_raw)?/(\d+)' => 'secure_POST edit_post', // edit post
|
|
|
|
'/(\%b)/delete/(\d+)' => 'secure delete', // delete post
|
|
|
|
'/(\%b)/deletefile/(\d+)/(\d+)' => 'secure deletefile', // delete file from post
|
|
|
|
'/(\%b+)/spoiler/(\d+)/(\d+)' => 'secure spoiler_image', // spoiler file
|
2014-12-19 06:42:14 -06:00
|
|
|
'/(\%b+)/spoiler_all/(\d+)' => 'secure spoiler_images', // spoiler file
|
2014-10-20 10:17:19 -05:00
|
|
|
'/(\%b)/deletebyip/(\d+)(/global)?' => 'secure deletebyip', // delete all posts by IP address
|
|
|
|
'/(\%b)/(un)?lock/(\d+)' => 'secure lock', // lock thread
|
|
|
|
'/(\%b)/(un)?sticky/(\d+)' => 'secure sticky', // sticky thread
|
2015-04-03 14:56:28 +08:00
|
|
|
'/(\%b)/(un)?cycle/(\d+)' => 'secure cycle', // cycle thread
|
2014-10-20 10:17:19 -05:00
|
|
|
'/(\%b)/bump(un)?lock/(\d+)' => 'secure bumplock', // "bumplock" thread
|
2012-04-16 20:11:10 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/themes' => 'themes_list', // manage themes
|
|
|
|
'/themes/(\w+)' => 'secure_POST theme_configure', // configure/reconfigure theme
|
|
|
|
'/themes/(\w+)/rebuild' => 'secure theme_rebuild', // rebuild theme
|
|
|
|
'/themes/(\w+)/uninstall' => 'secure theme_uninstall', // uninstall theme
|
2012-08-13 00:18:13 +10:00
|
|
|
|
2013-09-23 16:48:56 +10:00
|
|
|
'/config' => 'secure_POST config', // config editor
|
|
|
|
'/config/(\%b)' => 'secure_POST config', // config editor
|
2017-04-08 01:03:15 +09:00
|
|
|
|
2012-04-13 02:11:41 +10:00
|
|
|
// This should always be at the end:
|
2014-06-10 23:46:28 +00:00
|
|
|
'/(\%b)/?' => 'view_board',
|
2013-07-31 02:08:55 -04:00
|
|
|
'/(\%b)/' . preg_quote($config['file_index'], '!') => 'view_board',
|
|
|
|
'/(\%b)/' . str_replace('%d', '(\d+)', preg_quote($config['file_page'], '!')) => 'view_board',
|
2013-08-10 17:16:30 -04:00
|
|
|
'/(\%b)/' . preg_quote($config['dir']['res'], '!') .
|
|
|
|
str_replace('%d', '(\d+)', preg_quote($config['file_page50'], '!')) => 'view_thread50',
|
2013-07-31 02:08:55 -04:00
|
|
|
'/(\%b)/' . preg_quote($config['dir']['res'], '!') .
|
2012-05-06 12:44:37 +10:00
|
|
|
str_replace('%d', '(\d+)', preg_quote($config['file_page'], '!')) => 'view_thread',
|
2012-04-13 02:11:41 +10:00
|
|
|
);
|
|
|
|
|
2012-05-06 01:33:10 +10:00
|
|
|
|
|
|
|
if (!$mod) {
|
2013-01-29 22:11:33 +11:00
|
|
|
$pages = array('!^(.+)?$!' => 'login');
|
2012-05-06 01:33:10 +10:00
|
|
|
} elseif (isset($_GET['status'], $_GET['r'])) {
|
2012-05-06 12:29:54 +10:00
|
|
|
header('Location: ' . $_GET['r'], true, (int)$_GET['status']);
|
2012-05-06 12:44:37 +10:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($config['mod']['custom_pages'])) {
|
2012-05-06 01:33:10 +10:00
|
|
|
$pages = array_merge($pages, $config['mod']['custom_pages']);
|
|
|
|
}
|
2012-04-13 02:11:41 +10:00
|
|
|
|
2012-05-06 12:44:37 +10:00
|
|
|
$new_pages = array();
|
|
|
|
foreach ($pages as $key => $callback) {
|
2013-07-15 08:17:49 -04:00
|
|
|
if (is_string($callback) && preg_match('/^secure /', $callback))
|
2012-08-27 15:19:05 +10:00
|
|
|
$key .= '(/(?P<token>[a-f0-9]{8}))?';
|
2013-08-02 20:52:58 -04:00
|
|
|
$key = str_replace('\%b', '?P<board>' . sprintf(substr($config['board_path'], 0, -1), $config['board_regex']), $key);
|
2013-07-31 02:08:55 -04:00
|
|
|
$new_pages[@$key[0] == '!' ? $key : '!^' . $key . '(?:&[^&=]+=[^&]*)*$!u'] = $callback;
|
2012-05-06 12:44:37 +10:00
|
|
|
}
|
|
|
|
$pages = $new_pages;
|
|
|
|
|
2015-03-27 18:49:17 +08:00
|
|
|
$parse_start_time = microtime(true);
|
|
|
|
|
2012-04-13 02:11:41 +10:00
|
|
|
foreach ($pages as $uri => $handler) {
|
|
|
|
if (preg_match($uri, $query, $matches)) {
|
|
|
|
$matches = array_slice($matches, 1);
|
|
|
|
|
2013-08-02 20:52:58 -04:00
|
|
|
if (isset($matches['board'])) {
|
|
|
|
$board_match = $matches['board'];
|
|
|
|
unset($matches['board']);
|
|
|
|
$key = array_search($board_match, $matches);
|
|
|
|
if (preg_match('/^' . sprintf(substr($config['board_path'], 0, -1), '(' . $config['board_regex'] . ')') . '$/u', $matches[$key], $board_match)) {
|
|
|
|
$matches[$key] = $board_match[1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-15 08:17:49 -04:00
|
|
|
if (is_string($handler) && preg_match('/^secure(_POST)? /', $handler, $m)) {
|
2012-08-27 15:19:05 +10:00
|
|
|
$secure_post_only = isset($m[1]);
|
|
|
|
if (!$secure_post_only || $_SERVER['REQUEST_METHOD'] == 'POST') {
|
|
|
|
$token = isset($matches['token']) ? $matches['token'] : (isset($_POST['token']) ? $_POST['token'] : false);
|
|
|
|
|
|
|
|
if ($token === false) {
|
|
|
|
if ($secure_post_only)
|
|
|
|
error($config['error']['csrf']);
|
|
|
|
else {
|
|
|
|
mod_confirm(substr($query, 1));
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// CSRF-protected page; validate security token
|
|
|
|
$actual_query = preg_replace('!/([a-f0-9]{8})$!', '', $query);
|
|
|
|
if ($token != make_secure_link_token(substr($actual_query, 1))) {
|
|
|
|
error($config['error']['csrf']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$handler = preg_replace('/^secure(_POST)? /', '', $handler);
|
|
|
|
}
|
|
|
|
|
2012-04-13 02:11:41 +10:00
|
|
|
if ($config['debug']) {
|
|
|
|
$debug['mod_page'] = array(
|
|
|
|
'req' => $query,
|
|
|
|
'match' => $uri,
|
2013-08-30 08:39:11 +10:00
|
|
|
'handler' => $handler,
|
2012-04-12 02:49:22 +10:00
|
|
|
);
|
2013-08-30 08:39:11 +10:00
|
|
|
$debug['time']['parse_mod_req'] = '~' . round((microtime(true) - $parse_start_time) * 1000, 2) . 'ms';
|
2012-04-12 02:49:22 +10:00
|
|
|
}
|
|
|
|
|
2012-05-06 01:33:10 +10:00
|
|
|
if (is_string($handler)) {
|
|
|
|
if ($handler[0] == ':') {
|
|
|
|
header('Location: ' . substr($handler, 1), true, $config['redirect_http']);
|
|
|
|
} elseif (is_callable("mod_page_$handler")) {
|
|
|
|
call_user_func_array("mod_page_$handler", $matches);
|
|
|
|
} elseif (is_callable("mod_$handler")) {
|
|
|
|
call_user_func_array("mod_$handler", $matches);
|
|
|
|
} else {
|
|
|
|
error("Mod page '$handler' not found!");
|
|
|
|
}
|
|
|
|
} elseif (is_callable($handler)) {
|
|
|
|
call_user_func_array($handler, $matches);
|
2012-04-12 02:49:22 +10:00
|
|
|
} else {
|
2012-05-06 01:33:10 +10:00
|
|
|
error("Mod page '$handler' not a string, and not callable!");
|
2012-04-12 02:49:22 +10:00
|
|
|
}
|
|
|
|
|
2012-04-13 02:11:41 +10:00
|
|
|
exit;
|
2010-12-01 21:53:11 +11:00
|
|
|
}
|
2012-04-12 02:49:22 +10:00
|
|
|
}
|
2011-11-16 18:53:37 +11:00
|
|
|
|
2012-04-13 02:11:41 +10:00
|
|
|
error($config['error']['404']);
|
|
|
|
|