initial release (duration not working correctly)

master
Dominic Reich 4 years ago
commit 4ae8b40561

@ -0,0 +1,24 @@
<?php
if (isset($_GET['debug'])) {
define("DEBUG", true);
}
if (isset($_GET['full'])) {
define("MAXENTRIES", 1000);
define("MAXLOGENTRIES", MAXENTRIES * 5);
} else {
define("MAXENTRIES", 20);
define("MAXLOGENTRIES", MAXENTRIES * 5);
//define("MAXLOGENTRIES", 500);
}
// default values for files etc...
define("MMDVM_INI", "/etc/MMDVM.ini");
define("YSFGW_INI", "/etc/YSFGateway.ini");
define("APRS_INI", "/etc/APRSGateway.ini");
define("LOGPATH", "/var/log/mmdvm");
define("MMDVM_PREFIX", "MMDVM");
define("YSFGW_PREFIX", "YSFGateway");
define("APRSGW_PREFIX","APRSGateway");
?>

370
dash.min.css vendored

@ -0,0 +1,370 @@
/*!
* CSS File for OE7DRT Dashboard
*/
#toptable, #lhtable {
margin-bottom: 0.5em;
}
.container {
width: 95%;
text-align: left;
margin: auto;
background : #ffffff;
border-radius: 10px 10px 10px 10px;
-moz-border-radius: 10px 10px 10px 10px;
-webkit-border-radius: 10px 10px 10px 10px;
-khtml-border-radius: 10px 10px 10px 10px;
-ms-border-radius: 10px 10px 10px 10px;
box-shadow: 3px 3px 3px #707070;
}
body, font {
font: 12px verdana,arial,sans-serif;
color: #ffffff;
}
.header {
background : #2d2d2d;
text-decoration : none;
color : #ffffff;
font-family : verdana, arial, sans-serif;
text-align : left;
padding : 5px 5px 5px 5px;
border-radius: 10px 10px 0 0;
-moz-border-radius: 10px 10px 0px 0px;
-webkit-border-radius: 10px 10px 0px 0px;
-khtml-border-radius: 10px 10px 0px 0px;
-ms-border-radius: 10px 10px 0px 0px;
overflow-wrap: break-word;
}
.content {
padding : 5px 5px 5px 5px;
color : #000000;
background : #ffffff;
text-align: center;
font-size: 1.4em;
overflow: auto;
}
.contentwide {
padding: 5px 5px 5px 5px;
color: #000000;
background: #ffffff;
text-align: center;
font-size: 1.4em;
}
.contentwide h2 {
color: #000000;
font: 1em verdana,arial,sans-serif;
text-align: center;
font-weight: bold;
padding: 0px;
margin: 0px;
}
.footer {
background : #2d2d2d;
text-decoration : none;
color : #ffffff;
font-family : verdana, arial, sans-serif;
font-size : 9px;
text-align : center;
padding : 10px 5px 10px 5px;
border-radius: 0 0 10px 10px;
-moz-border-radius: 0px 0px 10px 10px;
-webkit-border-radius: 0px 0px 10px 10px;
-khtml-border-radius: 0px 0px 10px 10px;
-ms-border-radius: 0px 0px 10px 10px;
clear : both;
overflow-wrap: break-word;
}
#tail {
height: 450px;
width: 805px;
overflow-y: scroll;
overflow-x: scroll;
color: #00ff00;
background: #000000;
}
table {
vertical-align: middle;
text-align: center;
empty-cells: show;
padding-left: 0px;
padding-right: 0px;
padding-top: 0px;
padding-bottom: 0px;
border-collapse:collapse;
border-color: #000000;
border-style: solid;
border-spacing: 4px;
border-width: 2px;
text-decoration: none;
color: #ffffff;
background: #000000;
font-family: verdana,arial,sans-serif;
width: 80%;
white-space: nowrap;
}
table th {
font-family: "Lucidia Console",Monaco,monospace;
text-shadow: 1px 1px #3d3d3d;
text-decoration: none;
background: #2d2d2d;
border: 1px solid #c0c0c0;
}
table tr:nth-child(even) {
background: #f7f7f7;
}
table tr:nth-child(odd) {
background: #d0d0d0;
}
table td {
color: #000000;
font-family: "Lucidia Console",Monaco,monospace;
text-decoration: none;
border: 1px solid #000000;
overflow-x: hidden;
}
body {
background: #edf0f5;
color: #000000;
}
a {
text-decoration:none;
}
a:link, a:visited {
text-decoration: none;
color: #0000e0;
font-weight: normal;
}
a.tooltip, a.tooltip:link, a.tooltip:visited, a.tooltip:active {
text-decoration: none;
position: relative;
color: #FFFFFF;
}
a.tooltip:hover {
text-shadow: none;
text-decoration: none;
color: #FFFFFF;
background: transparent;
}
a.tooltip span {
text-shadow: none;
text-decoration: none;
display: none;
}
a.tooltip:hover span {
text-shadow: none;
text-decoration: none;
display: block;
position: absolute;
top: 20px;
left: 0;
width: 200px;
z-index: 100;
color: #000000;
border:1px solid #000000;
background: #f7f7f7;
font: 12px Verdana, sans-serif;
text-align: left;
}
a.tooltip span b {
text-shadow: none;
text-decoration: none;
display: block;
color: #000000;
margin: 0;
padding: 0;
font-size: 12px;
font-weight: bold;
border: 0px;
border-bottom: 1px solid black;
background: #d0d0d0;
}
a.tooltip2, a.tooltip2:link, a.tooltip2:visited, a.tooltip2:active {
text-shadow: none;
text-decoration: none;
position: relative;
font-weight: bold;
color: #000000;
}
a.tooltip2:hover {
text-shadow: none;
text-decoration: none;
color: #000000;
background: transparent;
}
a.tooltip2 span {
text-shadow: none;
text-decoration: none;
display: none;
}
a.tooltip2:hover span {
text-shadow: none;
text-decoration: none;
display: block;
position: absolute;
top: 20px;
left: 0;
width: 200px;
z-index: 100;
color: #000000;
border:1px solid #000000;
background: #f7f7f7;
font: 12px Verdana, sans-serif;
text-align: left;
}
a.tooltip2 span b {
text-shadow: none;
text-decoration: none;
display: block;
color: #000000;
margin: 0;
padding: 0;
font-size: 12px;
font-weight: bold;
border: 0px;
border-bottom: 1px solid black;
background: #d0d0d0;
}
ul {
padding: 5px;
margin: 10px 0;
list-style: none;
float: left;
}
ul li {
float: left;
display: inline; /*For ignore double margin in IE6*/
margin: 0 10px;
}
ul li a {
text-decoration: none;
float:left;
color: #999;
cursor: pointer;
font: 900 14px/22px "Arial", Helvetica, sans-serif;
}
ul li a span {
margin: 0 10px 0 -10px;
padding: 1px 8px 5px 18px;
position: relative; /*To fix IE6 problem (not displaying)*/
float:left;
}
ul.mmenu li a.current, ul.mmenu li a:hover {
background: url(/images/buttonbg.png) no-repeat top right;
color: #0d5f83;
}
ul.mmenu li a.current span, ul.mmenu li a:hover span {
background: url(/images/buttonbg.png) no-repeat top left;
}
h1 {
text-shadow: 2px 2px #000000;
text-align: center;
}
/* CSS Toggle Code here */
.toggle {
position: absolute;
margin-left: -9999px;
visibility: hidden;
}
.toggle + label {
display: block;
position: relative;
cursor: pointer;
outline: none;
}
input.toggle-round-flat + label {
padding: 1px;
width: 33px;
height: 18px;
background-color: #dddddd;
border-radius: 10px;
transition: background 0.4s;
}
input.toggle-round-flat + label:before,
input.toggle-round-flat + label:after {
display: block;
position: absolute;
content: "";
}
input.toggle-round-flat + label:before {
top: 1px;
left: 1px;
bottom: 1px;
right: 1px;
background-color: #fff;
border-radius: 10px;
transition: background 0.4s;
}
input.toggle-round-flat + label:after {
top: 2px;
left: 2px;
bottom: 2px;
width: 16px;
background-color: #dddddd;
border-radius: 12px;
transition: margin 0.4s, background 0.4s;
}
input.toggle-round-flat:checked + label {
background-color: #2d2d2d;
}
input.toggle-round-flat:checked + label:after {
margin-left: 14px;
background-color: #2d2d2d;
}
/* Tame Firefox Buttons */
@-moz-document url-prefix() {
select,
input {
margin : 0;
padding : 0;
border-width : 1px;
font : 12px verdana,arial,sans-serif;
}
input[type="button"], button, input[type="submit"] {
padding : 0px 3px 0px 3px;
border-radius : 3px 3px 3px 3px;
-moz-border-radius : 3px 3px 3px 3px;
}
}

