Basic search function for mods
This commit is contained in:
parent
80955172e9
commit
b2ae5fdcba
@ -250,6 +250,8 @@
|
|||||||
$config['mod']['recent_reports'] = 5;
|
$config['mod']['recent_reports'] = 5;
|
||||||
// How many actions to show per page in the moderation log
|
// How many actions to show per page in the moderation log
|
||||||
$config['mod']['modlog_page'] = 350;
|
$config['mod']['modlog_page'] = 350;
|
||||||
|
// Maximum number of results to display for a search, per board
|
||||||
|
$config['mod']['search_results'] = 75;
|
||||||
|
|
||||||
// Probably best not to change these:
|
// Probably best not to change these:
|
||||||
if(!defined('JANITOR')) {
|
if(!defined('JANITOR')) {
|
||||||
@ -333,6 +335,8 @@
|
|||||||
$config['mod']['create_pm'] = JANITOR;
|
$config['mod']['create_pm'] = JANITOR;
|
||||||
// Rebuild everything
|
// Rebuild everything
|
||||||
$config['mod']['rebuild'] = ADMIN;
|
$config['mod']['rebuild'] = ADMIN;
|
||||||
|
// Search through posts
|
||||||
|
$config['mod']['search'] = JANITOR;
|
||||||
|
|
||||||
// Wait indefinitely when rebuilding everything
|
// Wait indefinitely when rebuilding everything
|
||||||
$config['mod']['rebuild_timelimit'] = 0;
|
$config['mod']['rebuild_timelimit'] = 0;
|
||||||
|
73
mod.php
73
mod.php
@ -79,6 +79,7 @@
|
|||||||
$fieldset = Array(
|
$fieldset = Array(
|
||||||
'Boards' => '',
|
'Boards' => '',
|
||||||
'Administration' => '',
|
'Administration' => '',
|
||||||
|
'Search' => '',
|
||||||
'Logout' => ''
|
'Logout' => ''
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -104,6 +105,16 @@
|
|||||||
$fieldset['Administration'] .= '<li><a href="?/config">Show configuration</a></li>';
|
$fieldset['Administration'] .= '<li><a href="?/config">Show configuration</a></li>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($mod['type'] >= $config['mod']['search']) {
|
||||||
|
$fieldset['Search'] .= '<li><form style="display:inline" action="?/search" method="post">' .
|
||||||
|
'<label style="display:inline" for="search">Phrase:</label> ' .
|
||||||
|
'<input id="search" name="search" type="text" size="35" />' .
|
||||||
|
'<input type="submit" value="Search" />' .
|
||||||
|
'</form>' .
|
||||||
|
'<p class="unimportant">(Search is case-insensitive but not based on keywords.)</p>' .
|
||||||
|
'</li>';
|
||||||
|
}
|
||||||
|
|
||||||
$fieldset['Logout'] .= '<li><a href="?/logout">Logout</a></li>';
|
$fieldset['Logout'] .= '<li><a href="?/logout">Logout</a></li>';
|
||||||
|
|
||||||
// TODO: Statistics, etc, in the dashboard.
|
// TODO: Statistics, etc, in the dashboard.
|
||||||
@ -283,11 +294,69 @@
|
|||||||
echo Element('page.html', Array(
|
echo Element('page.html', Array(
|
||||||
'config'=>$config,
|
'config'=>$config,
|
||||||
'title'=>'New PM for ' . htmlentities($to['username']),
|
'title'=>'New PM for ' . htmlentities($to['username']),
|
||||||
'body'=>$body
|
'body'=>$body,
|
||||||
,'mod'=>true
|
'mod'=>true
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
} elseif(preg_match('/^\/search$/', $query)) {
|
||||||
|
if($mod['type'] < $config['mod']['search']) error($config['error']['noaccess']);
|
||||||
|
|
||||||
|
$body = '<div class="ban"><h2>Search</h2><form style="display:inline" action="?/search" method="post">' .
|
||||||
|
'<p><label style="display:inline" for="search">Phrase:</label> ' .
|
||||||
|
'<input id="search" name="search" type="text" size="35" ' .
|
||||||
|
(isset($_POST['search']) ? 'value="' . htmlentities($_POST['search']) . '" ' : '') .
|
||||||
|
'/>' .
|
||||||
|
'<input type="submit" value="Search" />' .
|
||||||
|
'</p></form>' .
|
||||||
|
'<p><span class="unimportant">(Search is case-insensitive but not based on keywords.)</span></p>' .
|
||||||
|
'</div>';
|
||||||
|
|
||||||
|
if(isset($_POST['search']) && !empty($_POST['search'])) {
|
||||||
|
$phrase = $_POST['search'];
|
||||||
|
$_body = '';
|
||||||
|
|
||||||
|
$boards = listBoards();
|
||||||
|
foreach($boards as &$_b) {
|
||||||
|
openBoard($_b['uri']);
|
||||||
|
|
||||||
|
$query = prepare(sprintf("SELECT * FROM `posts_%s` WHERE `body` LIKE :query ORDER BY `time` DESC LIMIT :limit", $board['uri']));
|
||||||
|
$query->bindValue(':query', "%{$phrase}%");
|
||||||
|
$query->bindValue(':limit', $config['mod']['search_results'], PDO::PARAM_INT);
|
||||||
|
$query->execute() or error(db_error($query));
|
||||||
|
|
||||||
|
$temp = '';
|
||||||
|
while($post = $query->fetch()) {
|
||||||
|
if(!$post['thread']) {
|
||||||
|
$po = new Thread($post['id'], $post['subject'], $post['email'], $post['name'], $post['trip'], $post['body'], $post['time'], $post['thumb'], $post['thumbwidth'], $post['thumbheight'], $post['file'], $post['filewidth'], $post['fileheight'], $post['filesize'], $post['filename'], $post['ip'], $post['sticky'], $post['locked'], '?/', $mod, false);
|
||||||
|
} else {
|
||||||
|
$po = new Post($post['id'], $post['thread'], $post['subject'], $post['email'], $post['name'], $post['trip'], $post['body'], $post['time'], $post['thumb'], $post['thumbwidth'], $post['thumbheight'], $post['file'], $post['filewidth'], $post['fileheight'], $post['filesize'], $post['filename'], $post['ip'], '?/', $mod);
|
||||||
|
}
|
||||||
|
$temp .= $po->build(true) . '<hr/>';
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($temp))
|
||||||
|
$_body .= '<fieldset><legend>' . $query->rowCount() . ' result' . ($query->rowCount() != 1 ? 's' : '') . ' on <a href="?/' .
|
||||||
|
sprintf($config['board_path'], $board['uri']) . $config['file_index'] .
|
||||||
|
'">' .
|
||||||
|
sprintf($config['board_abbreviation'], $board['uri']) . ' - ' . $board['title'] .
|
||||||
|
'</a></legend>' . $temp . '</fieldset>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$body .= '<hr/>';
|
||||||
|
if(!empty($_body))
|
||||||
|
$body .= $_body;
|
||||||
|
else
|
||||||
|
$body .= '<p style="text-align:center" class="unimportant">(No results.)</p>';
|
||||||
|
}
|
||||||
|
|
||||||
|
echo Element('page.html', Array(
|
||||||
|
'config'=>$config,
|
||||||
|
'title'=>'Search',
|
||||||
|
'body'=>$body,
|
||||||
|
'mod'=>true
|
||||||
|
)
|
||||||
|
);
|
||||||
} elseif(preg_match('/^\/users$/', $query)) {
|
} elseif(preg_match('/^\/users$/', $query)) {
|
||||||
if($mod['type'] < $config['mod']['manageusers']) error($config['error']['noaccess']);
|
if($mod['type'] < $config['mod']['manageusers']) error($config['error']['noaccess']);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user