Basic search function for mods

This commit is contained in:
Savetheinternet 2011-03-30 00:56:38 +11:00
parent 80955172e9
commit b2ae5fdcba
2 changed files with 75 additions and 2 deletions

View File

@ -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
View File

@ -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']);