@ -0,0 +1,160 @@
<?php
function linkCallsign( $callsign ) {
$call = $callsign;
$tmp = explode( "-", $callsign );
$call = $tmp[0];
$suffix = $tmp[1];
if( !empty( $suffix )) {
$suffix="-$suffix";
}
if( !is_numeric( $call )) {
$call = "<a href=\"https://qrz.com/db/$call\" target=\"_blank\">$call" . "</a>$suffix";
} elseif( strlen( $call ) == 7 ) {
$call = "<a href=\"https://ham-digital.org/dmr-userreg.php?usrid=$call\"" . " target=\"_blank\">$call</a>";
}
return $call;
}
function rssiCalc( $val ) {
if( $val > -53 ) $rssi = "S9+40dB";
else if( $val > -63 ) $rssi = "S9+30dB";
else if( $val > -73 ) $rssi = "S9+20dB";
else if( $val > -83 ) $rssi = "S9+10dB";
else if( $val > -93 ) $rssi = "S9";
else if( $val > -99 ) $rssi = "S8";
else if( $val > -105 ) $rssi = "S7";
else if( $val > -111 ) $rssi = "S6";
else if( $val > -117 ) $rssi = "S5";
else if( $val > -123 ) $rssi = "S4";
else if( $val > -129 ) $rssi = "S3";
else if( $val > -135 ) $rssi = "S2";
else if( $val > -141 ) $rssi = "S1";
return "$rssi ($val dBm)";
}
function printTable( $time, $callsign, $dgid, $duration, $repeater, $loss = "0", $ber = "0" ) {
echo " <tr>\n" .
"<td>$time</td>\n" .
"<td>" . linkCallsign( $callsign ) ."</td>\n" .
"<td>$dgid</td>\n" .
"<td>$duration</td>\n" .
"<td>$repeater</td>\n" .
"<td>$loss</td>\n" .
"<td>$ber</td>\n" .
"</tr>\n";
}
function getLastHeard($limit = MAXENTRIES) {
$logPath = LOGPATH."/".MMDVM_PREFIX."-*.log";
//$logLines = explode( "\n", `egrep -h "network (data|watchdog)|RF end" $logPath | tail -$limit` );
//$logLines = explode( "\n", `egrep -h "YSF" $logPath | tail -$limit` );
$logLines = explode( "\n", `egrep -h "YSF" $logPath` );
$oldline = "";
$time = "";
$loss = "";
$ber = "";
$rssi = "";
$call = "";
$duration = "";
$repeater = "";
//$key = 0;
$printLines = [];
//$old_time = "";
$new_time = "";
foreach( $logLines as $line ) {
$time = date( "Y-m-d H:i:s", strtotime( substr( $line, 3, 23 )." UTC" ));
if( strpos( $line, "network data" )) {
//if( empty( $old_time )) {
if( !strpos( $oldline, "network data" )) {
$old_time = strtotime( substr( $line, 3, 19 ));
}
//$old_time = substr( $line, 3, 23 );
//}
$oldline = $line;
} else {
if( strpos( $line, "network watchdog" )) {
$callsign = substr( $oldline, 59, strpos( $oldline, "to" ) - 59 );
$dgid = substr( $oldline, 79, strpos( $oldline, "at " ) - 79 );
//$duration = substr( $line, 62, strpos( $line, "seconds,", 62 ) - 62 ) . "sec";
//$duration = substr( $line, 62, strpos( $line, "seconds,", 62 ) - 62 );
$new_time = strtotime( substr( $oldline, 3, 19 ));
//$new_time = substr( $line, 3, 19 );
//$duration = floatval( $new_time - $old_time );
$duration = round( floatval(( $new_time - $old_time )), 1);
//$duration = date("i:s", floatval( $new_time - $old_time ) / 100000 );
//$old_time = "";
echo "<pre><code>$time\nold_time: $old_time\nnew_time: $new_time\n$callsign</code></pre>";
$repeater = substr( $oldline, strpos( $oldline, "at " ) + 3, strpos( $oldline, " ", strpos( $oldline, "at " ) + 3) - strpos( $oldline, "at " ) + 3 );
$loss = substr( $line, 75, strpos( $line, "%", 75 ) - 74 );
$ber = substr( $line, 96, strpos( $line, "%", 96 ) - 95 );
} elseif( strpos( $line, "RF end of" )) {
$oldline = "";
$callsign = substr( $line, 69, strpos( $line, "to" ) - 69 );
$dgid = substr( $line, 89, strpos( $line, ",", 89 ) - 89 );
$duration = trim( substr( $line, 92, strpos( $line, "seconds,", 92 ) - 92 ), " ,");
$rssi_values = explode( "/", substr( $line, 113, strpos( $line, "dBm", 113 ) - 113 ));
$rssi = rssiCalc( round( array_sum( $rssi_values ) / count( $rssi_values )));
$loss = "---";
$ber = substr( $line, 111, strpos( $line, ",", 111 ) - 111 );
if( empty( $ber )) $ber = "---";
$repeater = $rssi; // use this testwise, debug
} else {
$oldline = "";
continue;
}
$tmp = [];
$tmp['time'] = $time;
$tmp['callsign'] = $callsign;
$tmp['dgid'] = $dgid;
$tmp['duration'] = $duration;
$tmp['repeater'] = $repeater;
$tmp['loss'] = $loss;
$tmp['ber'] = $ber;
array_unshift( $printLines, $tmp );
unset( $tmp );
} // end if clauses
} // end foreach
$c = 0;
foreach( $printLines as $key=>$line ) {
printTable(
$line['time'],
$line['callsign'],
$line['dgid'],
$line['duration'],
$line['repeater'],
$line['loss'],
$line['ber']
);
if( ++$c >= MAXENTRIES ) break;
} // end foreach $printLines
} // end function
function printLogs($limit = MAXLOGENTRIES) {
$logPath = LOGPATH."/*-".gmdate("Y-m-d").".log";
$logLines = explode("\n", `tail -n $limit $logPath`);
echo "\n<!-- start logfile output -->\n<h2>DEBUG LOGFILES OUTPUT</h2>\n";
echo "<div style=\"text-align:left;font-size:0.8em;\"><code><pre>\n";
foreach( $logLines as $line ) {
if ( substr( $line, 0, 4) == "==> " ) {
echo "<strong style=\"font-size:1.3em;\">$line</strong>\n";
} else {
echo "$line\n";
}
}
echo "\n</pre></code></div>\n<!-- end logfile output -->\n\n";
return 0;
}

@ -0,0 +1,86 @@
<?php
$time_start = microtime(true);
include("conf.php");
include("func.php");
?><html>
<head>
<meta name=viewport content="width=device-width,initial-scale=1">
<meta name=generator content="Sublime Text 3 / Vim">
<meta name="author" content="Dominic Reich">
<title>OE7DRT Hotspot Dashboard</title>
<link rel="stylesheet" type="text/css" media="screen" href="dash.min.css" />
<meta http-equiv="refresh" content="60">
</head>
<body>
<div class="container">
<div class="header">
<div style="font-size: 0.9em; text-align: left; padding-left: 8px; float: left;">
Hostname: <?php echo trim(`hostname`); ?> (<?php echo trim(`hostname -I | cut -d' ' -f1`); ?>)<br />
<?php
$iniFile = YSFGW_INI;
$logline = `egrep -h Options $iniFile | tail -n 1`;
//$options = substr($logline, strpos($logline, "Options="));
$optionsLine = explode( "=", $logline );
$DGIDs = explode( ",", $optionsLine[1] );
echo "Static DG-IDs: ";
foreach( $DGIDs as $DGID ) {
echo "$DGID ";
}
?>
</div>
<div style="font-size: 0.9em; text-align: right; padding-right: 8px;"><?php echo date("d.m.Y H:i:s T"); ?></div>
<a href="/" style="color: #ffffff;"><h1>Dashboard for YSF Hotspot OE7DRT</h1></a>
<p style="padding-right: 5px; text-align: right; color: #ffffff;">
<a href="/" style="color: #ffffff;">Dashboard</a>
| <a href="http://49.12.77.74/ysf-reflector/" style="color: #ffffff;" target="_blank">
YSF-<strong>Test</strong>-Reflector Dashboard</a>
</p>
<div style="font-size: 8px; text-align: left; padding-left: 8px; ">
</div>
</div>
<div class="content">
<table id="toptable" align="center">
<tr>
<th>Model</th>
<th>CPU Freq.</th>
<th>Load</th>
<th>Temp.</th>
</tr>
<tr>
<td><?php echo trim( `cat /sys/firmware/devicetree/base/model` ); ?> (<?php echo trim( `uname -sr` ); ?>)</td>
<td><?php echo round((int)`cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq` / 1000) . " MHz"; ?></td>
<td><?php echo str_replace(","," /",implode(", ", explode(" ", `cat /proc/loadavg`, -2))); ?></td>
<td><?php echo round((int)`cat /sys/class/thermal/thermal_zone0/temp` / 1000) . "°C"; ?></td>
</tr>
</table>
<table align="center">
<tr>
<th>Time (<?php echo date("T"); ?>)</th>
<!-- <th>Mode</th> -->
<th>Callsign</th>
<th>DG-ID</th>
<th>Dur(s)</th>
<th>Source/Repeater</th>
<th>Loss</th>
<th>BER</th>
</tr>
<?php
getLastHeard();
?>
</table>
<?php
!defined("DEBUG") ?: printLogs();
//printLogs();
?>
</div>
<div class="footer">
This dashboard has been put together by
<a href="https://oe7drt.com/" style="color: #ffffff;">Dominic, OE7DRT</a>.
It looks like Pi-Star. Just in case you did not notice ;-)
</div>
</body>
</html>
<!-- <?php $time_end = microtime(true); echo (round($time_end - $time_start, 3)*1000)." ms execution time"; ?> -->
Loading…
Cancel
Save