|
|
@@ -573,15 +573,20 @@ function listBoards() { |
|
|
|
function checkFlood($post) { |
|
|
|
global $board, $config; |
|
|
|
|
|
|
|
$query = prepare(sprintf("SELECT * FROM ``posts_%s`` WHERE (`ip` = :ip AND `time` >= :floodtime) OR (`ip` = :ip AND `body` != '' AND `body` = :body AND `time` >= :floodsameiptime) OR (`body` != '' AND `body` = :body AND `time` >= :floodsametime) LIMIT 1", $board['uri'])); |
|
|
|
$query = prepare(sprintf("SELECT COUNT(*) FROM ``posts_%s`` WHERE |
|
|
|
(`ip` = :ip AND `time` >= :floodtime) |
|
|
|
OR |
|
|
|
(`ip` = :ip AND :body != '' AND `body_nomarkup` = :body AND `time` >= :floodsameiptime) |
|
|
|
OR |
|
|
|
(:body != '' AND `body_nomarkup` = :body AND `time` >= :floodsametime) LIMIT 1", $board['uri'])); |
|
|
|
$query->bindValue(':ip', $_SERVER['REMOTE_ADDR']); |
|
|
|
$query->bindValue(':body', $post['body']); |
|
|
|
$query->bindValue(':floodtime', time()-$config['flood_time'], PDO::PARAM_INT); |
|
|
|
$query->bindValue(':floodsameiptime', time()-$config['flood_time_ip'], PDO::PARAM_INT); |
|
|
|
$query->bindValue(':floodsametime', time()-$config['flood_time_same'], PDO::PARAM_INT); |
|
|
|
$query->execute() or error(db_error($query)); |
|
|
|
|
|
|
|
$flood = (bool) $query->fetch(PDO::FETCH_ASSOC); |
|
|
|
|
|
|
|
$flood = (bool) $query->fetchColumn(); |
|
|
|
|
|
|
|
if (event('check-flood', $post)) |
|
|
|
return true; |
|
|
@@ -658,12 +663,12 @@ function checkBan($board = 0) { |
|
|
|
if (event('check-ban', $board)) |
|
|
|
return true; |
|
|
|
|
|
|
|
$query = prepare("SELECT `set`, `expires`, `reason`, `board`, `seen`, ``bans``.`id` FROM ``bans`` WHERE (`board` IS NULL OR `board` = :board) AND `ip` = :ip ORDER BY `expires` IS NULL DESC, `expires` DESC LIMIT 1"); |
|
|
|
$query = prepare("SELECT `set`, `expires`, `reason`, `board`, `seen`, `id` FROM ``bans`` WHERE (`board` IS NULL OR `board` = :board) AND `ip` = :ip ORDER BY `expires` IS NULL DESC, `expires` DESC LIMIT 1"); |
|
|
|
$query->bindValue(':ip', $_SERVER['REMOTE_ADDR']); |
|
|
|
$query->bindValue(':board', $board); |
|
|
|
$query->execute() or error(db_error($query)); |
|
|
|
if ($query->rowCount() < 1 && $config['ban_range']) { |
|
|
|
$query = prepare("SELECT `set`, `expires`, `reason`, `board`, `seen`, ``bans``.`id` FROM ``bans`` WHERE (`board` IS NULL OR `board` = :board) AND :ip LIKE REPLACE(REPLACE(`ip`, '%', '!%'), '*', '%') ESCAPE '!' ORDER BY `expires` IS NULL DESC, `expires` DESC LIMIT 1"); |
|
|
|
$query = prepare("SELECT `set`, `expires`, `reason`, `board`, `seen`, `id` FROM ``bans`` WHERE (`board` IS NULL OR `board` = :board) AND :ip LIKE REPLACE(REPLACE(`ip`, '%', '!%'), '*', '%') ESCAPE '!' ORDER BY `expires` IS NULL DESC, `expires` DESC LIMIT 1"); |
|
|
|
$query->bindValue(':ip', $_SERVER['REMOTE_ADDR']); |
|
|
|
$query->bindValue(':board', $board); |
|
|
|
$query->execute() or error(db_error($query)); |
|
|
@@ -1229,14 +1234,11 @@ function checkRobot($body) { |
|
|
|
// Returns an associative array with 'replies' and 'images' keys |
|
|
|
function numPosts($id) { |
|
|
|
global $board; |
|
|
|
$query = prepare(sprintf("SELECT COUNT(*) FROM ``posts_%s`` WHERE `thread` = :thread UNION ALL SELECT COUNT(*) FROM ``posts_%s`` WHERE `file` IS NOT NULL AND `thread` = :thread", $board['uri'], $board['uri'])); |
|
|
|
$query = prepare(sprintf("SELECT COUNT(*) AS `replies`, COUNT(NULLIF(`file`, 0)) AS `images` FROM ``posts_%s`` WHERE `thread` = :thread", $board['uri'], $board['uri'])); |
|
|
|
$query->bindValue(':thread', $id, PDO::PARAM_INT); |
|
|
|
$query->execute() or error(db_error($query)); |
|
|
|
|
|
|
|
$num_posts = $query->fetchColumn(); |
|
|
|
$num_images = $query->fetchColumn(); |
|
|
|
|
|
|
|
return array('replies' => $num_posts, 'images' => $num_images); |
|
|
|
return $query->fetch(PDO::FETCH_ASSOC); |
|
|
|
} |
|
|
|
|
|
|
|
function muteTime() { |
|
|
|