Magellan Linux

Annotation of /alx-src/branches/alx-web-070/index.php

Parent Directory Parent Directory | Revision Log Revision Log


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

Properties

Name Value
svn:executable *