+define('UPATH', dirname(__FILE__));
+require_once "config.php";
+require_once UPATH . '/vendor/autoload.php';
+require_once "connection.php";
+require_once "Classes/class-log.php";
+require_once "Classes/class-message.php";
+require_once "Classes/class-rpc.php";
+
+do_log($_POST);
+
+if (!empty($_POST)) {
+ if (!($bantype = $_POST['bantype'])) {
+
+ } else if (!($users = $_POST["userch"])) {
+ Message::Fail("No user was specified");
+ } else {
+ foreach ($_POST["userch"] as $user) {
+ $user = base64_decode($user);
+ $bantype = (isset($_POST['bantype'])) ? $_POST['bantype'] : NULL;
+ if (!$bantype)
+ {
+ Message::Fail("An error occured");
+ return;
+ }
+ $banlen_w = (isset($_POST['banlen_w'])) ? $_POST['banlen_w'] : NULL;
+ $banlen_d = (isset($_POST['banlen_d'])) ? $_POST['banlen_d'] : NULL;
+ $banlen_h = (isset($_POST['banlen_h'])) ? $_POST['banlen_h'] : NULL;
+
+ $duration = "";
+ if (!$banlen_d && !$banlen_h && !$banlen_w)
+ $duration .= "0";
+
+ else
+ {
+ if ($banlen_w)
+ $duration .= $banlen_w;
+ if ($banlen_d)
+ $duration .= $banlen_d;
+ if ($banlen_h)
+ $duration .= $banlen_h;
+ }
+
+ $nick = $rpc->user()->get($user);
+ if (!$nick)
+ {
+ Message::Fail("Could not find that user. Maybe they disconnected after you clicked this?");
+ return;
+ }
+
+ $msg_msg = ($duration == "0" || $duration == "0w0d0h") ? "permanently" : "for ".rpc_convert_duration_string($duration);
+ $reason = (isset($_POST['ban_reason'])) ? $_POST['ban_reason'] : "No reason";
+ if ($rpc->serverban()->add($user, $bantype, $duration, $reason))
+ {
+ $c = $nick->client;
+ Message::Success($c->name . " (*@".$c->hostname.") has been $bantype" . "d $msg_msg: $reason");
+ }
+ }
+ }
+
+ if (!empty($_POST['tklch']))
+ foreach ($_POST as $key => $value) {
+ foreach ($value as $tok) {
+ $tok = explode(",", $tok);
+ $ban = base64_decode($tok[0]);
+ $type = base64_decode($tok[1]);
+ if ($rpc->serverban()->delete($ban, $type))
+ Message::Success("$type has been removed for $ban");
+ else
+ Message::Fail("Unable to remove $type on $ban: $rpc->error");
+ }
+ }
+
+ if (!empty($_POST['sf']))
+ foreach ($_POST as $key => $value) {
+ foreach ($value as $tok) {
+ $tok = explode(",", $tok);
+ $name = base64_decode($tok[0]);
+ $match_type = base64_decode($tok[1]);
+ $spamfilter_targets = base64_decode($tok[2]);
+ $ban_action = base64_decode($tok[3]);
+ if ($rpc->spamfilter()->delete($name, $match_type, $spamfilter_targets, $ban_action))
+ Message::Success("Spamfilter on $name has been removed");
+ else
+ Message::Fail("Unable to remove spamfilter on $name: $rpc->error");
+ }
+ }
+}
+
+rpc_pop_lists();