286 lines
6.5 KiB
PHP
286 lines
6.5 KiB
PHP
|
<?
|
||
|
/*
|
||
|
Jorge - frontend for mod_logdb - ejabberd server-side message archive module.
|
||
|
|
||
|
Copyright (C) 2009 Zbigniew Zolkiewski
|
||
|
|
||
|
This program is free software; you can redistribute it and/or
|
||
|
modify it under the terms of the GNU General Public License
|
||
|
as published by the Free Software Foundation; either version 2
|
||
|
of the License, or (at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License
|
||
|
along with this program; if not, write to the Free Software
|
||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
|
||
|
*/
|
||
|
require_once("headers.php");
|
||
|
require_once("upper.php");
|
||
|
|
||
|
if (ADMIN_NAME !== TOKEN) {
|
||
|
|
||
|
print 'no access';
|
||
|
exit;
|
||
|
|
||
|
}
|
||
|
|
||
|
// vhost stats
|
||
|
$vhost_selected = $_POST['stats_vhost'];
|
||
|
if (array_key_exists($vhost_selected, $vhosts) === true) {
|
||
|
|
||
|
$vhost_valid = true;
|
||
|
$vhost_active = $vhost_selected;
|
||
|
|
||
|
}
|
||
|
else{
|
||
|
|
||
|
$vhost_valid = false;
|
||
|
$vhost_active = null;
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('<form name="stats_form" method="post"><b>'.$stats_vhost_select[$lang].' </b><select class="settings" name="stats_vhost" onchange="javascript:document.stats_form.submit();">
|
||
|
<option value="null">'.$vhost_select[$lang].'</option>
|
||
|
');
|
||
|
|
||
|
while (array_keys($vhosts)) {
|
||
|
|
||
|
$vhost = key($vhosts);
|
||
|
if ($_POST['stats_vhost'] == $vhost) {
|
||
|
|
||
|
$marked_vhost="selected=\"selected\"";
|
||
|
|
||
|
}
|
||
|
else {
|
||
|
|
||
|
unset($marked_vhost);
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('<option value="'.$vhost.'" '.$marked_vhost.'>'.$vhost.'</option>');
|
||
|
array_shift($vhosts);
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('</select></form>');
|
||
|
|
||
|
if ($vhost_valid === true) {
|
||
|
|
||
|
|
||
|
$db->total_messages($vhost_active);
|
||
|
$total_messages = $db->result;
|
||
|
$html->set_body('<h2><u>'.$stats_for[$lang].$vhost_active.'</u></h2><p style="padding-left: 10px;">
|
||
|
'.$stats_messages[$lang].' <b>'.number_format($total_messages[1][total_messages]).'</b>
|
||
|
'.$stats_messages_b[$lang].'<b>'.number_format($total_messages[1][total_chats]).'</b>'.$stats_messages_c[$lang].'</b></p>
|
||
|
<hr size="1" noshade="noshade" style="color: #cccccc;">');
|
||
|
|
||
|
// get dates
|
||
|
$today = date("Y-n-j");
|
||
|
$yesterday = date("Y-n-j", strtotime("-1 day"));
|
||
|
$last_week = date("Y-n-j", strtotime("-7 days"));
|
||
|
for ($ds=0;$ds<=4;$ds++) {
|
||
|
|
||
|
$days[$ds] = date("Y-n-j", strtotime("-$ds day"));
|
||
|
|
||
|
}
|
||
|
|
||
|
// Top 10
|
||
|
$html->set_body('<table class="ff" cellpadding="0" cellspacing="0" style="display:inline;">
|
||
|
<tr><td><b>'.$stats_top[$lang].'</b></td></tr><tr><td style="width:420px; border: 0px; vertical-align: top;">');
|
||
|
foreach ($days as $current_day) {
|
||
|
|
||
|
$i=0;
|
||
|
$html->set_body('<b>'.verbose_date($current_day,$months_names,$weekdays,true).' :</b><br>');
|
||
|
$db->get_top_ten($current_day,$vhost_active);
|
||
|
$result = $db->result;
|
||
|
foreach ($result as $entry) {
|
||
|
|
||
|
$i++;
|
||
|
$db->get_user_name($entry[owner_id],$vhost_active);
|
||
|
$local_user = $db->result->username;
|
||
|
$db->get_user_name($entry[peer_name_id],$vhost_active);
|
||
|
$peer_name = $db->result->username;
|
||
|
$db->get_server_name($entry[peer_server_id],$vhost_active);
|
||
|
$peer_server = $db->result->server_name;
|
||
|
$html->set_body('
|
||
|
<b>'.$i.'.</b> '.htmlspecialchars($local_user).'@'.$vhost_active.'<b> --> </b>
|
||
|
'.htmlspecialchars($peer_name).'@'.htmlspecialchars($peer_server).' (<i><b>'.$entry[count].'</b></i>)<br>
|
||
|
');
|
||
|
|
||
|
}
|
||
|
$html->set_body('<br>');
|
||
|
|
||
|
}
|
||
|
$html->set_body('</td></tr></table>');
|
||
|
|
||
|
// get data for graphs. We can now draw data only if we have full array. This is known issue.
|
||
|
$db->get_monthly_stats($vhost_active);
|
||
|
$result = $db->result;
|
||
|
|
||
|
if (count($result)<30) {
|
||
|
|
||
|
$html->status_message($stats_not_eno[$lang]);
|
||
|
|
||
|
}
|
||
|
else {
|
||
|
|
||
|
|
||
|
foreach ($result as $entry) {
|
||
|
|
||
|
$i++;
|
||
|
$f[$i] = $entry[time_unix];
|
||
|
$d[$i] = $entry[messages];
|
||
|
$e[$i] = $entry[users_total];
|
||
|
|
||
|
}
|
||
|
|
||
|
// hourly stats
|
||
|
$db->get_hourly_stats($yesterday,$vhost_active);
|
||
|
$result = $db->result;
|
||
|
foreach ($result as $entry) {
|
||
|
|
||
|
$hs[$entry[hour]] = $entry[value];
|
||
|
}
|
||
|
|
||
|
// weekly stats
|
||
|
$db->get_weekly_stats($last_week,$yesterday,$vhost_active);
|
||
|
$result = $db->result;
|
||
|
foreach ($result as $entry) {
|
||
|
|
||
|
$idx++;
|
||
|
$hy[$idx] = $entry[value];
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('<table class="ff" cellpadding="0" cellspacing="0" style="display:inline;">
|
||
|
<tr>
|
||
|
<td style="padding-left: 10px vertical-align: top;">
|
||
|
<div id="no_users" style="width:800px;height:200px;"></div><br>
|
||
|
<div id="no_messages" style="width:800px;height:200px;"></div><br>
|
||
|
<div id="hourly_yesterday" style="width:800px;height:200px;"></div><br>
|
||
|
<div id="hourly_week" style="width:800px;height:200px;"></div>
|
||
|
</td>
|
||
|
</table>
|
||
|
<script id="source" language="javascript" type="text/javascript">
|
||
|
$(function () {
|
||
|
|
||
|
var d1 = [
|
||
|
|
||
|
');
|
||
|
|
||
|
$cn=31;
|
||
|
for ($z=1;$z<31;$z++) {
|
||
|
|
||
|
$cn--;
|
||
|
$html->set_body("[$f[$cn],$e[$cn]],");
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('
|
||
|
|
||
|
|
||
|
];
|
||
|
|
||
|
var d2 = [
|
||
|
|
||
|
');
|
||
|
|
||
|
$cn=31;
|
||
|
for ($z=1; $z<31; $z++) {
|
||
|
|
||
|
$cn--;
|
||
|
$html->set_body("[$f[$cn],$d[$cn]],");
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('
|
||
|
|
||
|
|
||
|
];
|
||
|
|
||
|
var d3 = [
|
||
|
|
||
|
');
|
||
|
|
||
|
for ($z=0;$z<24;$z++) {
|
||
|
|
||
|
$html->set_body("[$z,$hs[$z]],");
|
||
|
|
||
|
}
|
||
|
|
||
|
$html->set_body('
|
||
|
|
||
|
];
|
||
|
|
||
|
var d4 = [
|
||
|
');
|
||
|
|
||
|
$idx=0;
|
||
|
for ($z=0;$z<168;$z++) {
|
||
|
|
||
|
$idx++;
|
||
|
$html->set_body("[$z,$hy[$idx]],");
|
||
|
}
|
||
|
|
||
|
$html->set_body('
|
||
|
|
||
|
];
|
||
|
|
||
|
$.plot($("#no_users"), [{
|
||
|
|
||
|
xaxis: {
|
||
|
mode: "time"
|
||
|
},
|
||
|
color: "#ff0000",
|
||
|
label: "'.$stats_graph1[$lang].'",
|
||
|
data: d1,
|
||
|
shadowSize: 10,
|
||
|
lines: { show: true, fill: true },
|
||
|
points: { show: true, fill: true, radius: 3}
|
||
|
}]);
|
||
|
|
||
|
$.plot($("#no_messages"), [{
|
||
|
|
||
|
xaxis: { mode: "time" },
|
||
|
color: "#3480ff",
|
||
|
label: "'.$stats_graph2[$lang].'",
|
||
|
shadowSize: 10,
|
||
|
data: d2,
|
||
|
lines: { show: true, fill: true },
|
||
|
points: { show: true, fill: true, radius: 3}
|
||
|
|
||
|
}]);
|
||
|
|
||
|
$.plot($("#hourly_yesterday"), [{
|
||
|
|
||
|
color: "#ff0000",
|
||
|
label: "'.$stats_graph3[$lang].' ('.$yesterday.')", shadowSize: 10, data: d3,
|
||
|
bars: { show: true }
|
||
|
}]);
|
||
|
|
||
|
$.plot($("#hourly_week"), [{
|
||
|
|
||
|
color: "#3480ff",
|
||
|
label: "'.$stats_graph4[$lang].' ('.$last_week.' - '.$yesterday.')", shadowSize: 10, data: d4,
|
||
|
bars: { show: true }
|
||
|
|
||
|
}]);
|
||
|
|
||
|
});
|
||
|
|
||
|
</script>
|
||
|
|
||
|
');
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
require_once("footer.php");
|
||
|
?>
|