<?php
require_once "inc/common.php";
+require_once "Classes/class-checkup.php";
if (!isset($config['unrealircd']))
{
$redirect = get_config("base_url")."settings/rpc-servers.php";
?>
<div class="row ml-0">
<h2>Network Overview</h2>
- <div id="live_stats" data-toggle="tooltip" data-placement="top" title="The stats on this page are updated in real-time"
- class="card text-center row font-weight-bold"
- style="margin-left:5%;height:26px;width:60px;background-color:red;color:white;visibility:hidden">
- <small style="margin-left:-40px;padding-top:3px;margin-right:-45px">⚪</small>LIVE
+ <span class="badge bg-danger text-light ml-4 pl-2 pr-2 rounded-pill" style="height:fit-content">LIVE</span>
+ <?php checkup_widget(); ?>
</div>
-</div>
<?php
$array_of_stats = [];
-
/* What if someone wants to add their own stats... */
Hook::run(HOOKTYPE_PRE_OVERVIEW_CARD, $array_of_stats);
$userlist = [];
Hook::run(HOOKTYPE_GET_USER_LIST, $userlist);
$num_of_panel_admins = count($userlist);
-
+$current_user = unreal_get_current_user();
+if (isset($current_user->user_meta['hibp']))
+{
+ $num = $current_user->user_meta['hibp'];
+ Message::Fail("<h6><strong>Urgent</strong></h6>","Your password was found in a data breach $num time(s).",
+ "Please <strong><a href=\"".get_config("base_url")."settings/user-edit.php\">update your password</a></strong> immediately");
+}
?>
<style>
- .card {
+ .alert {
+ margin-left: 20px;
+ width:94%;
+ max-width: 500px;
+ }
+ #health_banner {
+ margin-left:20px;
+ border-radius: 16px;
+ width:fit-content;
+ }
+ .card-container a.card:hover { opacity: 0.8; transition: opacity 0.2s ease-in-out; }
+ .card-container .card {
min-height: 80%;
border-radius: 16px;
}
- .card-body i {
+ body {
+ background-image: url('img/wallpaper.jpg');
+ background-size: cover;
+ }
+ .card-container .card-body i {
position: fixed;
top: 10px;
right: 10px;
}
- .card:hover {
+ .card-container .card:hover {
text-decoration: none;
}
+ @keyframes rotateEffect {
+ 0% { transform: rotateX(0deg); }
+ 50% { transform: rotateX(180deg); }
+ 100% { transform: rotateX(0deg); }
+ }
+
+ .numberDisplay {
+ animation: rotateEffect 0.5s ease;
+ }
.frosted-glass-success {
/* From https://css.glass */
}
</style>
-<div class="container card-container ml-1">
+ <div class="container card-container ml-1">
-<div class="row mt-3">
- <div class="col-sm mb-3">
- <a class="card frosted-glass-success text-center" href="<?php echo get_config("base_url"); ?>users/">
- <div class="card-body text-white">
- <div class="row text-center">
- <span id="userRecord" class="position-absolute badge rounded-pill badge-warning" hidden>
- <?php echo "Record: "; ?>
- </span>
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-users fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="stats_user_total" class="display-4"></h5>
- <h5 class="display-5">Users Online</h5>
+ <div class="row mt-3">
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-success text-center" href="<?php echo get_config("base_url"); ?>users/">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <span id="userRecord" class="position-absolute badge rounded-pill badge-warning" hidden>
+ <?php echo "Record: "; ?>
+ </span>
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-users fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="stats_user_total" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5">Users Online</h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
- </div>
- <div class="col-sm mb-3">
- <a class="card frosted-glass-info text-center" href="<?php echo get_config("base_url"); ?>channels/">
- <div class="card-body text-white">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-hashtag fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="stats_channel_total" class="display-4"></h5>
- <h5 class="display-5">Channels</h5>
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-info text-center" href="<?php echo get_config("base_url"); ?>channels/">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-hashtag fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="stats_channel_total" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5">Channels</h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
- </div>
- <div class="col-sm mb-3">
- <a class="card frosted-glass-warning text-center" href="<?php echo get_config("base_url"); ?>users/">
- <div class="card-body text-dark">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-shield-halved fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="stats_oper_total" class="display-4"></h5>
- <h5 class="display-5" style="margin-top: -3px">Operators</h5>
- <h5 style="font-size: 10px; margin-top:-12px">View in Users ></h5>
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-warning text-center" href="<?php echo get_config("base_url"); ?>users/">
+ <div class="card-body text-dark">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-shield-halved fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="stats_oper_total" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5" style="margin-top: -3px">Operators</h5>
+ <h5 style="font-size: 10px; margin-top:-12px">View in Users ></h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
- </div>
- <div class="col-sm mb-3">
- <a class="card frosted-glass-secondary text-center" href="<?php echo get_config("base_url"); ?>servers/">
- <div class="card-body text-white">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-network-wired fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="stats_server_total" class="display-4"></h5>
- <h5 class="display-5">Servers</h5>
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-secondary text-center" href="<?php echo get_config("base_url"); ?>servers/">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-network-wired fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="stats_server_total" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5">Servers</h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
+ </div>
</div>
- </div>
-</div>
-<div class="container card-container ml-1">
+ <div class="container card-container ml-1">
- <div class="row">
- <div class="col-sm mb-3">
- <a class="card frosted-glass-danger text-center" href="<?php echo get_config("base_url"); ?>server_bans/">
- <div class="card-body text-white">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-ban fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="num_server_bans" class="display-4"></h5>
- <h5 class="display-5">Server Bans</h5>
+ <div class="row">
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-danger text-center" href="<?php echo get_config("base_url"); ?>server-bans/">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-ban fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="num_server_bans" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5">Server Bans</h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
- </div>
- <div class="col-sm mb-3">
- <a class="card frosted-glass-secondary text-center" href="<?php echo get_config("base_url"); ?>spamfilter.php/">
- <div class="card-body text-white">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-filter fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="num_spamfilter_entries" class="display-4"></h5>
- <h5 class="display-5">Spamfilter</h5>
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-secondary text-center" href="<?php echo get_config("base_url"); ?>server-bans/spamfilter.php">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-filter fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="num_spamfilter_entries" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5">Spamfilter</h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
- </div>
- <div class="col-sm mb-3">
- <a class="card frosted-glass-info text-center" href="<?php echo get_config("base_url"); ?>server-bans/ban-exceptions.php">
- <div class="card-body text-white">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-door-open fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="num_ban_exceptions" class="display-4"></h5>
- <h5 class="display-5">Server Ban Exceptions</h5>
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-info text-center" href="<?php echo get_config("base_url"); ?>server-bans/ban-exceptions.php">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-door-open fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="num_ban_exceptions" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5">Server Ban Exceptions</h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
- </div>
- <div class="col-sm mb-3">
- <a class="card frosted-glass-success text-center" href="<?php echo get_config("base_url"); ?>servers">
- <div class="card-body text-white">
- <div class="row text-center">
- <div class="col">
- <div class="col">
- <i aria-hidden="true" class="fa fa-database fa-2x"></i>
- </div>
- <div class="col">
- <h5 id="stats_uline_total" class="display-4"></h5>
- <h5 class="display-5" style="margin-top: -3px">Services Online</h5>
- <h5 style="font-size: 10px; margin-top:-12px">View in Servers ></h5>
+ <div class="col-sm mb-3">
+ <a class="card frosted-glass-success text-center" href="<?php echo get_config("base_url"); ?>servers">
+ <div class="card-body text-white">
+ <div class="row text-center">
+ <div class="col">
+ <div class="col">
+ <i aria-hidden="true" class="fa fa-database fa-2x"></i>
+ </div>
+ <div class="col">
+ <h5 id="stats_uline_total" class="display-4 numberDisplay"></h5>
+ <h5 class="display-5" style="margin-top: -3px">Services Online</h5>
+ <h5 style="font-size: 10px; margin-top:-12px">View in Servers ></h5>
+ </div>
+ </div>
</div>
</div>
- </div>
+ </a>
</div>
- </a>
+ </div>
</div>
- </div>
-</div>
-
<script>
/* Last time stats were updated */
stats_tick = Date.now()
console.log(data);
document.getElementById("userRecord").innerHTML = "Record: "+data.user.record;
- document.getElementById("live_stats").style.visibility = '';
document.getElementById("stats_user_total").innerHTML = data.user.total;
+ document.getElementById("stats_user_total").classList.remove('numberDisplay');
+ document.getElementById("stats_user_total").classList.add('numberDisplay');
document.getElementById("stats_channel_total").innerHTML = data.channel.total;
document.getElementById("stats_oper_total").innerHTML = data.user.oper;
document.getElementById("stats_server_total").innerHTML = data.server.total;
<i aria-hidden="true" class="fa fa-lock-open fa-2x"></i>
</div>
<div class="col">
- <h5 class="display-4"><?php echo $num_of_panel_admins; ?></h5>
+ <h5 class="display-4 numberDisplay"><?php echo $num_of_panel_admins; ?></h5>
<h5 class="display-5">Panel Accounts</h5>
</div>
</div>
<i aria-hidden="true" class="fa fa-plug fa-2x"></i>
</div>
<div class="col">
- <h5 class="display-4"><?php echo count(Plugins::$list); ?></h5>
+ <h5 class="display-4 numberDisplay"><?php echo count(Plugins::$list); ?></h5>
<h5 class="display-5">Plugins</h5>
</div>
</div>