New debug mod page: ?/debug/recent (recent posts across all boards)
This commit is contained in:
parent
060be53797
commit
d5a994537b
@ -1733,43 +1733,6 @@ function mod_config() {
|
|||||||
mod_page(_('Config editor'), 'mod/config-editor.html', array('conf' => $conf));
|
mod_page(_('Config editor'), 'mod/config-editor.html', array('conf' => $conf));
|
||||||
}
|
}
|
||||||
|
|
||||||
function mod_debug_antispam() {
|
|
||||||
global $pdo, $config;
|
|
||||||
|
|
||||||
$args = array();
|
|
||||||
|
|
||||||
if (isset($_POST['board'], $_POST['thread'])) {
|
|
||||||
$where = '`board` = ' . $pdo->quote($_POST['board']);
|
|
||||||
if ($_POST['thread'] != '')
|
|
||||||
$where .= ' AND `thread` = ' . $pdo->quote($_POST['thread']);
|
|
||||||
|
|
||||||
if (isset($_POST['purge'])) {
|
|
||||||
$query = prepare('UPDATE `antispam` SET `expires` = UNIX_TIMESTAMP() + :expires WHERE' . $where);
|
|
||||||
$query->bindValue(':expires', $config['spam']['hidden_inputs_expire']);
|
|
||||||
$query->execute() or error(db_error());
|
|
||||||
}
|
|
||||||
|
|
||||||
$args['board'] = $_POST['board'];
|
|
||||||
$args['thread'] = $_POST['thread'];
|
|
||||||
} else {
|
|
||||||
$where = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
$query = query('SELECT COUNT(*) FROM `antispam`' . ($where ? " WHERE $where" : '')) or error(db_error());
|
|
||||||
$args['total'] = number_format($query->fetchColumn(0));
|
|
||||||
|
|
||||||
$query = query('SELECT COUNT(*) FROM `antispam` WHERE `expires` IS NOT NULL' . ($where ? " AND $where" : '')) or error(db_error());
|
|
||||||
$args['expiring'] = number_format($query->fetchColumn(0));
|
|
||||||
|
|
||||||
$query = query('SELECT * FROM `antispam` ' . ($where ? "WHERE $where" : '') . ' ORDER BY `passed` DESC LIMIT 40') or error(db_error());
|
|
||||||
$args['top'] = $query->fetchAll(PDO::FETCH_ASSOC);
|
|
||||||
|
|
||||||
$query = query('SELECT * FROM `antispam` ' . ($where ? "WHERE $where" : '') . ' ORDER BY `created` DESC LIMIT 20') or error(db_error());
|
|
||||||
$args['recent'] = $query->fetchAll(PDO::FETCH_ASSOC);
|
|
||||||
|
|
||||||
mod_page(_('Debug: Anti-spam'), 'mod/debug/antispam.html', $args);
|
|
||||||
}
|
|
||||||
|
|
||||||
function mod_themes_list() {
|
function mod_themes_list() {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
@ -1897,3 +1860,65 @@ function mod_theme_rebuild($theme_name) {
|
|||||||
'theme_name' => $theme_name,
|
'theme_name' => $theme_name,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function mod_debug_antispam() {
|
||||||
|
global $pdo, $config;
|
||||||
|
|
||||||
|
$args = array();
|
||||||
|
|
||||||
|
if (isset($_POST['board'], $_POST['thread'])) {
|
||||||
|
$where = '`board` = ' . $pdo->quote($_POST['board']);
|
||||||
|
if ($_POST['thread'] != '')
|
||||||
|
$where .= ' AND `thread` = ' . $pdo->quote($_POST['thread']);
|
||||||
|
|
||||||
|
if (isset($_POST['purge'])) {
|
||||||
|
$query = prepare('UPDATE `antispam` SET `expires` = UNIX_TIMESTAMP() + :expires WHERE' . $where);
|
||||||
|
$query->bindValue(':expires', $config['spam']['hidden_inputs_expire']);
|
||||||
|
$query->execute() or error(db_error());
|
||||||
|
}
|
||||||
|
|
||||||
|
$args['board'] = $_POST['board'];
|
||||||
|
$args['thread'] = $_POST['thread'];
|
||||||
|
} else {
|
||||||
|
$where = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = query('SELECT COUNT(*) FROM `antispam`' . ($where ? " WHERE $where" : '')) or error(db_error());
|
||||||
|
$args['total'] = number_format($query->fetchColumn(0));
|
||||||
|
|
||||||
|
$query = query('SELECT COUNT(*) FROM `antispam` WHERE `expires` IS NOT NULL' . ($where ? " AND $where" : '')) or error(db_error());
|
||||||
|
$args['expiring'] = number_format($query->fetchColumn(0));
|
||||||
|
|
||||||
|
$query = query('SELECT * FROM `antispam` ' . ($where ? "WHERE $where" : '') . ' ORDER BY `passed` DESC LIMIT 40') or error(db_error());
|
||||||
|
$args['top'] = $query->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
|
||||||
|
$query = query('SELECT * FROM `antispam` ' . ($where ? "WHERE $where" : '') . ' ORDER BY `created` DESC LIMIT 20') or error(db_error());
|
||||||
|
$args['recent'] = $query->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
|
||||||
|
mod_page(_('Debug: Anti-spam'), 'mod/debug/antispam.html', $args);
|
||||||
|
}
|
||||||
|
|
||||||
|
function mod_debug_recent_posts() {
|
||||||
|
global $pdo, $config;
|
||||||
|
|
||||||
|
$limit = 150;
|
||||||
|
|
||||||
|
$boards = listBoards();
|
||||||
|
|
||||||
|
// Manually build an SQL query
|
||||||
|
$query = 'SELECT * FROM (';
|
||||||
|
foreach ($boards as $board) {
|
||||||
|
$query .= sprintf('SELECT *, %s AS `board` FROM `posts_%s` UNION ALL ', $pdo->quote($board['uri']), $board['uri']);
|
||||||
|
}
|
||||||
|
// Remove the last "UNION ALL" seperator and complete the query
|
||||||
|
$query = preg_replace('/UNION ALL $/', ') AS `all_posts` ORDER BY `time` DESC LIMIT ' . $limit, $query);
|
||||||
|
$query = query($query) or error(db_error());
|
||||||
|
$posts = $query->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
|
||||||
|
foreach ($posts as &$post) {
|
||||||
|
$post['snippet'] = pm_snippet($post['body']);
|
||||||
|
}
|
||||||
|
|
||||||
|
mod_page(_('Debug: Recent posts'), 'mod/debug/recent_posts.html', array('posts' => $posts));
|
||||||
|
}
|
||||||
|
|
||||||
|
1
mod.php
1
mod.php
@ -78,6 +78,7 @@ $pages = array(
|
|||||||
|
|
||||||
// these pages aren't listed in the dashboard without $config['debug']
|
// these pages aren't listed in the dashboard without $config['debug']
|
||||||
'/debug/antispam' => 'debug_antispam',
|
'/debug/antispam' => 'debug_antispam',
|
||||||
|
'/debug/recent' => 'debug_recent_posts',
|
||||||
|
|
||||||
// This should always be at the end:
|
// This should always be at the end:
|
||||||
'/(\w+)/' => 'view_board',
|
'/(\w+)/' => 'view_board',
|
||||||
|
81
templates/mod/debug/recent_posts.html
Normal file
81
templates/mod/debug/recent_posts.html
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
<table class="modlog">
|
||||||
|
<tr>
|
||||||
|
<th>Time</th>
|
||||||
|
<th>Board</th>
|
||||||
|
<th>ID</th>
|
||||||
|
<th>Thread</th>
|
||||||
|
<th>IP</th>
|
||||||
|
<th>Name</th>
|
||||||
|
<th>Subject</th>
|
||||||
|
<th>File</th>
|
||||||
|
<th>Body (snippet)</th>
|
||||||
|
</tr>
|
||||||
|
{% for post in posts %}
|
||||||
|
<tr>
|
||||||
|
<td class="minimal">
|
||||||
|
{{ post.time | ago }} ago
|
||||||
|
</td>
|
||||||
|
<td class="minimal">
|
||||||
|
<a href="?/{{ config.board_path|sprintf(post.board) }}{{ config.file_index }}">{{ config.board_abbreviation|sprintf(post.board) }}</a>
|
||||||
|
</td>
|
||||||
|
<td class="minimal" >
|
||||||
|
{% if post.thread %}
|
||||||
|
{% set thread = post.thread %}
|
||||||
|
{% else %}
|
||||||
|
{% set thread = post.id %}
|
||||||
|
{% endif %}
|
||||||
|
<a href="{{ config.root ~ post.board ~ '/' ~ config.dir.res}}{{ config.file_page|sprintf(thread) }}#{{ post.id }}">
|
||||||
|
{{ post.id }}
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
|
<td class="minimal">
|
||||||
|
{% if post.thread %}
|
||||||
|
{{ post.thread }}
|
||||||
|
{% else %}
|
||||||
|
<small>(OP)</small>
|
||||||
|
{% endif %}
|
||||||
|
</td>
|
||||||
|
<td class="minimal">
|
||||||
|
<a href="?/IP/{{ post.ip }}">
|
||||||
|
{{ post.ip }}
|
||||||
|
</a>
|
||||||
|
</td>
|
||||||
|
<td class="minimal" >
|
||||||
|
{% if post.email|length > 0 %}
|
||||||
|
{# start email #}
|
||||||
|
<a class="email" href="mailto:{{ post.email }}">
|
||||||
|
{% endif %}
|
||||||
|
{% set capcode = post.capcode|capcode %}
|
||||||
|
<span {% if capcode.name %}style="{{ capcode.name }}" {% endif %}class="name">{{ post.name }}</span>
|
||||||
|
{% if post.trip|length > 0 %}
|
||||||
|
<span {% if capcode.trip %}style="{{ capcode.trip }}" {% endif %}class="trip">{{ post.trip }}</span>
|
||||||
|
{% endif %}
|
||||||
|
{% if post.email|length > 0 %}
|
||||||
|
{# end email #}
|
||||||
|
</a>
|
||||||
|
{% endif %}
|
||||||
|
{% if capcode %}
|
||||||
|
{{ capcode.cap }}
|
||||||
|
{% endif %}
|
||||||
|
</td>
|
||||||
|
<td class="minimal" >
|
||||||
|
{% if post.subject %}
|
||||||
|
{{ post.subject }}
|
||||||
|
{% else %}
|
||||||
|
–
|
||||||
|
{% endif %}
|
||||||
|
</td>
|
||||||
|
<td class="minimal">
|
||||||
|
{% if post.file %}
|
||||||
|
{{ post.file }} <small>({{ post.filesize | filesize }})</small>
|
||||||
|
{% else %}
|
||||||
|
–
|
||||||
|
{% endif %}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<em>{{ post.snippet }}</em>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</table>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user