Magellan Linux

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

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

Legend:
Removed from v.1650  
changed lines
  Added in v.8531