5 |
|
|
6 |
session_start(); |
session_start(); |
7 |
//session_register('alx_sort_krit'); session_register('alx_sort_onfirst'); session_register('alx_sort_loc'); |
//session_register('alx_sort_krit'); session_register('alx_sort_onfirst'); session_register('alx_sort_loc'); |
8 |
$_SESSION['alx_sort_krit'] = $alx_sort_krit; |
if(isset($_SESSION['alx_sort_krit'])) $alx_sort_krit = $_SESSION['alx_sort_krit']; |
9 |
$_SESSION['alx_sort_onfirst'] = $alx_sort_onfirst; |
if(isset($_SESSION['alx_sort_onfirst'])) $alx_sort_onfirst = $_SESSION['alx_sort_onfirst']; |
10 |
$_SESSION['alx_sort_loc'] = $alx_sort_loc; |
if(isset($_SESSION['alx_sort_loc'])) $alx_sort_loc = $_SESSION['alx_sort_loc']; |
11 |
|
|
12 |
$locations = sqlarr('SELECT location FROM client_locations', '', 'location'); |
// fix reload php debug message |
13 |
|
if(!isset($reload)) $reload = 'not set'; |
14 |
|
|
15 |
|
$locations = sqlarr('SELECT location FROM client_locations where enabled="1"', '', 'location'); |
16 |
$locations[] = ''; |
$locations[] = ''; |
17 |
|
|
18 |
if($_SESSION['alx_sort_krit']==null) |
if($_SESSION['alx_sort_krit']==null) |
33 |
function check_online($dat, $bla) |
function check_online($dat, $bla) |
34 |
{ |
{ |
35 |
global $comps; |
global $comps; |
|
global $ssh_port; |
|
36 |
global $mcore_port; |
global $mcore_port; |
37 |
global $ping_timeout; |
global $ping_timeout; |
38 |
if(!isset($comps[$dat['serial']])) return false; |
if(!isset($comps[$dat['serial']])) return false; |
39 |
|
|
|
// first try mcore, then get ssh |
|
40 |
$retval = ping_host($dat['ip'],$mcore_port,$ping_timeout); |
$retval = ping_host($dat['ip'],$mcore_port,$ping_timeout); |
|
if($retval==1) $retval = ping_host($dat['ip'],$ssh_port,$ping_timeout); |
|
41 |
if($retval==0) |
if($retval==0) |
42 |
{ |
{ |
43 |
$comps[$dat['serial']]['online'] = true; |
$comps[$dat['serial']]['online'] = true; |
56 |
|
|
57 |
if($_SESSION['alx_sort_onfirst']) |
if($_SESSION['alx_sort_onfirst']) |
58 |
{ |
{ |
59 |
if($a['online'] && !$b['online']) return -1; |
if(isset($a['online']) && !isset($b['online'])) return -1; |
60 |
if($b['online'] && !$a['online']) return 1; |
if(isset($b['online']) && !isset($a['online'])) return 1; |
61 |
} |
} |
62 |
if($_SESSION['alx_sort_krit']=='hostname') |
if($_SESSION['alx_sort_krit']=='hostname') |
63 |
{ |
{ |
73 |
else return ''; |
else return ''; |
74 |
} |
} |
75 |
|
|
76 |
$comps = sqlarr("select client_serials.serial, client_serials.location, client_serials.mac, cfg_network.hostname, state_connected.mtime from client_serials left join cfg_network on client_serials.serial=cfg_network.serial left join state_connected on client_serials.serial=state_connected.serial", "serial"); |
$comps = sqlarr("select client_serials.serial, client_serials.enabled, client_serials.location, client_serials.mac, cfg_network.hostname, state_connected.mtime, state_connected.netboot from client_serials left join cfg_network on client_serials.serial=cfg_network.serial left join state_connected on client_serials.serial=state_connected.serial", "serial"); |
77 |
|
|
78 |
sqlforeach('SELECT serial, ip, hostname, mac FROM state_connected', 'check_online', null); |
sqlforeach('SELECT state_connected.serial, state_connected.ip, cfg_network.hostname, state_connected.mac FROM state_connected left join cfg_network on cfg_network.serial=state_connected.serial', 'check_online', null); |
79 |
usort($comps, 'sortcomp'); |
usort($comps, 'sortcomp'); |
80 |
echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" |
echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" |
81 |
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'; |
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'; |
82 |
echo '<head>'; |
echo '<head>'; |
83 |
echo '<title>ALX Config - Index</title>'; |
echo '<title>ALX Config - Index</title>'; |
84 |
echo '<script language="JavaScript">'; |
echo '<script language="JavaScript">'; |
91 |
|
|
92 |
if($reload!='off') echo '<body onload="window.setTimeout(\'location.reload()\',60000)">'; |
if($reload!='off') echo '<body onload="window.setTimeout(\'location.reload()\',60000)">'; |
93 |
|
|
|
/* |
|
|
echo '<img src="logo.jpg" align=middle>'; |
|
|
echo '<a href="index.php" style="padding-left:170px; color:#000000;text-decoration:none; font-weight:bold">[REFRESH]</a><br>'; |
|
|
|
|
|
echo '<form action="index.php" method="get" style="margin-top:0px"><b>SORT BY</b> <input onclick="this.form.submit()" type="radio" name="s_krit" value="serial"'.checkif($_SESSION['alx_sort_krit']=='serial').'>serial <input onclick="this.form.submit()" type="radio" name="s_krit" value="hostname"'.checkif($_SESSION['alx_sort_krit']=='hostname').'>hostname'; |
|
|
echo '<input onclick="this.form.submit()" style="margin-left:125px" name="s_on" type="checkbox" value="1"'.checkif($_SESSION['alx_sort_onfirst']).'>online clients on top</form><br>'; |
|
|
*/ |
|
|
|
|
94 |
echo '<form action="index.php" method="get" style="margin:0px">'; |
echo '<form action="index.php" method="get" style="margin:0px">'; |
95 |
echo '<table width=480><tr>'; |
echo '<table width=480><tr>'; |
96 |
echo '<td><img src="pics/logo.jpg"></td>'; |
// print version info |
97 |
|
$version = file_get_contents('./VERSION', FILE_USE_INCLUDE_PATH); |
98 |
|
echo '<td><img src="pics/logo.jpg"><font size="1">v'.$version.'</font></td>'; |
99 |
echo '<td align=right valign=top><a href="index.php" style="color:#000000;text-decoration:none; font-weight:bold">[REFRESH]</a></td>'; |
echo '<td align=right valign=top><a href="index.php" style="color:#000000;text-decoration:none; font-weight:bold">[REFRESH]</a></td>'; |
100 |
echo '</tr><tr>'; |
echo '</tr><tr>'; |
101 |
echo '<td valign=top><b>SORT BY</b> <input onclick="this.form.submit()" type="radio" name="s_krit" value="serial"'.checkif($_SESSION['alx_sort_krit']=='serial').'>serial <input onclick="this.form.submit()" type="radio" name="s_krit" value="hostname"'.checkif($_SESSION['alx_sort_krit']=='hostname').'>hostname<br>'; |
echo '<td valign=top><b>SORT BY</b> <input onclick="this.form.submit()" type="radio" name="s_krit" value="serial"'.checkif($_SESSION['alx_sort_krit']=='serial').'>serial <input onclick="this.form.submit()" type="radio" name="s_krit" value="hostname"'.checkif($_SESSION['alx_sort_krit']=='hostname').'>hostname<br>'; |
113 |
|
|
114 |
|
|
115 |
echo '<table border="1" id="mytab">'; |
echo '<table border="1" id="mytab">'; |
116 |
echo '<thead><tr style="font-weight:bold;background-color:#d5e5ff"><th>edit</th><th colspan=3>serial</th><th width=170>hostname</th><th width=100>ip</th><th width=100>last connected</th>'; |
echo '<thead><tr style="font-weight:bold;background-color:#d5e5ff"><th>edit</th><th colspan=3>serial</th><th width=170>hostname</th><th width=100>ip</th><th width=100>mac</th><th width=100>last connected</th>'; |
117 |
//always enable showversion atm |
echo '<th colspan=2>version</th>'; |
118 |
$showversion = "on"; |
echo '<th width=100>boot</th>'; |
|
if($showversion=='on') echo '<th colspan=2>version</th>'; |
|
119 |
echo '<th width=150>up/down</th></tr></thead><tbody>'; |
echo '<th width=150>up/down</th></tr></thead><tbody>'; |
120 |
|
|
121 |
foreach($comps as $c) |
foreach($comps as $c) |
122 |
{ |
{ |
123 |
if(!$_SESSION['alx_sort_loc'][$c['location']]) Continue; |
if(!$_SESSION['alx_sort_loc'][$c['location']]) Continue; |
124 |
if($c['serial']<0 && !$_SESSION['alx_sort_loc']['DEAD']) Continue; |
if($c['enabled']==0 && !$_SESSION['alx_sort_loc']['DEAD']) Continue; |
125 |
|
|
126 |
if($c['online']) $pic='online'; |
if(isset($c['online'])) $pic='online'; |
127 |
else $pic='offline'; |
else $pic='offline'; |
128 |
|
|
129 |
if($c['serial']<0) |
if($c['enabled']==0) |
130 |
{ |
{ |
131 |
echo '<tr style="text-decoration:line-through; color:#aaaaaa">'; |
echo '<tr style="text-decoration:line-through; color:#aaaaaa">'; |
132 |
$pic = 'deact'; |
$pic = 'deact'; |
139 |
echo '<td width=40><b>#'.$c['serial'].'</b></td>'; |
echo '<td width=40><b>#'.$c['serial'].'</b></td>'; |
140 |
echo '<td><nobr>'.$c['hostname'].'</nobr></td>'; |
echo '<td><nobr>'.$c['hostname'].'</nobr></td>'; |
141 |
|
|
142 |
echo '<td><nobr>'.$c['ip'].'</nobr></td>'; |
echo '<td><nobr>'.$c['ip'].'</nobr></td>'; |
143 |
|
echo '<td><nobr>'.$c['mac'].'</nobr></td>'; |
144 |
if($c['mtime']) { echo '<td><nobr>'.date('Y-m-d, H:i:s',$c['mtime']).'</nobr></td>'; } |
if($c['mtime']) { echo '<td><nobr>'.date('Y-m-d, H:i:s',$c['mtime']).'</nobr></td>'; } |
|
//if($c['mtime']) { echo '<td><nobr>'.$c['mtime'].'</nobr></td>'; } |
|
145 |
else echo '<td></td>'; |
else echo '<td></td>'; |
146 |
|
|
147 |
if($showversion=='on') |
// get alx version info for |
148 |
{ |
$alxinfo = sqlfirst('SELECT * FROM client_version WHERE serial='.$c['serial']); |
149 |
// get alx version info for |
if (isset($alxinfo[os])) $alxver = $alxinfo[os]; |
150 |
$alxinfo = sqlfirst('SELECT * FROM client_version WHERE serial='.$c['serial']); |
else $alxver = 'unknown'; |
151 |
$alxver = $alxinfo[os]; |
if (isset($alxinfo[utils])) $alxutils = $alxinfo[utils]; |
152 |
$alxutils = $alxinfo[utils]; |
else $alxutils = 'unknown'; |
153 |
|
|
154 |
if( $alxver == '') |
echo '<td>'.$alxver.'</td>'; |
155 |
{ |
echo '<td>'.$alxutils.'</td>'; |
156 |
if($c['online']) |
|
157 |
{ |
// netboot state |
158 |
//$alxinfo = @sshdo('os_ver=$(</etc/mageversion);cfg_ver=$(/sbin/magequery -n alxconfig-ng | cut -d" " -f5);pname=${cfg_ver%-*-*};cfg_ver=${cfg_ver/${pname}-};echo "${os_ver}:${cfg_ver}"', $c['ip']); |
if($c['netboot'] == 1) echo '<td>Netboot (PXE)</td>'; |
159 |
//$alxinfo = explode(':',$alxinfo[1]); |
else echo '<td>Local Disk</td>'; |
|
//$alxver = $alxinfo[0]; |
|
|
//$alxutils = $alxinfo[1]; |
|
|
} |
|
|
} |
|
|
if($alxver == '') $alxver='unknown'; |
|
|
if($alxutils == '') $alxutils='unknown'; |
|
|
|
|
|
echo '<td>'.$alxver.'</td>'; |
|
|
echo '<td>'.$alxutils.'</td>'; |
|
|
} |
|
160 |
|
|
161 |
echo '<td>'; |
echo '<td>'; |
162 |
if($c['online']) |
if(isset($c['online'])) |
163 |
{ |
{ |
164 |
echo '<input type=button style="width:24%" value="RB" onclick="if(confirm(\'REBOOT CLIENT #'.$c['serial'].' ?\')) window.open(\'reboot.php?client='.$c['serial'].'&ip='.$c['ip'].'&op=reboot\', \'ShutdownWin\', \'width=200,height=100\')">'; |
echo '<input type=button style="width:24%" value="RB" onclick="if(confirm(\'REBOOT CLIENT #'.$c['serial'].' ?\')) window.open(\'reboot.php?client='.$c['serial'].'&ip='.$c['ip'].'&op=reboot\', \'ShutdownWin\', \'width=200,height=100\')">'; |
165 |
echo '<input type=button style="width:24%" value="SD" onclick="if(confirm(\'SHUTDOWN CLIENT #'.$c['serial'].' ?\')) window.open(\'reboot.php?client='.$c['serial'].'&ip='.$c['ip'].'&op=halt\', \'ShutdownWin\', \'width=200,height=100\')">'; |
echo '<input type=button style="width:24%" value="SD" onclick="if(confirm(\'SHUTDOWN CLIENT #'.$c['serial'].' ?\')) window.open(\'reboot.php?client='.$c['serial'].'&ip='.$c['ip'].'&op=halt\', \'ShutdownWin\', \'width=200,height=100\')">'; |
169 |
else echo '<input type=button style="width:100%" value="WOL" onclick="if(confirm(\'WAKE CLIENT #'.$c['serial'].' ?\')) window.open(\'wake_on_lan.php?mac='.$c['mac'].'\', \'WakeWin\', \'width=200,height=100\')">'; |
else echo '<input type=button style="width:100%" value="WOL" onclick="if(confirm(\'WAKE CLIENT #'.$c['serial'].' ?\')) window.open(\'wake_on_lan.php?mac='.$c['mac'].'\', \'WakeWin\', \'width=200,height=100\')">'; |
170 |
echo '</td>'; |
echo '</td>'; |
171 |
|
|
172 |
echo '</tr>'; |
echo '</tr>'; |
173 |
} |
} |
174 |
echo '</tbody></table><br>'; |
echo '</tbody></table><br>'; |
175 |
|
|