''); $page['saved'] = false; $page['thread'] = ''; $page['threadid'] = ''; $errors = array(); if (isset($_POST['address'])) { $banId = verifyparam("banId", "/^(\d{1,9})?$/", ""); $address = getparam("address"); $days = getparam("days"); $comment = getparam('comment'); $threadid = isset($_POST['threadid']) ? getparam('threadid') : ""; if (!$address) { $errors[] = no_field("form.field.address"); } if (!preg_match("/^\d+$/", $days)) { $errors[] = wrong_field("form.field.ban_days"); } if (!$comment) { $errors[] = no_field("form.field.ban_comment"); } $existing_ban = ban_for_addr($address); if ((!$banId && $existing_ban) || ($banId && $existing_ban && $banId != $existing_ban['banid'])) { $errors[] = getlocal2("ban.error.duplicate", array($address, $existing_ban['banid'])); } if (count($errors) == 0) { $db = Database::getInstance(); $utime = time() + $days * 24 * 60 * 60; if (!$banId) { $db->query( "insert into {chatban} (dtmcreated,dtmtill,address,comment) " . "values (CURRENT_TIMESTAMP,FROM_UNIXTIME(?),?,?)", array( $utime, $address, $comment ) ); } else { $db->query( "update {chatban} set dtmtill = FROM_UNIXTIME(?),address = ?, " . "comment = ? where banid = ?", array( $utime, $address, $comment, $banId ) ); } if (!$threadid) { header("Location: $webimroot/operator/blocked.php"); exit; } else { $page['saved'] = true; $page['address'] = $address; } } else { $page['banId'] = topage($banId); $page['formaddress'] = topage($address); $page['formdays'] = topage($days); $page['formcomment'] = topage($comment); $page['threadid'] = $threadid; } } else if (isset($_GET['id'])) { $banId = verifyparam('id', "/^\d{1,9}$/"); $db = Database::getInstance(); $ban = $db->query( "select banid,(unix_timestamp(dtmtill)-unix_timestamp(CURRENT_TIMESTAMP))" . " as days,address,comment from {chatban} where banid = ?", array($banId), array('return_rows' => Database::RETURN_ONE_ROW) ); if ($ban) { $page['banId'] = topage($ban['banid']); $page['formaddress'] = topage($ban['address']); $page['formdays'] = topage(round($ban['days'] / 86400)); $page['formcomment'] = topage($ban['comment']); } else { $errors[] = "Wrong id"; } } else if (isset($_GET['thread'])) { $threadid = verifyparam('thread', "/^\d{1,9}$/"); $thread = thread_by_id($threadid); if ($thread) { $page['thread'] = topage($thread['userName']); $page['threadid'] = $threadid; $page['formaddress'] = topage($thread['remote']); $page['formdays'] = 15; } } prepare_menu($operator, false); start_html_output(); require('../view/ban.php'); exit; ?>