Moderator noticeboard
This commit is contained in:
parent
44aeb4d97d
commit
e978bfd2b0
|
@ -252,6 +252,8 @@
|
||||||
$config['mod']['modlog_page'] = 350;
|
$config['mod']['modlog_page'] = 350;
|
||||||
// Maximum number of results to display for a search, per board
|
// Maximum number of results to display for a search, per board
|
||||||
$config['mod']['search_results'] = 75;
|
$config['mod']['search_results'] = 75;
|
||||||
|
// Maximum number of notices to display on the moderator noticeboard
|
||||||
|
$config['mod']['noticeboard_display'] = 50;
|
||||||
|
|
||||||
// Probably best not to change these:
|
// Probably best not to change these:
|
||||||
if(!defined('JANITOR')) {
|
if(!defined('JANITOR')) {
|
||||||
|
@ -337,6 +339,12 @@
|
||||||
$config['mod']['rebuild'] = ADMIN;
|
$config['mod']['rebuild'] = ADMIN;
|
||||||
// Search through posts
|
// Search through posts
|
||||||
$config['mod']['search'] = JANITOR;
|
$config['mod']['search'] = JANITOR;
|
||||||
|
// Read the moderator noticeboard
|
||||||
|
$config['mod']['noticeboard'] = JANITOR;
|
||||||
|
// Post to the moderator noticeboard
|
||||||
|
$config['mod']['noticeboard_post'] = MOD;
|
||||||
|
// Delete entries from the noticeboard
|
||||||
|
$config['mod']['noticeboard_delete'] = ADMIN;
|
||||||
|
|
||||||
// Wait indefinitely when rebuilding everything
|
// Wait indefinitely when rebuilding everything
|
||||||
$config['mod']['rebuild_timelimit'] = 0;
|
$config['mod']['rebuild_timelimit'] = 0;
|
||||||
|
|
19
install.sql
19
install.sql
|
@ -204,3 +204,22 @@ CREATE TABLE IF NOT EXISTS `robot` (
|
||||||
-- Dumping data for table `robot`
|
-- Dumping data for table `robot`
|
||||||
--
|
--
|
||||||
|
|
||||||
|
|
||||||
|
-- --------------------------------------------------------
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Table structure for table `noticeboard`
|
||||||
|
--
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `noticeboard` (
|
||||||
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||||
|
`mod` int(11) NOT NULL,
|
||||||
|
`time` int(11) NOT NULL,
|
||||||
|
`subject` text NOT NULL,
|
||||||
|
`body` text NOT NULL,
|
||||||
|
UNIQUE KEY `id` (`id`)
|
||||||
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=10 ;
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Dumping data for table `noticeboard`
|
||||||
|
--
|
||||||
|
|
82
mod.php
82
mod.php
|
@ -78,6 +78,7 @@
|
||||||
// Dashboard
|
// Dashboard
|
||||||
$fieldset = Array(
|
$fieldset = Array(
|
||||||
'Boards' => '',
|
'Boards' => '',
|
||||||
|
'Noticeboard' => '',
|
||||||
'Administration' => '',
|
'Administration' => '',
|
||||||
'Search' => '',
|
'Search' => '',
|
||||||
'Logout' => ''
|
'Logout' => ''
|
||||||
|
@ -86,6 +87,10 @@
|
||||||
// Boards
|
// Boards
|
||||||
$fieldset['Boards'] .= ulBoards();
|
$fieldset['Boards'] .= ulBoards();
|
||||||
|
|
||||||
|
if($mod['type'] >= $config['mod']['noticeboard']) {
|
||||||
|
$fieldset['Noticeboard'] .= '<li><a href="?/noticeboard">View previous entries</a></li>';
|
||||||
|
}
|
||||||
|
|
||||||
if($mod['type'] >= $config['mod']['reports']) {
|
if($mod['type'] >= $config['mod']['reports']) {
|
||||||
$fieldset['Administration'] .= '<li><a href="?/reports">Report queue</a></li>';
|
$fieldset['Administration'] .= '<li><a href="?/reports">Report queue</a></li>';
|
||||||
}
|
}
|
||||||
|
@ -178,6 +183,83 @@
|
||||||
'mod'=>true
|
'mod'=>true
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
} elseif(preg_match('/^\/noticeboard\/delete\/(\d+)$/', $query, $match)) {
|
||||||
|
if($mod['type'] < $config['mod']['noticeboard_delete']) error($config['error']['noaccess']);
|
||||||
|
|
||||||
|
$query = prepare("DELETE FROM `noticeboard` WHERE `id` = :id");
|
||||||
|
$query->bindValue(':id', $match[1], PDO::PARAM_INT);
|
||||||
|
$query->execute() or error(db_error($query));
|
||||||
|
|
||||||
|
header('Location: ?/noticeboard', true, $config['redirect_http']);
|
||||||
|
} elseif(preg_match('/^\/noticeboard$/', $query)) {
|
||||||
|
if($mod['type'] < $config['mod']['noticeboard']) error($config['error']['noaccess']);
|
||||||
|
|
||||||
|
$body = '';
|
||||||
|
|
||||||
|
if($mod['type'] >= $config['mod']['noticeboard_post']) {
|
||||||
|
if(isset($_POST['subject']) && isset($_POST['body'])) {
|
||||||
|
$query = prepare("INSERT INTO `noticeboard` VALUES (NULL, :mod, :time, :subject, :body)");
|
||||||
|
$query->bindValue(':mod', $mod['id'], PDO::PARAM_INT);
|
||||||
|
$query->bindvalue(':time', time(), PDO::PARAM_INT);
|
||||||
|
$query->bindValue(':subject', utf8tohtml($_POST['subject']));
|
||||||
|
|
||||||
|
markup($_POST['body']);
|
||||||
|
$query->bindValue(':body', $_POST['body']);
|
||||||
|
$query->execute() or error(db_error($query));
|
||||||
|
}
|
||||||
|
|
||||||
|
$body .= '<fieldset><legend>New post</legend><form style="display:inline" action="" method="post"><table>' .
|
||||||
|
'<tr>' .
|
||||||
|
'<th><label for="subject">Name</label></th>' .
|
||||||
|
'<td>' . $mod['username'] . '</td>' .
|
||||||
|
'</tr><tr>' .
|
||||||
|
'<th>Subject</th>' .
|
||||||
|
'<td><input type="text" size="55" name="subject" id="subject" /></td>' .
|
||||||
|
'</tr><tr>' .
|
||||||
|
'<th>Body</th>' .
|
||||||
|
'<td><textarea name="body" style="width:100%;height:100px"></textarea></td>' .
|
||||||
|
'</tr><tr>' .
|
||||||
|
'<td></td><td><input type="submit" value="Post to noticeboard" /></td>' .
|
||||||
|
'</tr></table>' .
|
||||||
|
'</form></fieldset>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = prepare("SELECT * FROM `noticeboard` ORDER BY `id` DESC LIMIT :limit");
|
||||||
|
$query->bindValue(':limit', $config['mod']['noticeboard_display'], PDO::PARAM_INT);
|
||||||
|
$query->execute() or error(db_error($query));
|
||||||
|
while($notice = $query->fetch()) {
|
||||||
|
$m_query = prepare("SELECT `username` FROM `mods` WHERE `id` = :id");
|
||||||
|
$m_query->bindValue(':id', $notice['mod'], PDO::PARAM_INT);
|
||||||
|
$m_query->execute() or error(db_error($m_query));
|
||||||
|
if(!$_mod = $m_query->fetch()) {
|
||||||
|
$_mod = Array('username' => '<em>???</em>');
|
||||||
|
}
|
||||||
|
|
||||||
|
$body .= '<div class="ban">' .
|
||||||
|
($mod['type'] >= $config['mod']['noticeboard_delete'] ?
|
||||||
|
'<span style="float:right;padding:2px"><a class="unimportant" href="?/noticeboard/delete/' . $notice['id'] . '">[delete]</a>'
|
||||||
|
: '') .
|
||||||
|
'</span><h2>' .
|
||||||
|
($notice['subject'] ?
|
||||||
|
$notice['subject']
|
||||||
|
:
|
||||||
|
'<em>no subject</em>'
|
||||||
|
) .
|
||||||
|
'<span class="unimportant"> — by ' .
|
||||||
|
$_mod['username'] .
|
||||||
|
' at ' .
|
||||||
|
date($config['post_date'], $notice['time']) .
|
||||||
|
'</span></h2><p>' . $notice['body'] . '</p></div>';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
echo Element('page.html', Array(
|
||||||
|
'config'=>$config,
|
||||||
|
'title'=>'Noticeboard',
|
||||||
|
'body'=>$body,
|
||||||
|
'mod'=>true
|
||||||
|
)
|
||||||
|
);
|
||||||
} elseif(preg_match('/^\/PM\/(\d+)$/', $query, $match)) {
|
} elseif(preg_match('/^\/PM\/(\d+)$/', $query, $match)) {
|
||||||
$id = $match[1];
|
$id = $match[1];
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue