This repository has been archived by the owner on Sep 13, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathrefreshInQSO.php
95 lines (86 loc) · 3.54 KB
/
refreshInQSO.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php include "ircddblocal.php"; ?>
<?php include "tools.php"; ?>
<tbody>
<tr>
<th class="calls">Date & Time (UTC)</th>
<th class="calls">Call</th>
<th class="calls">Frames (s)</th>
<th class="calls">Loss (%)/BER (%)</th>
</tr>
<?php // Headers.log sample:
// 00000000001111111111222222222233333333334444444444555555555566666666667777777777888888888899999999990000000000111111111122
// 01234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901
// M: 2015-08-18 19:23:48: Transmitting to - My: DL1ESZ /5100 Your: CQCQCQ Rpt1: DG9VH G Rpt2: DG9VH B Flags: 00 00 00
// M: 2015-08-18 19:24:40: Stats for DL1ESZ Frames: 17.8s, Loss: 1.2%, Packets: 11/890
// M: 2015-10-06 07:33:41: AMBE for DG9VH Frames: 5.3s, Silence: 0.0%, BER: 0.0%
exec('(grep -v " /TIME" '.DSTARREPEATERLOGPATH.'/'.DSTARREPEATERLOGFILENAME.'$(date --utc +%Y-%m-%d).log|egrep -h "Stats|AMBE"|sort -r -k3,9 |sort -u -k6,6|sort -r|head -10 >'.TMPPATH.'/qsoinfo.log) 2>&1 &');
$ci = 0;
if ($QSOInfoLog = fopen(TMPPATH."/qsoinfo.log",'r')) {
while ($linkLine = fgets($QSOInfoLog)) {
if(preg_match_all('/^(.{22}).*Stats for (.*).*Frames: (.*).*s, Loss: (.*).*%, Packets:(.*)/',$linkLine,$linx) > 0){
$QSODate = substr($linx[1][0],3,21);
$MyCall = getAnonymizedValue(substr($linx[2][0],0,8));
$Frames = $linx[3][0];
$Loss = $linx[4][0];
$UTC = new DateTimeZone("UTC");
$d1 = new DateTime($QSODate, $UTC);
$d2 = new DateTime();
$diff = $d2->diff($d1);
if ($Frames>3 && $diff->y==0 && $diff->m==0 && $diff->d==0 && $diff->h==0 && $diff->i<10 ) {
$ci++;
if($ci > 1) { $ci = 0; }
print "<tr class=\"row".$ci."\">";
print "<td>$QSODate</td>";
if (SHOWQRZ AND !ANONYMIZE)
print "<td><a title=\"Ask QRZ.com about $MyCall\" href=\"http://qrz.com/db/$MyCall\">".trim($MyCall)."</a></td>";
else
print "<td>$MyCall</td>";
print "<td>$Frames</td>";
print "<td>";
if (SHOWPROGRESSBARS) {
?>
<div class="progress"><div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="<?php echo $Loss; ?>" aria-valuemin="0" aria-valuemax="100" style="width: <?php echo $Loss; ?>%;"><?php echo $Loss; ?></div></div>
<?php
} else {
echo $Loss;
}
print "</td>";
print "</tr>";
}
}
if(preg_match_all('/^(.{22}).*AMBE for (.*).*Frames: (.*).*s, Silence: (.*).*%, BER:(.*)/',$linkLine,$linx) > 0){
$QSODate = substr($linx[1][0],3,21);
$MyCall = substr($linx[2][0],0,8);
$Frames = $linx[3][0];
$BER = $linx[4][0];
$UTC = new DateTimeZone("UTC");
$d1 = new DateTime($QSODate, $UTC);
$d2 = new DateTime();
$diff = $d2->diff($d1);
if ($Frames>3 && $diff->y==0 && $diff->m==0 && $diff->d==0 && $diff->h==0 && $diff->i<10 ) {
$ci++;
if($ci > 1) { $ci = 0; }
print "<tr class=\"row".$ci."\">";
print "<td>$QSODate</td>";
if (SHOWQRZ)
print "<td><a title=\"Ask QRZ.com about $MyCall\" href=\"http://qrz.com/db/$MyCall\">".trim($MyCall)."</a></td>";
else
print "<td>$MyCall</td>";
print "<td>$Frames</td>";
print "<td>";
if (SHOWPROGRESSBARS) {
?>
<div class="progress"><div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="<?php echo $BER; ?>" aria-valuemin="0" aria-valuemax="100" style="width: <?php echo $BER; ?>%;"><?php echo $BER; ?></div></div>
<?php
} else {
echo $BER;
}
print "</td>";
print "</tr>";
}
}
}
fclose($QSOInfoLog);
}
?>
</tbody>