<!DOCTYPE html>
+<title>UnrealIRCd Panel</title>
<link rel="icon" type="image/x-icon" href="/img/favicon.ico">
<link href="css/unrealircd-admin.css" rel="stylesheet">
<body class="body-for-sticky">
<div id="headerContainer">
-<h2><a href="">UnrealIRCd</a> <small>Administration Panel</small></h2><br>
-</div>
+<h2><a href="">UnrealIRCd <small>Administration Panel</small></a></h2></div>
<script src="js/unrealircd-admin.js" defer></script>
<div class="topnav">
<a data-tab-target="#overview" class="active" href="#overview">Overview</a>
</div>
<?php
define('UPATH', dirname(__FILE__));
-include "config.php";
-include "Classes/class-log.php";
-include "Classes/class-message.php";
-include "Classes/class-rpc.php";
+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)) {
return;
}
- $msg_msg = ($duration == 0) ? "permanently" : "for $duration";
+ $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_tkl_add($user, $bantype, $duration, $reason))
{
$c = $nick['result']['client'];
- Message::Success($c['name'] . " (*@".$c['hostname'].") has been $bantype" . "'d $msg_msg");
+ Message::Success($c['name'] . " (*@".$c['hostname'].") has been $bantype" . "d $msg_msg: $reason");
}
}
}
foreach ($value as $tok) {
$tok = explode(",", $tok);
rpc_sf_del(base64_decode($tok[0]), base64_decode($tok[1]), base64_decode($tok[2]), base64_decode($tok[3]));
- Message::Success(base64_decode($tok[1])." has been added for ".base64_decode($tok[0]));
}
}
}
<div class="tab-content\">
<div id="Users" data-tab-content>
- <p></p>
+ <table class='users_filter'>
+ <th class="thuf">Filter by: </th>
+ <th>
+ <form action="" method="post">
+ Nick: <input name="uf_nick" id="uf_nick" type="text">
+ <input class="cute_button2" type="submit" value="Search">
+ </form>
+ </th>
+ <th>
+ <form action="" method="post">
+ Hostname: <input name="uf_host" id="uf_host" type="text">
+ <input class="cute_button2" type="submit" value="Search">
+ </form>
+ </th>
+ <th>
+ <form action="" method="post">
+ IP: <input name="uf_ip" id="uf_ip" type="text">
+ <input class="cute_button2" type="submit" value="Search">
+ </form>
+ </th>
+ <th class="thuffer">
+ <form action="" method="post">
+ Account: <input name="uf_account" id="uf_account" type="text">
+ <input class="cute_button2" type="submit" value="Search">
+ </form>
+ </th>
+ </form>
+ </table>
+ <?php
+ if (isset($_POST['uf_nick']) && strlen($_POST['uf_nick']))
+ Message::Info("Listing users which match nick: \"" . $_POST['uf_nick'] . "\"");
+
+ if (isset($_POST['uf_ip']) && strlen($_POST['uf_ip']))
+ Message::Info("Listing users which match IP: \"" . $_POST['uf_ip'] . "\"");
+
+ if (isset($_POST['uf_host']) && strlen($_POST['uf_host']))
+ Message::Info("Listing users which match hostmask: \"" . $_POST['uf_host'] . "\"");
+
+ if (isset($_POST['uf_account']) && strlen($_POST['uf_account']))
+ Message::Info("Listing users which match account: \"" . $_POST['uf_account'] . "\"");
+
+ ?>
<table class='users_overview'>
<th><input type="checkbox" label='selectall' onClick="toggle_user(this)" />Select all</th>
<th>Nick</th>
<th>UID</th>
<th>Host / IP</th>
<th>Account</th>
- <th>Usermodes</th>
+ <th>Usermodes<a href="https://www.unrealircd.org/docs/User_modes" target="_blank">ℹ️</a></th>
<th>Oper</th>
<th>Secure</th>
<th>Connected to</th>
- <th>Reputation <a href="https://www.unrealircd.org/docs/Reputation_score">ℹ️</a></th>
+ <th>Reputation <a href="https://www.unrealircd.org/docs/Reputation_score" target="_blank">ℹ️</a></th>
<form action="" method="post">
<?php
foreach(RPC_List::$user as $user)
{
+
+ /* Some basic filtering for NICK */
+ if (isset($_POST['uf_nick']) && strlen($_POST['uf_nick']) &&
+ strpos(strtolower($user->name), strtolower($_POST['uf_nick'])) !== 0 &&
+ strpos(strtolower($user->name), strtolower($_POST['uf_nick'])) == false)
+ continue;
+
+ /* Some basic filtering for HOST */
+ if (isset($_POST['uf_host']) && strlen($_POST['uf_host']) &&
+ strpos(strtolower($user->hostname), strtolower($_POST['uf_host'])) !== 0 &&
+ strpos(strtolower($user->hostname), strtolower($_POST['uf_host'])) == false)
+ continue;
+
+ /* Some basic filtering for IP */
+ if (isset($_POST['uf_ip']) && strlen($_POST['uf_ip']) &&
+ strpos(strtolower($user->ip), strtolower($_POST['uf_ip'])) !== 0 &&
+ strpos(strtolower($user->ip), strtolower($_POST['uf_ip'])) == false)
+ continue;
+
+ /* Some basic filtering for ACCOUNT */
+ if (isset($_POST['uf_account']) && strlen($_POST['uf_account']) &&
+ strpos(strtolower($user->user->account), strtolower($_POST['uf_account'])) !== 0 &&
+ strpos(strtolower($user->user->account), strtolower($_POST['uf_account'])) == false)
+ continue;
+
echo "<tr>";
- echo "<td><input type=\"checkbox\" value='" . base64_encode($user['id'])."' name=\"userch[]\"></td>";
- echo "<td>".$user['name']."</td>";
- echo "<td>".$user['id']."</td>";
- echo "<td>".$user['hostname']." (".$user['ip'].")</td>";
- $account = (isset($user['user']['account'])) ? $user['user']['account'] : "";
+ echo "<td><input type=\"checkbox\" value='" . base64_encode($user->id)."' name=\"userch[]\"></td>";
+ $isBot = (strpos($user->user->modes, "B") !== false) ? ' <span class="label">Bot</span>' : "";
+ echo "<td>".$user->name.$isBot.'</td>';
+ echo "<td>".$user->id."</td>";
+ echo "<td>".$user->hostname." (".$user->ip.")</td>";
+ $account = (isset($user->user->account)) ? '<span class="label">'.$user->user->account.'</span>' : '<span class="label noaccount">None</span>';
echo "<td>".$account."</td>";
- $modes = (isset($user['user']['modes'])) ? "+" . $user['user']['modes'] : "<none>";
+ $modes = (isset($user->user->modes)) ? "+" . $user->user->modes : "<none>";
echo "<td>".$modes."</td>";
- $oper = (isset($user['user']['operlogin'])) ? $user['user']['operlogin']." (".$user['user']['operclass'].")" : "";
+ $oper = (isset($user->user->operlogin)) ? '<span class="label">'.$user->user->operlogin."</span> <span class=\"label operclass-label\">".$user->user->operclass."</span>" : "";
+ if (!strlen($oper))
+ $oper = (strpos($user->user->modes, "S") !== false) ? '<span class="label secure-connection">Service</span>' : "";
echo "<td>".$oper."</td>";
- $secure = (isset($user['tls'])) ? "✅" : "❌";
+ $secure = (isset($user->tls)) ? "<span class=\"label secure-connection\">Secure</span>" : "<span class=\"label noaccount\">Insecure</span>";
echo "<td>".$secure."</td>";
- echo "<td>".$user['user']['servername']."</td>";
- echo "<td>".$user['user']['reputation']."</td>";
+ echo "<td>".$user->user->servername."</td>";
+ echo "<td>".$user->user->reputation."</td>";
}
?></table>
- <label for="bantype">Apply action:
+ <label for="bantype">Apply action: </label><br>
<select name="bantype" id="bantype">
<option value=""></option>
<optgroup label="Bans">
</optgroup>
</select>
<br>
- <label for="banlen_w">Duration: </label>
+ <label for="banlen_w">Duration: </label><br>
<select name="banlen_w" id="banlen_w">
<?php
for ($i = 0; $i <= 56; $i++)
}
?>
</select>
- <br>
- <input type="text" name="ban_reason" id="ban_reason" value="No reason"></input><br>
- <input type="submit" value="Apply">
+ <br><label for="ban_reason">Reason:<br></label>
+ <textarea name="ban_reason" id="ban_reason">No reason</textarea><br>
+ <input class="cute_button" type="submit" value="Apply">
</form>
</div></div>
foreach(RPC_List::$channel as $channel)
{
echo "<tr>";
- echo "<td>".$channel['name']."</td>";
- echo "<td>".$channel['creation_time']."</td>";
- echo "<td>".$channel['num_users']."</td>";
- $topic = (isset($channel['topic'])) ? $channel['topic'] : "";
+ echo "<td>".$channel->name."</td>";
+ echo "<td>".$channel->creation_time."</td>";
+ echo "<td>".$channel->num_users."</td>";
+ $topic = (isset($channel->topic)) ? $channel->topic : "";
echo "<td>".$topic."</td>";
- $setby = (isset($channel['topic'])) ? "By ".$channel['topic_set_by'] .", at ".$channel['topic_set_at'] : "";
+ $setby = (isset($channel->topic)) ? "By ".$channel->topic_set_by .", at ".$channel->topic_set_at : "";
echo "<td>".$setby."</td>";
- $modes = (isset($channel['modes'])) ? "+" . $channel['modes'] : "<none>";
+ $modes = (isset($channel->modes)) ? "+" . $channel->modes : "<none>";
echo "<td>".$modes."</td>";
}
?></table></div></div>
foreach(RPC_List::$tkl as $tkl)
{
echo "<tr>";
- echo "<td><input type=\"checkbox\" value='" . base64_encode($tkl['name']).",".base64_encode($tkl['type']) . "' name=\"tklch[]\"></td>";
- echo "<td>".$tkl['name']."</td>";
- echo "<td>".$tkl['type_string']."</td>";
- echo "<td>".$tkl['set_by']."</td>";
- echo "<td>".$tkl['set_at_string']."</td>";
- echo "<td>".$tkl['expire_at_string']."</td>";
- echo "<td>".$tkl['duration_string']."</td>";
- echo "<td>".$tkl['reason']."</td>";
+ echo "<td><input type=\"checkbox\" value='" . base64_encode($tkl->name).",".base64_encode($tkl->type) . "' name=\"tklch[]\"></td>";
+ echo "<td>".$tkl->name."</td>";
+ echo "<td>".$tkl->type_string."</td>";
+ echo "<td>".$tkl->set_by."</td>";
+ echo "<td>".$tkl->set_at_string."</td>";
+ echo "<td>".$tkl->expire_at_string."</td>";
+ echo "<td>".$tkl->duration_string."</td>";
+ echo "<td>".$tkl->reason."</td>";
}
?></table><p><input class="cute_button" type="submit" value="Delete selected"></p></form></div></div>
foreach(RPC_List::$spamfilter as $sf)
{
echo "<tr>";
- echo "<td><input type=\"checkbox\" value='" . base64_encode($sf['name']).",".base64_encode($sf['match_type']).",".base64_encode($sf['spamfilter_targets']).",".base64_encode($sf['ban_action']) . "' name=\"sf[]\"></td>";
- echo "<td>".$sf['name']."</td>";
- echo "<td>".$sf['type_string']."</td>";
- echo "<td>".$sf['set_by']."</td>";
- echo "<td>".$sf['set_at_string']."</td>";
- echo "<td>".$sf['expire_at_string']."</td>";
- echo "<td>".$sf['duration_string']."</td>";
- echo "<td>".$sf['match_type']."</td>";
- echo "<td>".$sf['ban_action']."</td>";
- echo "<td>".$sf['ban_duration_string']."</td>";
- for ($i = 0, $targs = ""; ($c = $sf['spamfilter_targets'][$i]); $i++)
+ echo "<td><input type=\"checkbox\" value='" . base64_encode($sf->name).",".base64_encode($sf->match_type).",".base64_encode($sf->spamfilter_targets).",".base64_encode($sf->ban_action) . "' name=\"sf[]\"></td>";
+ echo "<td>".$sf->name."</td>";
+ echo "<td>".$sf->type_string."</td>";
+ echo "<td>".$sf->set_by."</td>";
+ echo "<td>".$sf->set_at_string."</td>";
+ echo "<td>".$sf->expire_at_string."</td>";
+ echo "<td>".$sf->duration_string."</td>";
+ echo "<td>".$sf->match_type."</td>";
+ echo "<td>".$sf->ban_action."</td>";
+ echo "<td>".$sf->ban_duration_string."</td>";
+ for ($i = 0, $targs = ""; $i < strlen($sf->spamfilter_targets); $i++)
{
+ $c = $sf->spamfilter_targets[$i];
if ($c == "c")
$targs .= "Channel, ";
else if ($c == "p")
$targs .= "MessageTag, ";
else if ($c == "u")
$targs .= "Usermask, ";
-
- $targs = rtrim($targs,", ");
}
+ $targs = rtrim($targs,", ");
echo "<td>".$targs."</td>";
- echo "<td>".$sf['reason']."</td>";
+ echo "<td>".$sf->reason."</td>";
}
?></table><p><input class="cute_button" type="submit" value="Delete selected"></p></form></div></div>