Contents of /alx-src/tags/alx-web-0_7_0_20170802_2/index.php
Parent Directory | Revision Log
Revision 9681 -
(show annotations)
(download)
Wed Aug 2 15:09:41 2017 UTC (7 years, 1 month ago) by niro
File size: 7961 byte(s)
Wed Aug 2 15:09:41 2017 UTC (7 years, 1 month ago) by niro
File size: 7961 byte(s)
tagged 'alx-web-0_7_0_20170802_2'
1 | <? |
2 | |
3 | include('include/basesql.php'); |
4 | include('include/common-functions.php'); |
5 | |
6 | session_start(); |
7 | //session_register('alx_sort_krit'); session_register('alx_sort_onfirst'); session_register('alx_sort_loc'); |
8 | if(isset($_SESSION['alx_sort_krit'])) $alx_sort_krit = $_SESSION['alx_sort_krit']; |
9 | if(isset($_SESSION['alx_sort_onfirst'])) $alx_sort_onfirst = $_SESSION['alx_sort_onfirst']; |
10 | if(isset($_SESSION['alx_sort_loc'])) $alx_sort_loc = $_SESSION['alx_sort_loc']; |
11 | |
12 | // 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[] = ''; |
17 | |
18 | if($_SESSION['alx_sort_krit']==null) |
19 | { |
20 | $_SESSION['alx_sort_krit'] = 'serial'; |
21 | $_SESSION['alx_sort_onfirst'] = 1; |
22 | $_SESSION['alx_sort_loc'] = array('DEAD'=>false); |
23 | foreach($locations as $l) $_SESSION['alx_sort_loc'][$l]=true; |
24 | } |
25 | if(isset($_GET['s_krit'])) |
26 | { |
27 | $_SESSION['alx_sort_krit']=$_GET['s_krit']; |
28 | $_SESSION['alx_sort_onfirst']=0+$_GET['s_on']; |
29 | $_SESSION['alx_sort_loc']['DEAD']=$_GET['s_dead']; |
30 | foreach($locations as $l) $_SESSION['alx_sort_loc'][$l]=$_GET['s_'.$l]; |
31 | } |
32 | |
33 | function check_online($dat, $bla) |
34 | { |
35 | global $comps; |
36 | global $mcore_port; |
37 | global $ping_timeout; |
38 | if(!isset($comps[$dat['serial']])) return false; |
39 | |
40 | $retval = ping_host($dat['ip'],$mcore_port,$ping_timeout); |
41 | if($retval==0) |
42 | { |
43 | $comps[$dat['serial']]['online'] = true; |
44 | $comps[$dat['serial']]['ip'] = $dat['ip']; |
45 | } |
46 | else $comps[$dat['serial']]['ip'] = '<font color=#a00000>'.$dat['ip'].' <small>(no ping)</small></font>'; |
47 | |
48 | $comps[$dat['serial']]['hostname'] = $dat['hostname']; |
49 | $comps[$dat['serial']]['mac'] = $dat['mac']; |
50 | } |
51 | |
52 | function sortcomp($a,$b) |
53 | { |
54 | if($a['serial']<0 && $b['serial']>0) return -1; |
55 | if($a['serial']>0 && $b['serial']<0) return 1; |
56 | |
57 | if($_SESSION['alx_sort_onfirst']) |
58 | { |
59 | if(isset($a['online']) && !isset($b['online'])) return -1; |
60 | if(isset($b['online']) && !isset($a['online'])) return 1; |
61 | } |
62 | if($_SESSION['alx_sort_krit']=='hostname') |
63 | { |
64 | if(strtoupper($a['hostname'])<strtoupper($b['hostname'])) return -1; |
65 | else if(strtoupper($a['hostname'])>strtoupper($b['hostname'])) return 1; |
66 | } |
67 | return $a['serial']-$b['serial']; |
68 | } |
69 | |
70 | function checkif($b) |
71 | { |
72 | if($b) return ' checked'; |
73 | else return ''; |
74 | } |
75 | |
76 | $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 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'); |
80 | echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" |
81 | "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'; |
82 | echo '<head>'; |
83 | echo '<title>ALX Config - Index</title>'; |
84 | echo '<script language="JavaScript">'; |
85 | echo 'function loc(name) { window.open(\'loc.php?location=\'+name, \'\', \'width=350,height=180\'); }'; |
86 | echo '</script>'; |
87 | echo '</head>'; |
88 | echo '<script type="text/javascript" src="js/jquery-1.2.6.min.js"></script>'; |
89 | echo '<script type="text/javascript" src="js/jquery.tablesorter.js"></script>'; |
90 | //echo '<link rel="stylesheet" type="text/css" media="screen" href="js/style.css" />'; |
91 | |
92 | if($reload!='off') echo '<body onload="window.setTimeout(\'location.reload()\',60000)">'; |
93 | |
94 | echo '<form action="index.php" method="get" style="margin:0px">'; |
95 | echo '<table width=480><tr>'; |
96 | // 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>'; |
100 | 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>'; |
102 | echo '<input onclick="this.form.submit()" name="s_on" style="margin-left:72px" type="checkbox" value="1"'.checkif($_SESSION['alx_sort_onfirst']).'>online clients on top</td>'; |
103 | echo '<td align=right valign=top>'; |
104 | |
105 | foreach($locations as $l) |
106 | echo '<input onclick="this.form.submit()" type="checkbox" name="s_'.$l.'" value="1"'.checkif($_SESSION['alx_sort_loc'][$l]).'><a href="JavaScript:loc(\''.$l.'\')" style="color:#000000">'.($l=='' ? '?' : $l).'</a>'; |
107 | |
108 | echo '<br/>'; |
109 | echo '<input onclick="this.form.submit()" type="checkbox" name="s_dead" value="1"'.checkif($_SESSION['alx_sort_loc']['DEAD']).'>DEACTIVATED'; |
110 | echo '</td>'; |
111 | echo '</tr></table><br>'; |
112 | echo '</form>'; |
113 | |
114 | |
115 | 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>mac</th><th width=100>last connected</th>'; |
117 | echo '<th colspan=2>version</th>'; |
118 | echo '<th width=100>boot</th>'; |
119 | echo '<th width=150>up/down</th></tr></thead><tbody>'; |
120 | |
121 | foreach($comps as $c) |
122 | { |
123 | if(!$_SESSION['alx_sort_loc'][$c['location']]) Continue; |
124 | if($c['enabled']==0 && !$_SESSION['alx_sort_loc']['DEAD']) Continue; |
125 | |
126 | if(isset($c['online'])) $pic='online'; |
127 | else $pic='offline'; |
128 | |
129 | if($c['enabled']==0) |
130 | { |
131 | echo '<tr style="text-decoration:line-through; color:#aaaaaa">'; |
132 | $pic = 'deact'; |
133 | } |
134 | else echo '<tr>'; |
135 | |
136 | echo '<td><input type=button value="EDIT" onclick="location.href=\'show.php?id='.$c['serial'].'\'"></td>'; |
137 | echo '<td>'.substr($c['location'],0,3).'</td>'; |
138 | echo '<td><img src="pics/'.$pic.'.gif" alt="'.strtoupper($pic).'"></td>'; |
139 | echo '<td width=40><b>#'.$c['serial'].'</b></td>'; |
140 | echo '<td><nobr>'.$c['hostname'].'</nobr></td>'; |
141 | |
142 | 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>'; } |
145 | else echo '<td></td>'; |
146 | |
147 | // get alx version info for |
148 | $alxinfo = sqlfirst('SELECT * FROM client_version WHERE serial='.$c['serial']); |
149 | if (isset($alxinfo[os])) $alxver = $alxinfo[os]; |
150 | else $alxver = 'unknown'; |
151 | if (isset($alxinfo[utils])) $alxutils = $alxinfo[utils]; |
152 | else $alxutils = 'unknown'; |
153 | |
154 | echo '<td>'.$alxver.'</td>'; |
155 | echo '<td>'.$alxutils.'</td>'; |
156 | |
157 | // netboot state |
158 | if($c['netboot'] == 1) echo '<td>Netboot (PXE)</td>'; |
159 | else echo '<td>Local Disk</td>'; |
160 | |
161 | echo '<td>'; |
162 | 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\')">'; |
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\')">'; |
166 | echo '<input type=button style="width:24%" value="VNC" onclick="window.open(\'vncviewer.php?ip='.$c['ip'].'\', \'VncViewer\', \'width=200,height=100\')">'; |
167 | echo '<input type=button style="width:24%" value="SSH" onclick="window.open(\'mindterm.php?ip='.$c['ip'].'\', \'MindTerm\', \'width=200,height=100\')">'; |
168 | } |
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\')">'; |
170 | echo '</td>'; |
171 | |
172 | echo '</tr>'; |
173 | } |
174 | echo '</tbody></table><br>'; |
175 | |
176 | echo ''; |
177 | |
178 | ?> |
179 | <script type="text/javascript"> |
180 | $(document).ready(function(){ $("#mytab").tablesorter({ headers: { 0:{sorter: false}, 1:{sorter: false}, 5:{sorter: false}} } ); }); |
181 | </script> |