Annotation of /alx-src/branches/alx-web-070/index.php
Parent Directory | Revision Log
Revision 1630 -
(hide annotations)
(download)
Thu Dec 9 22:27:33 2010 UTC (13 years, 9 months ago) by niro
Original Path: alx-src/branches/alx-web-050/index.php
File size: 8311 byte(s)
Thu Dec 9 22:27:33 2010 UTC (13 years, 9 months ago) by niro
Original Path: alx-src/branches/alx-web-050/index.php
File size: 8311 byte(s)
-fixed whitspace
1 | niro | 1610 | <? |
2 | include('include/basesql.php'); | ||
3 | session_start(); | ||
4 | session_register('alx_sort_krit'); session_register('alx_sort_onfirst'); session_register('alx_sort_loc'); | ||
5 | |||
6 | $locations = sqlarr('SELECT location FROM client_locations', '', 'location'); | ||
7 | $locations[] = ''; | ||
8 | |||
9 | if($_SESSION['alx_sort_krit']==null) | ||
10 | { | ||
11 | $_SESSION['alx_sort_krit'] = 'serial'; | ||
12 | $_SESSION['alx_sort_onfirst'] = 1; | ||
13 | $_SESSION['alx_sort_loc'] = array('DEAD'=>false); | ||
14 | foreach($locations as $l) $_SESSION['alx_sort_loc'][$l]=true; | ||
15 | } | ||
16 | if(isset($_GET['s_krit'])) | ||
17 | { | ||
18 | $_SESSION['alx_sort_krit']=$_GET['s_krit']; | ||
19 | $_SESSION['alx_sort_onfirst']=0+$_GET['s_on']; | ||
20 | $_SESSION['alx_sort_loc']['DEAD']=$_GET['s_dead']; | ||
21 | foreach($locations as $l) $_SESSION['alx_sort_loc'][$l]=$_GET['s_'.$l]; | ||
22 | } | ||
23 | |||
24 | function check_online($dat, $bla) | ||
25 | { | ||
26 | global $comps; | ||
27 | global $pingcmd; | ||
28 | if(!isset($comps[$dat['serial']])) return false; | ||
29 | |||
30 | //passthru("/bin/ping -I eth0 -c 1 -W 1 -q ".$dat['ip']." &> /dev/null && exit 0 || exit 1",$retval); | ||
31 | passthru($pingcmd." ".$dat['ip']." &> /dev/null && exit 0 || exit 1",$retval); | ||
32 | if($retval==0) | ||
33 | { | ||
34 | $comps[$dat['serial']]['online'] = true; | ||
35 | $comps[$dat['serial']]['ip'] = $dat['ip']; | ||
36 | } | ||
37 | else $comps[$dat['serial']]['ip'] = '<font color=#a00000>'.$dat['ip'].' <small>(no ping)</small></font>'; | ||
38 | |||
39 | $comps[$dat['serial']]['hostname'] = $dat['hostname']; | ||
40 | $comps[$dat['serial']]['mac'] = $dat['mac']; | ||
41 | } | ||
42 | |||
43 | function sortcomp($a,$b) | ||
44 | { | ||
45 | if($a['serial']<0 && $b['serial']>0) return -1; | ||
46 | if($a['serial']>0 && $b['serial']<0) return 1; | ||
47 | |||
48 | if($_SESSION['alx_sort_onfirst']) | ||
49 | { | ||
50 | if($a['online'] && !$b['online']) return -1; | ||
51 | if($b['online'] && !$a['online']) return 1; | ||
52 | } | ||
53 | if($_SESSION['alx_sort_krit']=='hostname') | ||
54 | { | ||
55 | if(strtoupper($a['hostname'])<strtoupper($b['hostname'])) return -1; | ||
56 | else if(strtoupper($a['hostname'])>strtoupper($b['hostname'])) return 1; | ||
57 | } | ||
58 | return $a['serial']-$b['serial']; | ||
59 | } | ||
60 | |||
61 | function checkif($b) | ||
62 | { if($b) return ' checked'; else return ''; } | ||
63 | |||
64 | $comps = sqlarr("SELECT s.serial, s.location, s.mac, n.hostname, t.mtime FROM cfg_network n,client_serials s,state_connected t WHERE n.serial=s.serial OR t.serial=s.serial", "serial"); | ||
65 | sqlforeach('SELECT serial, ip, hostname, mac FROM state_connected', 'check_online', null); | ||
66 | usort($comps, 'sortcomp'); | ||
67 | echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" | ||
68 | "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'; | ||
69 | echo '<head>'; | ||
70 | echo '<title>ALX Config - Index</title>'; | ||
71 | echo '<script language="JavaScript">'; | ||
72 | echo 'function loc(name) { window.open(\'loc.php?location=\'+name, \'\', \'width=350,height=180\'); }'; | ||
73 | echo '</script>'; | ||
74 | echo '</head>'; | ||
75 | echo '<script type="text/javascript" src="js/jquery-1.2.6.min.js"></script>'; | ||
76 | echo '<script type="text/javascript" src="js/jquery.tablesorter.js"></script>'; | ||
77 | //echo '<link rel="stylesheet" type="text/css" media="screen" href="js/style.css" />'; | ||
78 | |||
79 | if($reload!='off') echo '<body onload="window.setTimeout(\'location.reload()\',60000)">'; | ||
80 | |||
81 | /* | ||
82 | echo '<img src="logo.jpg" align=middle>'; | ||
83 | echo '<a href="index.php" style="padding-left:170px; color:#000000;text-decoration:none; font-weight:bold">[REFRESH]</a><br>'; | ||
84 | |||
85 | 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'; | ||
86 | 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>'; | ||
87 | */ | ||
88 | |||
89 | echo '<form action="index.php" method="get" style="margin:0px">'; | ||
90 | echo '<table width=480><tr>'; | ||
91 | echo '<td><img src="pics/logo.jpg"></td>'; | ||
92 | echo '<td align=right valign=top><a href="index.php" style="color:#000000;text-decoration:none; font-weight:bold">[REFRESH]</a></td>'; | ||
93 | echo '</tr><tr>'; | ||
94 | 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>'; | ||
95 | 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>'; | ||
96 | echo '<td align=right valign=top>'; | ||
97 | |||
98 | foreach($locations as $l) | ||
99 | 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>'; | ||
100 | |||
101 | echo '<br/>'; | ||
102 | echo '<input onclick="this.form.submit()" type="checkbox" name="s_dead" value="1"'.checkif($_SESSION['alx_sort_loc']['DEAD']).'>DEACTIVATED'; | ||
103 | echo '</td>'; | ||
104 | echo '</tr></table><br>'; | ||
105 | echo '</form>'; | ||
106 | |||
107 | |||
108 | echo '<table border="1" id="mytab">'; | ||
109 | 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>'; | ||
110 | if($showversion=='on') echo '<th colspan=2>version</th>'; | ||
111 | echo '<th>up/down</th></tr></thead><tbody>'; | ||
112 | |||
113 | foreach($comps as $c) | ||
114 | { | ||
115 | if(!$_SESSION['alx_sort_loc'][$c['location']]) Continue; | ||
116 | if($c['serial']<0 && !$_SESSION['alx_sort_loc']['DEAD']) Continue; | ||
117 | |||
118 | if($c['online']) $pic='online'; else $pic='offline'; | ||
119 | |||
120 | if($c['serial']<0) { echo '<tr style="text-decoration:line-through; color:#aaaaaa">'; $pic = 'deact'; } | ||
121 | else echo '<tr>'; | ||
122 | |||
123 | echo '<td><input type=button value="EDIT" onclick="location.href=\'show.php?id='.$c['serial'].'\'"></td>'; | ||
124 | echo '<td>'.substr($c['location'],0,1).'</td>'; | ||
125 | echo '<td><img src="pics/'.$pic.'.gif" alt="'.strtoupper($pic).'"></td>'; | ||
126 | echo '<td width=40><b>#'.$c['serial'].'</b></td>'; | ||
127 | echo '<td><nobr>'.$c['hostname'].'</nobr></td>'; | ||
128 | |||
129 | echo '<td><nobr>'.$c['ip'].'</nobr></td>'; | ||
130 | if($c['mtime']) { echo '<td><nobr>'.date('Y-m-d, H:i:s',$c['mtime']).'</nobr></td>'; } | ||
131 | //if($c['mtime']) { echo '<td><nobr>'.$c['mtime'].'</nobr></td>'; } | ||
132 | else echo '<td></td>'; | ||
133 | |||
134 | niro | 1630 | if($c['online']) |
135 | niro | 1610 | { |
136 | if($showversion=='on') | ||
137 | { | ||
138 | $pubkey = mysql_query('select public_key from ssh_auth_clients where serial='.$c['serial'].''); | ||
139 | while ($row = mysql_fetch_row ($pubkey)) { | ||
140 | |||
141 | # schreiben der .ssh/known_hosts file mit dem public rsa key des client, | ||
142 | # um die "yes" abfrage zu vermeiden | ||
143 | $hostfile = fopen ($home."/.ssh/known_hosts","w"); | ||
144 | fwrite($hostfile,$c['ip']." ".$row[0],strlen($row[0])+strlen($c['ip'])+1); | ||
145 | fclose($hostfile); | ||
146 | |||
147 | $osver = exec($sshcmd.' '.$c['ip'].' \'os_ver=$(</etc/mageversion);cfg_ver=$(/sbin/magequery -n alxconfig-ng-alx|cut -d" " -f5);pname=${cfg_ver%-*-*};cfg_ver=${cfg_ver/${pname}-};echo "${os_ver}:${cfg_ver}"\''); | ||
148 | $osver = explode(':',$osver); | ||
149 | } | ||
150 | if($osver[0] == '') $osver[0]='unkown'; | ||
151 | if($osver[1] == '') $osver[1]='unkown'; | ||
152 | echo '<td>'.$osver[0].'</td>'; | ||
153 | echo '<td>'.$osver[1].'</td>'; | ||
154 | } | ||
155 | } | ||
156 | |||
157 | echo '<td>'; | ||
158 | if($c['online']) | ||
159 | { | ||
160 | echo '<input type=button style="width:33%" 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\')">'; | ||
161 | echo '<input type=button style="width:33%" 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\')">'; | ||
162 | echo '<input type=button style="width:33%" value="VNC" onclick="window.open(\'vncviewer.php?ip='.$c['ip'].'\', \'VncViewer\', \'width=200,height=100\')">'; | ||
163 | } | ||
164 | 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\')">'; | ||
165 | echo '</td>'; | ||
166 | |||
167 | echo '</tr>'; | ||
168 | } | ||
169 | echo '</tbody></table><br>'; | ||
170 | |||
171 | echo ''; | ||
172 | |||
173 | ?> | ||
174 | <script type="text/javascript"> | ||
175 | $(document).ready(function(){ $("#mytab").tablesorter({ headers: { 0:{sorter: false}, 1:{sorter: false}, 5:{sorter: false}} } ); }); | ||
176 | </script> |
Properties
Name | Value |
---|---|
svn:executable | * |