]> jfr.im git - irc/unrealircd/unrealircd-webpanel.git/blobdiff - index.php
javascript function to generate a new toast notification
[irc/unrealircd/unrealircd-webpanel.git] / index.php
index dd0d60fe3f4b24a9cb23543304ffa9e3fdece57a..6384929e931f85540ae84a0dab19ce7e686bc9b3 100644 (file)
--- a/index.php
+++ b/index.php
@@ -1,24 +1,43 @@
 <?php
 require_once "common.php";
+require_once "connection.php";
 require_once "header.php";
 
-rpc_pop_lists();
+$stats = $rpc->query("stats.get", []);
 ?>
 
 <h2>Network Overview</h2>
 
-<div class="container mt-5">
+<?php
+$array_of_stats = (array)$stats;
 
-       <div class="row">
-               <div class="col-sm">
+/* What if someone wants to add their own stats... */
+Hook::run(HOOKTYPE_PRE_OVERVIEW_CARD, $array_of_stats);
+
+/* This makes sure that a plugin which called the parameter
+ * by reference can add/update the stats for display here.
+*/
+$stats = (object) $array_of_stats;
+
+$userlist = [];
+Hook::run(HOOKTYPE_GET_USER_LIST, $userlist);
+$num_of_panel_admins = count($userlist);
+
+?>
+<div class="container">
+
+       <div class="row mt-3">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-success text-white">
                                        <div class="row">
                                                <div class="col">
-                                                       <i class="fa fa-users fa-3x"></i>
+                                                       <i class="fa fa-users fa-3x"></i><span class="position-absolute badge rounded-pill badge-warning">
+                                                       <?php echo "Record: ".$stats->user->record; ?>
+                                               </span>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$user); ?></h3>
+                                                       <h3 id="stats_user_total" class="display-4"><?php echo $stats->user->total; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -31,8 +50,10 @@ rpc_pop_lists();
                                        </div>
                                </div>
                        </div>
+                       
+
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-primary text-white">
                                        <div class="row">
@@ -40,7 +61,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-hashtag fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$channel); ?></h3>
+                                                       <h3 id="stats_channel_total" class="display-4"><?php echo $stats->channel->total; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -54,7 +75,7 @@ rpc_pop_lists();
                                </div>
                        </div>
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-warning">
                                        <div class="row">
@@ -62,7 +83,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-shield-halved fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo RPC_List::$opercount; ?></h3>
+                                                       <h3 id="stats_oper_total" class="display-4"><?php echo $stats->user->oper; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -71,14 +92,13 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Opers</h6>
                                                </div>
-                                               <!-- TODO: Filter opers in user list and make this do that -->
-                                               <div class="col"><a class="btn btn-secondary disabled" href="#">View</a></div>
+                                               <div class="col"><a class="btn btn-primary" href="<?php echo BASE_URL."users/?operonly"; ?>">View</a></div>
                                        </div>
                                </div>
                        </div>
                </div>
 
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-secondary text-white">
                                        <div class="row">
@@ -86,7 +106,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-network-wired fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$server); ?></h3>
+                                                       <h3 id="stats_server_total" class="display-4"><?php echo $stats->server->total; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -95,7 +115,7 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Servers</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>network">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>servers">View</a></div>
                                        </div>
                                </div>
                        </div>
@@ -105,7 +125,7 @@ rpc_pop_lists();
 <div class="container mt-3">
 
        <div class="row">
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-danger text-white">
                                        <div class="row">
@@ -113,7 +133,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-ban fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$tkl); ?></h3>
+                                                       <h3 id="num_server_bans" class="display-4"><?php echo $stats->server_ban->server_ban; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -122,12 +142,12 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Server Bans</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>server_bans.php">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>server-bans">View</a></div>
                                        </div>
                                </div>
                        </div>
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-secondary text-white">
                                        <div class="row">
@@ -135,7 +155,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-filter fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$spamfilter); ?></h3>
+                                                       <h3 id="num_spamfilter_entries" class="display-4"><?php echo $stats->server_ban->spamfilter; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -149,7 +169,7 @@ rpc_pop_lists();
                                </div>
                        </div>
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-primary text-white">
                                        <div class="row">
@@ -157,7 +177,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-door-open fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$exception); ?></h3>
+                                                       <h3 id="num_ban_exceptions" class="display-4"><?php echo $stats->server_ban->server_ban_exception; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -167,16 +187,20 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Server Ban Exceptions</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-secondary disabled" href="#">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>server-bans/ban-exceptions.php">View</a></div>
                                        </div>
                                </div>
                        </div>
                </div>
                <?php
-               if (RPC_List::$services_count) {
+               if ($stats->server->ulined) {
                        $bg = "bg-success";
-               } ?> 
-               <div class="col-sm">
+                       $tooltip = "Users / Servers";
+               }
+               else
+                       $bg = "bg-warning";
+               ?> 
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header <?php echo $bg; ?> text-white">
                                        <div class="row">
@@ -184,7 +208,8 @@ rpc_pop_lists();
                                                        <i class="fa fa-database fa-3x"> </i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo RPC_List::$services_count; ?></h3>
+                                               <span data-toggle="tooltip" title="<?php echo $tooltip; ?>" style="border-bottom: 1px dotted #000000">
+                                               <h3 id="stats_uline_total" class="display-4"><?php echo $stats->user->ulined; ?>/<?php echo $stats->server->ulined; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -193,7 +218,7 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Services Online</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-secondary disabled" href="#">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL."users/?servicesonly"; ?>">View</a></div>
                                        </div>
                                </div>
                                
@@ -202,6 +227,59 @@ rpc_pop_lists();
        </div>
 </div>
 
+
+<script>
+    function updateStats() {
+        var xhttp = new XMLHttpRequest();
+        xhttp.onreadystatechange = function() {
+            if (this.readyState == 4 && this.status == 200) {
+                var data = JSON.parse(this.responseText);
+                document.getElementById("stats_user_total").innerHTML = data.user.total;
+                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;
+                               document.getElementById("num_server_bans").innerHTML = data.server_ban.server_ban;
+                               document.getElementById("num_spamfilter_entries").innerHTML = data.server_ban.spamfilter;
+                               document.getElementById("num_ban_exceptions").innerHTML = data.server_ban.server_ban_exception;
+                               document.getElementById("stats_uline_total").innerHTML = data.user.ulined + "/" + data.server.ulined;
+            }
+        };
+        xhttp.open("GET", "api/overview.php", true);
+        xhttp.send();
+    }
+    updateStats();
+    setInterval(updateStats, 1000); // Update stats every second
+</script>
+
+<div class="container mt-3">
+
+                       <div class="row">
+                               <div class="col-sm-3">
+                                       <div class="card text-center">
+                                               <div class="card-header bg-success text-white">
+                                                       <div class="row">
+                                                               <div class="col">
+                                                                       <i class="fa fa-lock-open fa-3x"></i>
+                                                               </div>
+                                                               <div class="col">
+                                                                       <h3 class="display-4"><?php echo $num_of_panel_admins; ?></h3>
+                                                               </div>
+                                                       </div>
+                                               </div>
+                                               <div class="card-body">
+                                                       <div class="row">
+                                                               <div class="col">
+                                                                       <h6>Panel Access</h6>
+                                                               </div>
+                                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>settings">View</a></div>
+                                                       </div>
+                                               </div>
+                                       </div>
+                               </div>
+                       </div>
+               </div>  
 <?php
 
+Hook::run(HOOKTYPE_OVERVIEW_CARD, $stats);
+
 require_once "footer.php";