Contents of /alx-src/branches/alx-web-060/show.php
Parent Directory | Revision Log
Revision 2601 -
(show annotations)
(download)
Wed Jul 6 10:37:11 2011 UTC (13 years, 2 months ago) by niro
File size: 21299 byte(s)
Wed Jul 6 10:37:11 2011 UTC (13 years, 2 months ago) by niro
File size: 21299 byte(s)
-removed deprecated comments and fixed coding style
1 | <? |
2 | // INCLUDE UND TABELLEN-DEFINITIONEN |
3 | include('include/basesql.php'); |
4 | include('include/common-functions.php'); |
5 | |
6 | // INCLUDE CURRENT-PROBLEMS |
7 | include('include/current-problems.php'); |
8 | |
9 | $tabs = array('cfg_graphic', 'cfg_network', 'cfg_input', 'client_auth', 'cfg_autostart', 'client_serials', 'cfg_comments', 'cfg_printers', 'cfg_sessions', 'cfg_modules', 'cfg_other_menuitems', 'cfg_screensaver', 'client_version'); |
10 | $multi= array( 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0); |
11 | $data = array(); |
12 | |
13 | |
14 | // get alx version info for |
15 | $alxinfo = sqlfirst('SELECT * FROM client_version WHERE serial='.$id); |
16 | $alxos = $alxinfo[os]; |
17 | $alxutils = $alxinfo[utils]; |
18 | |
19 | if($kill==1) |
20 | { |
21 | foreach($tabs as $t) mysql_query('UPDATE '.$t.' SET serial=-serial WHERE serial='.$id); |
22 | |
23 | echo '<body onload="window.setTimeout(\'window.close()\', 1750)">'; |
24 | echo '<table width=100% height=100% style="border:solid black 1px; background-color:#d5e5ff"><tr><td valign=middle align=center>'; |
25 | |
26 | if($id<0) echo 'ACTIVATED #'.abs($id); |
27 | else echo 'DEACTIVATED #'.$id; |
28 | |
29 | echo '</td></tr></table>'; |
30 | return true; |
31 | } |
32 | |
33 | // FELD-DEFINITIONEN (ARRAY=>DROPDOWN / HIDDEN / IGNORE / 1 / BOLD / PASSWORD / SHOW / SHOWTIME / MONITORID) |
34 | $drop = array(); |
35 | if($alxos >= '0.5.3') |
36 | { |
37 | $drop['cfg_graphic_module'] = array('vesa', 'ati', 'cirrus', 'i710', 'intel', 'nv', 'mach64', 'mga', 'openchrome', 'radeon', 's3', 's3virge', 'savage', 'sis', 'trident', 'tseng'); |
38 | } |
39 | else |
40 | { |
41 | $drop['cfg_graphic_module'] = array('vesa', 'ati', 'cirrus', 'i810', 'i710', 'nv', 'mga', 'r128', 'radeon', 's3', 's3virge', 'savage', 'sis', 'trident', 'tseng', 'via'); |
42 | } |
43 | $drop['resolution'] = array('640x480', '800x600', '1024x768', '1280x960', '1280x1024', '1360x768', '1366x768', '1400x1050', '1440x900', '1600x1200', '1680x1050', '1280x720', '1920x1080'); |
44 | $drop['depth'] = array('24', '16', '8'); |
45 | $drop['mouse'] = array('Auto', 'IMPS/2', 'PS/2'); |
46 | $drop['keyboard'] = array('PC105'); |
47 | if($alxos >= '0.6.0') |
48 | { |
49 | $drop['cfg_network_module'] = array('3c509', '3c59x', '8139cp', '8139too', '8390', 'amd8111e', 'atl1c', 'atl1e', 'atl1', 'atl2', 'b44', 'bnx2', 'cnic', 'e100', 'e1000', 'e1000e', 'forcedeth', 'igb', 'ipg', 'jme', 'natsemi', 'ne2k-pci', 'ns83820', 'pcnet32', 'qla3xxx', 'r8169', 'sis190', 'sis900', 'skge', 'sky2', 'tg3', 'typhoon', 'via-rhine', 'via-velocity', 'adm8211', 'airo', 'at76c50x-usb', 'ar9170usb', 'ath5k', 'ath9k', 'atmel', 'b43', 'b43legacy', 'hostap_pci', 'hostap_plx', 'ipw2100', 'ipw2200', 'iwl3945', 'usb8xxx', 'libertas_tf', 'libertas_tf_usb', 'mwl8k', 'orinoco', 'orinoco_nortel', 'orinoco_plx', 'orinoco_tmd', 'orinoco_usb', 'p54pci', 'p54usb', 'prism54', 'rndis_wlan', 'rt2400pci', 'rt2500pci', 'rt2500usb', 'rt2800pci', 'rt2800usb', 'rt61pci', 'rt73usb', 'rtl8180', 'rtl8187', 'wl1251', 'wl1271', 'zd1201', 'zd1211rw'); |
50 | } |
51 | else |
52 | { |
53 | $drop['cfg_network_module'] = array('3c59x', '8139too', '8139cp', 'e100', 'ne2k-pci', 'pcnet32', 'sis900', 'via-rhine', 'zd1211', 'b44', 'bnx2', 'dl2k', 'e1000', 'forcedeth', 'r8169', 'sk98lin', 'tg3', 'via-velocity'); |
54 | } |
55 | $drop['networking'] = array('dhcp', 'static'); |
56 | $drop['port'] = array('lpt1', 'usb1', 'usb2', 'com1', 'com2', 'lpd', 'socket', 'ipp'); |
57 | $drop['location'] = sqlarr('SELECT location FROM client_locations', '', 'location'); |
58 | $drop['id'] = 'hidden'; |
59 | $drop['flg_modified'] = '1'; |
60 | $drop['serial'] = 'ignore'; |
61 | if($alxos>='0.5.3') |
62 | { |
63 | $drop['monitorid'] = 'ignore'; |
64 | $drop['refresh_rate'] = array('','60','75','85','100'); |
65 | } |
66 | else |
67 | { |
68 | $drop['monitorid'] = 'monitorid'; |
69 | $drop['refresh_rate'] = 'ignore'; |
70 | } |
71 | $drop['hostname'] = 'bold'; |
72 | $drop['session'] = 'bold'; |
73 | if($alxos>='0.6.0') |
74 | { |
75 | $drop['cfg_autostart_session'] = array(''); |
76 | $drop['cfg_autostart_session'] += sqlarr('SELECT filename FROM cfg_sessions where serial='.$id, 'array', 'filename'); |
77 | } |
78 | else |
79 | { |
80 | $drop['cfg_autostart_session'] = 'filename'; |
81 | } |
82 | $drop['mtime'] = 'showtime'; |
83 | $drop['mac'] = 'show'; |
84 | $drop['client_serials_serial'] = 'show'; |
85 | $drop['password'] = 'password'; |
86 | $drop['shell'] = 'password'; |
87 | $drop['vnc'] = 'password'; |
88 | $drop['samba'] = 'password'; |
89 | $drop['station'] = 'password'; |
90 | $drop['txt'] = 'txt'; |
91 | $drop['screensaver'] = array('','blank', 'random', 'ant', 'ant3d', 'apollonian', 'ball', 'bat', 'blot', 'bomb', 'bouboule', |
92 | 'bounce', 'braid', 'bubble', 'bug', 'clock', 'coral', 'crystal', 'daisy', 'dclock', 'decay', 'deco', |
93 | 'demon', 'dilemma', 'discrete', 'dragon', 'drift', 'euler2d', 'eyes', 'fadeplot', 'fiberlamp', 'flag', |
94 | 'flame', 'flow', 'forest', 'galaxy', 'goop', 'grav', 'helix', 'hop', 'hyper', 'ico', 'ifs', 'image', |
95 | 'juggle', 'julia', 'kaleid', 'kumppa', 'laser', 'life', 'life1d', 'life3d', 'lightning', 'lisa', 'lissie', |
96 | 'loop', 'lyapunov', 'mandelbrot', 'marquee', 'matrix', 'maze', 'mountain', 'munch', 'nose', 'pacman', |
97 | 'penrose', 'petal', 'petri', 'polyominoes', 'puzzle', 'pyro', 'qix', 'roll', 'rotor', 'scooter', 'shape', |
98 | 'sierpinski', 'slip', 'solitare', 'space', 'sphere', 'spiral', 'spline', 'star', 'starfish', 'strange', |
99 | 'swarm', 'swirl', 't3d', 'tetris', 'thornbird', 'tik_tak', 'toneclock', 'triangle', 'tube', 'turtle', |
100 | 'vines', 'voters', 'wator', 'wire', 'world', 'worm', 'xcl', 'xjack'); |
101 | $drop['iface'] = array('eth0', 'wlan0'); |
102 | $drop['client_version_os'] = 'show'; |
103 | $drop['client_version_utils'] = 'show'; |
104 | |
105 | // ACHTUNG!!! wlan_-Felder heißen eigentlich wireless_ |
106 | $drop['wireless_mode'] = array('', 'managed', 'ad-hoc', 'master', 'repeater', 'secondary', 'monitor', 'auto'); |
107 | $drop['wireless_auth_mode'] = array('', 'wep', 'wpa', 'wpa2', 'off'); |
108 | $drop['wireless_key_length'] = array('', '64', '128', '256'); |
109 | $drop['wireless_channel'] = array('', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14'); |
110 | $drop['wireless_frequency'] = array('', '2.412G', '2.417G', '2.422G', '2.427G', '2.432G', '2.437G', '2.442G', |
111 | '2.447G', '2.452G', '2.457G', '2.462G', '2.467G', '2.472G', '2.484G'); |
112 | $drop['wireless_key'] = 'password'; |
113 | $drop['wireless_key_ascii'] = 'password'; |
114 | |
115 | // GGF. NEUEN DATENSATZ EINFÜGEN |
116 | if(isset($_POST['do_add'])) |
117 | { |
118 | list($bla,$what) = explode(' ',$_POST['do_add']); |
119 | if($what=='COMMENT') sqladd('cfg_comments', array('serial'=>$id)); |
120 | else if($what=='PRINTER') sqladd('cfg_printers', array('serial'=>$id)); |
121 | else if($what=='MODULE') sqladd('cfg_modules', array('serial'=>$id)); |
122 | else if($what=='SESSION') sqladd('cfg_sessions', array('domain'=>'DOM_AKA_NT', 'browseradrs'=>'128.20.50.50;128.20.50.66;128.20.50.71;128.20.50.46;128.20.100.31;128.20.100.32', 'serial'=>$id)); |
123 | else if($what=='MENUITEM') sqladd('cfg_other_menuitems', array('serial'=>$id)); |
124 | } |
125 | |
126 | |
127 | // GGF. SPEICHERN |
128 | if($_POST['do_upl']) |
129 | { |
130 | function postarr($prefix) |
131 | { |
132 | $prefix.='_'; |
133 | $prelen = strlen($prefix); |
134 | |
135 | $arr = array(); |
136 | foreach($_POST as $k=>$v) |
137 | if((substr($k,0,$prelen)==$prefix) && ($v!='KEEPPASS')) |
138 | $arr[substr($k,$prelen)] = stripslashes($v); |
139 | |
140 | return $arr; |
141 | } |
142 | |
143 | foreach($tabs as $k=>$t) |
144 | { |
145 | if(!$multi[$k]) mysql_query('UPDATE '.$t.' SET '.updatestr(postarr($t)).' WHERE serial='.$id); |
146 | else |
147 | { |
148 | $i=0; |
149 | while(isset($_POST[$t.'_'.$i.'_id'])) |
150 | { |
151 | if($_POST[$t.'_'.$i.'_delete']) |
152 | mysql_query('DELETE FROM '.$t.' WHERE serial='.$id.' AND id='.$_POST[$t.'_'.$i.'_id']); |
153 | else |
154 | mysql_query('UPDATE '.$t.' SET '.updatestr(postarr($t.'_'.$i)).' WHERE serial='.$id.' AND id='.$_POST[$t.'_'.$i.'_id']); |
155 | $i++; |
156 | } |
157 | } |
158 | } |
159 | |
160 | // reload site |
161 | header("location: show.php?id=".$id); |
162 | } |
163 | |
164 | // EINLESEN DER DATEN AUS SQL-TABELLEN |
165 | foreach($tabs as $k=>$t) |
166 | { |
167 | if($multi[$k]) $data[$t] = sqlarr('SELECT * FROM '.$t.' WHERE serial='.$id); |
168 | else $data[$t] = sqlfirst('SELECT * FROM '.$t.' WHERE serial='.$id); |
169 | } |
170 | |
171 | // ANZEIGEN - KLAPPFUNKTIONEN |
172 | $absnames = array(); |
173 | |
174 | function openabs($heading, $helpfile='') |
175 | { |
176 | global $absnames; |
177 | $absnames[] = $heading; |
178 | |
179 | // <AufZuLink> <Bild/> <Heading/> </AufZuLink><BR/> <Absatz> |
180 | |
181 | if( $_SESSION['openclose'][$heading] ) |
182 | { |
183 | echo '<a href="JavaScript:openclose(\''.$heading.'\',1);"><img border="0" src="pics/minus.gif" title="CLOSE" id="sch_bild_'.$heading.'"> <b>['.$heading.']</b></a>'; |
184 | if($helpfile!='') echo ' <a href="JavaScript:showhelp(\''.$helpfile.'\')" title="HELP">[?]</a>'; |
185 | echo '<br><div id="sch_absatz_'.$heading.'" style="top:0px; visibility:visible">'; |
186 | } |
187 | else |
188 | { |
189 | echo '<a href="JavaScript:openclose(\''.$heading.'\',1);"><img border="0" src="pics/plus.gif" title="OPEN" id="sch_bild_'.$heading.'"> <b>['.$heading.']</b></a>'; |
190 | if($helpfile!='') echo ' <a href="JavaScript:showhelp(\''.$helpfile.'\')" title="HELP">[?]</a>'; |
191 | echo '<br><div id="sch_absatz_'.$heading.'" style="position:absolute; top:0px; visibility:hidden">'; |
192 | } |
193 | } |
194 | |
195 | function closeabs() |
196 | { |
197 | // </Absatz> <BR/> |
198 | |
199 | echo '</div><br>'; |
200 | } |
201 | |
202 | |
203 | // ANZEIGEN |
204 | |
205 | function parsearr($name, $arr, $del=false, $wireless=false) |
206 | { |
207 | global $drop; |
208 | global $id; |
209 | global $alxos; |
210 | |
211 | $parts = explode('_',$name); $helpfile='help.php?page='.$parts[1]; |
212 | openabs($name, $helpfile); |
213 | echo '<table class="keytab">'; |
214 | |
215 | foreach($arr as $k=>$v) |
216 | { |
217 | if( (substr($k,0,9)=='wireless_') xor $wireless ) Continue; |
218 | |
219 | $d = $drop[$name.'_'.$k]; if($d==null) $d = $drop[$k]; |
220 | $k = str_replace('wireless_', '', $k); |
221 | $k2 = $k; |
222 | |
223 | //replace some drivers on 0.5.3 or higher |
224 | if($alxos >= '0.5.3') |
225 | { |
226 | if($v == 'i810') |
227 | { |
228 | echo '<br><font color="#FF0000">Replaced "i810" with "intel" - Please press SAVE!</font><br>'; |
229 | $v='intel'; |
230 | } |
231 | if($v == 'r128') |
232 | { |
233 | echo '<br><font color="#FF0000">Replaced "r128" with "vesa" - Please press SAVE!</font><br>'; |
234 | $v='vesa'; |
235 | } |
236 | |
237 | if($v == 'via') |
238 | { |
239 | echo '<br><font color="#FF0000">Replaced "via" with "openchrome" - Please press SAVE!</font><br>'; |
240 | $v='openchrome'; |
241 | } |
242 | } |
243 | |
244 | # tell something about vesa |
245 | if ($v == 'vesa') echo '<br><font color="#FF0000">Warning: "vesa" graphic module doesn\'t support any resolutions higher than 1024x786x16@60hz!</font><br>'; |
246 | |
247 | |
248 | if(is_array($d)) |
249 | { |
250 | echo '<tr><td class="key">'.$k2.'</td><td>= <select style="width:144px" name="'.$name.'_'.$k.'">'; |
251 | foreach($d as $di) if($v==$di) echo '<option selected>'.$di; else echo '<option>'.$di; |
252 | echo '</select></td></tr>'; |
253 | } |
254 | else if($d=='hidden') echo '<tr><td colspan=2><input type=hidden name="'.$name.'_'.$k.'" value="'.$v.'"></td></tr>'; |
255 | else if($d=='1') echo '<tr><td colspan=2><input type=hidden name="'.$name.'_'.$k.'" value="1"></td></tr>'; |
256 | else if($d=='monitorid') echo '<tr><td class="key">'.$k2.'</td><td>= <input type=button style="width:24px" onclick="window.open(\'monitor.php?id='.$id.'\', \'MonitorWin\', \'width=350,height=200\')" value="..."></td>'; |
257 | else if($d=='bold') echo '<tr><td class="key">'.$k2.'</td><td>= <input style="width:144px;font-weight:bold" name="'.$name.'_'.$k.'" value="'.$v.'"></td></tr>'; |
258 | else if($d=='filename') echo '<tr><td class="key">filename</td><td>= <input style="width:144px;font-weight:bold" name="'.$name.'_'.$k.'" value="'.$v.'"></td></tr>'; |
259 | else if($d=='show') echo '<tr><td class="key">'.$k2.'</td><td>= <b>'.$v.'</b></td></tr>'; |
260 | else if($d=='showtime') echo '<tr><td class="key">'.$k2.'</td><td>= <b>'.date('d.m.y - H:i:s', $v).'</b></td></tr>'; |
261 | else if($d=='password' && $v=='') echo '<tr><td class="key">'.$k2.'</td><td>= <input type=password style="width:144px" name="'.$name.'_'.$k.'" value=""></td></tr>'; |
262 | else if($d=='password') echo '<tr><td class="key">'.$k2.'</td><td>= <input type=password style="width:144px" name="'.$name.'_'.$k.'" value="KEEPPASS"></td></tr>'; |
263 | else if($d=='txt') echo '<tr><td colspan=2><textarea style="width:240px; background-color:#d5e5ff" rows=4 name="'.$name.'_'.$k.'">'.$v.'</textarea></td></tr>'; |
264 | else if($d!='ignore') echo '<tr><td class="key">'.$k2.'</td><td>= <input style="width:144px" name="'.$name.'_'.$k.'" value="'.$v.'"></td></tr>'; |
265 | } |
266 | |
267 | if($del) echo '<tr><td class="key">delete</td><td>=<input type=checkbox name="'.$name.'_delete" value="1"></td></tr>'; |
268 | echo '</table>'; |
269 | closeabs(); |
270 | |
271 | if($name=='cfg_network' && !$wireless) parsearr($name.'_wireless', $arr, $del, true); |
272 | } |
273 | function parsearrs($name, $arr) |
274 | { |
275 | foreach($arr as $k=>$a) |
276 | parsearr($name.'_'.$k, $a, true); |
277 | } |
278 | |
279 | ?><head> |
280 | <title>ALX Config</title> |
281 | <style> |
282 | body,table { font-family:Tahoma; font-size:10pt } |
283 | a { color:#000000; text-decoration:none; } |
284 | .key { width:85px } |
285 | .keytab, input, textarea, select, option { font-size:8pt; font-family:Tahoma } |
286 | .but { font-size:10pt; font-family:Tahoma; height:23px } |
287 | </style> |
288 | <script language="JavaScript" src="openclose_ajax.js"></script> |
289 | <script language="JavaScript"> |
290 | |
291 | // opens an url and shows retval in a javascript-alert on current site |
292 | function urlopen(url,typ) { |
293 | var $url = url.split("?"); |
294 | $.ajax({type:""+typ+"",url:$url[0],data:$url[1],cache:false,success:function(data){ alert(data); }}); |
295 | } |
296 | |
297 | function openclose(nummer, act) |
298 | { |
299 | var bild = document.images['sch_bild_'+nummer]; |
300 | var absatz = document.all['sch_absatz_'+nummer].style; |
301 | var senden = false; |
302 | |
303 | $("#sch_absatz_"+nummer).toggle(0, function(){ |
304 | if($(this).css("display")=="none"){$("#sch_bild_"+nummer).attr({title:'OPEN',src:'pics/plus.gif'});}else{$("#sch_bild_"+nummer).attr({title:'CLOSE',src:'pics/minus.gif'});} |
305 | }); |
306 | if(act<=1){ $("#sch_bild_"+nummer).attr({title:'CLOSE',src:'pics/minus.gif'}); }else{ $("#sch_bild_"+nummer).attr({title:'OPEN',src:'pics/plus.gif'}); }; |
307 | } |
308 | |
309 | function showhelp(name) |
310 | { window.open(name, 'HelpWin', 'width=620,height=500,scrollbars=yes'); } |
311 | |
312 | </script> |
313 | </head> |
314 | |
315 | <body><? |
316 | |
317 | echo '<form action="show.php" method="post" onreset="return confirm(\'UNDO CHANGES?\')">'; |
318 | echo '<input type=hidden name="do_upl" value="1">'; |
319 | echo '<input type=hidden name="id" value="'.$id.'">'; |
320 | |
321 | // ANZEIGEN => NON-MULTI TABELLEN |
322 | echo '<table><tr><td valign=top width="300">'; |
323 | |
324 | echo '<b style="font-size:6pt">'; |
325 | echo '<a href="JavaScript:opencloseall(0);" title="OPEN ALL"><img src="pics/plus.gif" border="0"> OPEN...</a> '; |
326 | echo '<a href="JavaScript:opencloseall(2);" title="CLOSE ALL"><img src="pics/minus.gif" border="0"> CLOSE...</a> ALL'; |
327 | echo '</b><br><br>'; |
328 | |
329 | foreach($tabs as $k=>$t) if(!$multi[$k]) parsearr($t, $data[$t]); |
330 | |
331 | // ANZEIGEN => MULTI TABELLEN |
332 | echo '</td><td valign=top width="300">'; |
333 | |
334 | foreach($tabs as $k=>$t) if($multi[$k]) parsearrs($t, $data[$t]); |
335 | |
336 | echo '<script language="JavaScript">'; |
337 | echo 'function opencloseall(act) { '; |
338 | |
339 | foreach($absnames as $absname) |
340 | echo 'openclose("'.$absname.'", act); '; |
341 | |
342 | echo '}</script>'; |
343 | |
344 | // ANZEIGEN => NAVI |
345 | echo '</td><td valign=top>'; |
346 | |
347 | // STATUS BESTIMMEN (ON/OFF) |
348 | $conn = sqlfirst('SELECT * FROM state_connected WHERE serial='.$id); |
349 | $state = 'Off'; |
350 | if(count($conn)>0) |
351 | { |
352 | if($retval==0) $state = 'On'; |
353 | } |
354 | |
355 | echo '<img src="pics/logo2.jpg"><br><br>'; |
356 | |
357 | echo '<input class="but" type=submit value="SAVE" style="width:150px"><br><br>'; |
358 | |
359 | echo '<input class="but" type=submit name="do_add" value="SAVE+ADD COMMENT" style="width:150px"><br>'; |
360 | echo '<input class="but" type=submit name="do_add" value="SAVE+ADD PRINTER" style="width:150px"><br>'; |
361 | echo '<input class="but" type=submit name="do_add" value="SAVE+ADD SESSION" style="width:150px"><br>'; |
362 | echo '<input class="but" type=submit name="do_add" value="SAVE+ADD MODULE" style="width:150px"><br>'; |
363 | echo '<input class="but" type=submit name="do_add" value="SAVE+ADD MENUITEM" style="width:150px"><br><br>'; |
364 | |
365 | |
366 | if($id>0) $KILLCAP='DEACTIVATE'; else $KILLCAP='ACTIVATE'; |
367 | echo '<input class="but" type=button value="'.$KILLCAP.'" style="width:150px" onclick="if(confirm(\''.$KILLCAP.' CLIENT #'.abs($id).' ?\')) { window.open(\'show.php?id='.$id.'&kill=1\', \'DeactWin\', \'width=200,height=100\'); location.href=\'index.php\'; }"><br>'; |
368 | echo '<input class="but" type=button value="IMPORT FROM..." style="width:150px" onclick="location.href=\'import.php?id='.$id.'\'"><br>'; |
369 | echo '<input class="but" type=reset value="UNDO CHANGES" style="width:150px"><br><br>'; |
370 | |
371 | $davor = sqlfirst('SELECT mac FROM client_serials WHERE serial='.($id-1),'mac')!=null; if($davor) $disdavor=''; else $disdavor = 'disabled=1'; |
372 | $danach = sqlfirst('SELECT mac FROM client_serials WHERE serial='.($id+1),'mac')!=null; if($danach) $disdanach=''; else $disdanach = 'disabled=1'; |
373 | |
374 | echo '<input class="but" type=button '.$disdavor.' value="<" style="width:30px" onclick="location.href=\'show.php?id='.($id-1).'\'">'; |
375 | echo '<input class="but" type=button value="REFRESH" style="width:90px" onclick="location.href=\'show.php?id='.$id.'\'">'; |
376 | echo '<input class="but" type=button '.$disdanach.' value=">" style="width:30px" onclick="location.href=\'show.php?id='.($id+1).'\'">'; |
377 | echo '<br><input class="but" type=button value="INDEX" style="width:150px; font-weight:bold" onclick="location.href=\'index.php\'"><br><br>'; |
378 | |
379 | echo '<br>'; |
380 | echo '<div style="border:solid black 1px; padding:5px; background-color:#d5e5ff"><b>'; |
381 | if($id<0) echo '<b>DEACTIVATED!</b><br><br>'; |
382 | echo '<u>Serial:</u> #'.$id.'<br>'; |
383 | echo '<u>Stand:</u> '.date('H:i:s').'<br>'; |
384 | echo '<u>Status:</u> <img src="pics/'.strtolower($state).'line.gif" align=top> '.$state.'line<br>'; |
385 | if($state=='On') |
386 | { |
387 | echo '<u>IP:</u> '.$conn['ip'].'<br><br>'; |
388 | if($alxos >= '0.6.0') |
389 | { |
390 | $osver = 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}"', $conn['ip']); |
391 | } |
392 | else |
393 | { |
394 | $osver = sshdo('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}"', $conn['ip']); |
395 | } |
396 | $osver = explode(':',$osver[1]); |
397 | if($osver[0] == '') $osver[0]='unkown'; |
398 | if($osver[1] == '') $osver[1]='unkown'; |
399 | |
400 | # update os string in database |
401 | if($alxos == '' && $osver[0] >= '0.5.3') |
402 | { |
403 | mysql_query('insert into client_version(serial,os,utils) values("'.$id.'","'.$osver[0].'","'.$osver[1].'") |
404 | on duplicate key update os="'.$osver[0].'", utils="'.$osver[1].'"'); |
405 | # reload the site |
406 | echo '<script type="text/javascript">setTimeout(\'window.location.reload()\',0);</script>'; |
407 | } |
408 | |
409 | echo '<u>OS:</u> '.$osver[0].'<br>'; |
410 | echo '<u>Utils:</u> '.$osver[1].'<br>'; |
411 | |
412 | if($osver[0] <> 'unkown') |
413 | { |
414 | //write them to database |
415 | } |
416 | } |
417 | |
418 | echo '</b></div>'; |
419 | |
420 | if($state=='On') |
421 | { |
422 | echo '<input class="but" type=button value="REBOOT" style="width:150px" onclick="if(confirm(\'REBOOT CLIENT #'.$id.' ?\')) window.open(\'reboot.php?client='.$id.'&ip='.$conn['ip'].'&op=reboot\', \'ShutdownWin\', \'width=200,height=100\')"><br>'; |
423 | echo '<input class="but" type=button value="SHUTDOWN" style="width:150px" onclick="if(confirm(\'SHUTDOWN CLIENT #'.$id.' ?\')) window.open(\'reboot.php?client='.$id.'&ip='.$conn['ip'].'&op=halt\', \'ShutdownWin\', \'width=200,height=100\')"><br>'; |
424 | echo '<br>'; |
425 | |
426 | if($alxos >= '0.6.0') |
427 | { |
428 | echo '<div style="border:solid black 1px; padding:5px; background-color:#d5e5ff" align="center"><b>'; |
429 | echo 'Hardware Detection:</b></div>'; |
430 | echo '<input class="but" type=button value="LAN" style="width:50px" onclick="javascript:urlopen(\'include/hwinfo.php?ip='.$conn['ip'].'&cmd=lan\',\'POST\');">'; |
431 | echo '<input class="but" type=button value="WLAN" style="width:50px" onclick="javascript:urlopen(\'include/hwinfo.php?ip='.$conn['ip'].'&cmd=wlan\',\'POST\');">'; |
432 | echo '<input class="but" type=button value="VGA" style="width:50px" onclick="javascript:urlopen(\'include/hwinfo.php?ip='.$conn['ip'].'&cmd=vga\',\'POST\');">'; |
433 | echo '<br><br>'; |
434 | } |
435 | |
436 | echo '<div style="border:solid black 1px; padding:5px; background-color:#d5e5ff" align="center"><b>'; |
437 | echo 'Remote Shadow:</b></div>'; |
438 | echo '<input class="but" type=button value="VNC" style="width:150px" onclick="window.open(\'vncviewer.php?ip='.$conn['ip'].'\', \'VncViewer\', \'width=200,height=100\')"><br>'; |
439 | echo '<input class="but" type=button value="SSH" style="width:150px" onclick="window.open(\'mindterm.php?ip='.$conn['ip'].'\', \'MindTerm\', \'width=200,height=100\')"><br>'; |
440 | echo '<br>'; |
441 | echo '<div style="border:solid black 1px; padding:5px; background-color:#d5e5ff" align="center"><b>'; |
442 | echo 'Client Update:</b></div>'; |
443 | echo '<input class="but" type=button value="UPDATE MAGE DB" style="width:150px" onclick="if(confirm(\'UPDATE DB ON CLIENT #'.$id.' ?\')) window.open(\'mageupgrade.php?client='.$id.'&ip='.$conn['ip'].'&op=update\', \'ShutdownWin\', \'width=800,height=600\')"><br>'; |
444 | echo '<input class="but" type=button value="CALC DEPS" style="width:150px" onclick="if(confirm(\'CALC DEPS FOR CLIENT #'.$id.' ?\')) window.open(\'mageupgrade.php?client='.$id.'&ip='.$conn['ip'].'&op=calc\', \'ShutdownWin\', \'width=800,height=600\')"><br>'; |
445 | echo '<input class="but" type=button value="UPGRADE CLIENT" style="width:150px" onclick="if(confirm(\'UPGRADE ALL PACKAGES ON CLIENT #'.$id.' ?\')) window.open(\'mageupgrade.php?client='.$id.'&ip='.$conn['ip'].'&op=upgrade\', \'ShutdownWin\', \'width=800,height=600\');setTimeout(\'window.location.reload()\',0);"><br>'; |
446 | } |
447 | else |
448 | echo '<input class="but" type=button value="WAKE ON LAN" style="width:150px" onclick="if(confirm(\'WAKE CLIENT #'.$id.' ?\')) window.open(\'wake_on_lan.php?mac='.$data['client_serials']['mac'].'\', \'WakeWin\', \'width=200,height=100\')"><br>'; |
449 | |
450 | echo '<br><center><a href="share/ChangeLog.html" target="_blank">[ChangeLog]</a> <a href="share/FAQ.html" target="_blank">[FAQs]</a></center>'; |
451 | |
452 | echo '</td></tr></table>'; |
453 | echo '</form>'; |
454 | ?> |
Properties
Name | Value |
---|---|
svn:executable | * |