/[projects]/misc/xenconsole/index.php
ViewVC logotype

Diff of /misc/xenconsole/index.php

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

revision 1895 by torben, Sun Dec 9 19:57:00 2012 UTC revision 2014 by torben, Wed Jul 17 17:47:49 2013 UTC
# Line 1  Line 1 
1  <?php  <?php
2  include("config.php");  require("config.php");
3    
4  function format_memory($size) {  function format_memory($size) {
5    if (1024 > $size) {    if (1024 > $size) {
# Line 46  $namelabel = $host["name_label"]; Line 46  $namelabel = $host["name_label"];
46  <html>  <html>
47  <head>  <head>
48  <title>XenServer::<?php echo $namelabel;?></title>  <title>XenServer::<?php echo $namelabel;?></title>
49  <script type='text/javascript' src="jquery-1.8.2.min.js"></script>  
50    <link rel="stylesheet" type="text/css" href="jquery/theme/jquery-ui.css">
51    <style>
52    .ui-menu {
53            width: 200px;
54    }
55    </style>
56    <script type='text/javascript' src="jquery/jquery-1.9.1.min.js"></script>
57    <script type='text/javascript' src="jquery/jquery-ui-1.10.2.min.js"></script>
58    
59  <script type='text/javascript'>  <script type='text/javascript'>
60    var menu = 0;
61    var menu_uuid = '';
62    
63  $(document).ready( function() {  $(document).ready( function() {
64            $("#menu").hide();
65          setInterval(refreshData, 60000);                  setInterval(refreshData, 60000);        
66          refreshData();          refreshData();
67          $('.console').click( function() {          $('.console').click( function() {
68                  var session = $(this).data('session');                  var session = $(this).data('session');
69                  var conurl = $(this).data('conurl');                  var conurl = $(this).data('conurl');
70                  console(conurl,session);                  var name = $(this).data('name');
71                    openConsole(conurl,session,name);
72          });          });
73    
74          $('#logo').click( function() {          $('#logo').click( function() {
75                  refreshData();                  refreshData();
76          });          });
77    
78            $('.settings').click( function(event) {
79                    menu_uuid = $(this).attr('uuid');
80    
81                    $('#menu').menu( {
82                            select: function(event2,ui) {
83                                            var action = $(ui.item).attr("action");
84                                            if (action == "memory") {
85                                                    doAction("setMemory", menu_uuid, "");  
86                                            }
87                                            if (action == "cpu") {
88                                                    doAction("setCPU", menu_uuid, "");      
89                                            }
90                                    },
91                            create: function(event3,ui) {
92                                    menu = 1;
93                                    }
94                            /*position: {
95                                    my: "left", of: event
96                            }*/
97                    });
98                    $('#menu').show().position( {my: "left top", of: event} );
99                    event.stopPropagation();
100            });
101    
102            $(document).click( function(event) {
103                    closeMenu();
104            });
105    
106  });  });
107    
108    function closeMenu() {
109            if (menu > 0) {
110                    $("#menu").menu("destroy").hide();
111                    menu = 0;
112            }
113    }
114    
115  function refreshData() {  function refreshData() {
116          $("#logo").hide();                $("#logo").hide();      
117          $.get('ajaxdata.php', function(xml) {          $.get('ajaxdata.php', function(xml) {
# Line 97  function refreshData() { Line 146  function refreshData() {
146                          var conurl = $(this).find('conurl').text();                          var conurl = $(this).find('conurl').text();
147                          var session = $(this).find('session').text();                          var session = $(this).find('session').text();
148                          var os = $(this).find('os').text();                          var os = $(this).find('os').text();
149                            var guestversion = $(this).find('guestversion').text();
150                          var cpuavg = $(this).find('cpuavg').text();                          var cpuavg = $(this).find('cpuavg').text();
151                            var curmem = $(this).find('curmem').text();
152                          name = name.replace(" ", "_");                          var maxmem = $(this).find('maxmem').text();
153                          name = name.replace(".", "_");                          var cpus = $(this).find('cpus').text();
154    
155                            var mempercent = Math.round( (curmem*100) / maxmem );
156    
157                            name = name.replace(/ /g, "_");
158                            name = name.replace(/\./g, "_");
159                            name = name.replace(/\(/g, "_");
160                            name = name.replace(/\)/g, "_");
161                                                    
162                          var id = "#vm_" + name;                          var id = "#vm_" + name;
163    
164                          var vm = $(id);                                          var vm = $(id);                
165    
166                            if (guestversion != '') {
167                                    os += ' Guest Tools: ' + guestversion;
168                            }
169    
170                            vm.find('.vps_memory_usage_txt_UID').text( maxmem + " MB");
171                            vm.find('.vps_cpu_usage_txt_UID').text( cpus + " VCPU");
172    
173                          if (state == "Running") {                          if (state == "Running") {
174                                  vm.find('.state').css("background-image", "url('gfx/vps_topgreen.png')");                                  vm.find('.state').css("background-image", "url('gfx/vps_topgreen.png')");
175                                  vm.find('.network').show();                                  vm.find('.network').show();
# Line 113  function refreshData() { Line 177  function refreshData() {
177                                  vm.find('.console').show();                                  vm.find('.console').show();
178                                  vm.find('.console').data('conurl', conurl);                                  vm.find('.console').data('conurl', conurl);
179                                  vm.find('.console').data('session', session);                                  vm.find('.console').data('session', session);
180                                    vm.find('.console').data('name', name);
181                                    vm.find('.settings').hide();
182                                  vm.find('.actionstop').show();                                  vm.find('.actionstop').show();
183                                  vm.find('.actionstart').hide();                                  vm.find('.actionstart').hide();
184                                  vm.find('.os').text(' - ' + os);                                  vm.find('.os').text(' - ' + os);
# Line 121  function refreshData() { Line 187  function refreshData() {
187                                  vm.find('.cpu_graph').show();                                  vm.find('.cpu_graph').show();
188                                  vm.find('.cpu_graph').attr('src', 'usagebar.php?usage=' + cpuavg);                                  vm.find('.cpu_graph').attr('src', 'usagebar.php?usage=' + cpuavg);
189                                  vm.find('.cpu_graph').attr('title',  cpuavg + '%');                                  vm.find('.cpu_graph').attr('title',  cpuavg + '%');
190    
191                                  vm.find('.mem_graph').show();                                  vm.find('.mem_graph').show();
192                                    vm.find('.mem_graph').attr('src', 'usagebar.php?usage=' + mempercent);
193                                    vm.find('.mem_graph').attr('title',  curmem + ' / ' + maxmem + ' MB' );
194                          } else {                          } else {
195                                  if (state == "Halted") {                                  if (state == "Halted") {
196                                          vm.find('.state').css("background-image", "url('gfx/vps_topred.png')");                                          vm.find('.state').css("background-image", "url('gfx/vps_topred.png')");
197                                  } else {                                  } else {
198                                          vm.find('.state').css("background-image", "url('gfx/vps_topyellow.png')");                                          vm.find('.state').css("background-image", "url('gfx/vps_topyellow.png')");
199                                  }                                  }
200                                    vm.find('.os').text('');
201    
202                                  vm.find('.network').hide();                                  vm.find('.network').hide();
203                                  vm.find('.console').hide();                                  vm.find('.console').hide();
204                                    vm.find('.settings').show();
205                                  vm.find('.actionstop').hide();                                  vm.find('.actionstop').hide();
206                                  vm.find('.actionstart').show();                                  vm.find('.actionstart').show();
207                                  vm.find('.cpu_graph').hide();                                  vm.find('.cpu_graph').hide();
# Line 142  function refreshData() { Line 214  function refreshData() {
214  }  }
215    
216  function doAction(action, uuid, vm) {  function doAction(action, uuid, vm) {
217            var val="";
218    
219          var key = prompt("Key");          var key = prompt("Key");
220          if (key == "" || key == null) {          if (key == "" || key == null) {
221                  return;                  return;
# Line 149  function doAction(action, uuid, vm) { Line 223  function doAction(action, uuid, vm) {
223          document.body.style.cursor = 'wait';          document.body.style.cursor = 'wait';
224          $('#vm_' + vm).find('.state').css("background-image", "url('gfx/vps_topyellow.png')");          $('#vm_' + vm).find('.state').css("background-image", "url('gfx/vps_topyellow.png')");
225    
226          var url = "action.php?action=" + action + "&uuid=" + uuid + "&key=" + key;          if (action == "setMemory") {
227                    val = prompt("Set memory target");
228                    val *= (1024*1024);
229                    if (val == "" || val == null) {
230                            return;
231                    }
232            }
233            if (action == "setCPU") {
234                    val = prompt("Set CPU count");
235                    if (val == "" || val == null) {
236                            return;
237                    }
238            }
239    
240            var url = "action.php?action=" + action + "&uuid=" + uuid + "&key=" + key + "&val=" + val;;
241          var response = $.get(url, function(data) {          var response = $.get(url, function(data) {
242                  if (data != 'OK') {                  if (data != 'OK') {
243                          alert(data);                          alert(data);
# Line 160  function doAction(action, uuid, vm) { Line 248  function doAction(action, uuid, vm) {
248          });          });
249  }  }
250    
251  function console(url, session) {  function openConsole(url, session, name) {
252          if (url == '')          if (url == '')
253                  return;                  return;
254    
# Line 168  function console(url, session) { Line 256  function console(url, session) {
256          if (key == "" || key == null) {          if (key == "" || key == null) {
257                  return;                  return;
258          }          }
259          var url = "console.php?url=" + url + "&session=" + session + "&key=" + key;          var url = "console.php?url=" + url + "&session=" + session + "&key=" + key + "&name=" + name;
260    
261          //window.location = url;          //window.location = url;
262          //$('#mainwindow').load(url);          //$('#mainwindow').load(url);
# Line 221  body { Line 309  body {
309          <td colspan='4' class='small' align='right'><?php echo $namelabel . " / " . $xenversion;?><br><?php echo $license;?></td>          <td colspan='4' class='small' align='right'><?php echo $namelabel . " / " . $xenversion;?><br><?php echo $license;?></td>
310  </tr>  </tr>
311  <tr>  <tr>
312    <td width='150'></td>
313    <td width='150'></td>
314          <td width='150' align='right' class='small'><img src='gfx/icon-cpu.png'>          <td width='150' align='right' class='small'><img src='gfx/icon-cpu.png'>
315                  <img id='server_cpu_usage' src='usagebar.php?usage=12' width='102' height='16' title='static dummy data'><div id='server_cpu_usage_txt'>12%</div></td>                  <img id='server_cpu_usage' src='usagebar.php?usage=12' width='102' height='16' title='static dummy data'><div id='server_cpu_usage_txt'>12%</div></td>
316    
317          <td width='150' align='right' class='small'><img src='gfx/icon-memory.png'>          <td width='150' align='right' class='small'><img src='gfx/icon-memory.png'>
318                  <img id='server_memory_usage' src='usagebar.php?usage=1' width='102' height='16' title='static dummy data'><div id='server_memory_usage_txt'>0/4 MB</div></td>                  <img id='server_memory_usage' src='usagebar.php?usage=1' width='102' height='16' title='static dummy data'><div id='server_memory_usage_txt'>0/4 MB</div></td>
319    <!--
320          <td width='150' align='right' class='small'><img src='gfx/icon-network.png'>          <td width='150' align='right' class='small'><img src='gfx/icon-network.png'>
321                  <img id='server_net_usage' src='usagebar.php?usage=41' width='102' height='16' title='static dummy data'><div id='server_net_usage_txt'>1%</div></td>                  <img id='server_net_usage' src='usagebar.php?usage=41' width='102' height='16' title='static dummy data'><div id='server_net_usage_txt'>1%</div></td>
322          <td width='150' align='right' class='small'><img src='gfx/icon-disk.png'>          <td width='150' align='right' class='small'><img src='gfx/icon-disk.png'>
323                  <img id='server_disk_usage' src='usagebar.php?usage=41' width='102' height='16' title='static dummy data'><div id='server_memory_usage_txt'>89.3/405.5 GB</div></td>                  <img id='server_disk_usage' src='usagebar.php?usage=41' width='102' height='16' title='static dummy data'><div id='server_memory_usage_txt'>89.3/405.5 GB</div></td>
   
324          </td>          </td>
325    -->
326  </tr></table>  </tr></table>
327    
328    
# Line 245  foreach($vms_array as $vm) { Line 335  foreach($vms_array as $vm) {
335          }          }
336    
337          $name = $vm["name_label"];          $name = $vm["name_label"];
338            $description = $vm["name_description"];
339          $uuid = $vm["uuid"];          $uuid = $vm["uuid"];
340          $state = $vm["power_state"] ;          $state = $vm["power_state"] ;
341          $memory = $vm['memory_target'];          $memory = $vm['memory_target'];
# Line 253  foreach($vms_array as $vm) { Line 344  foreach($vms_array as $vm) {
344    
345          $clean_name = str_replace(" ", "_", $name);          $clean_name = str_replace(" ", "_", $name);
346          $clean_name = str_replace(".", "_", $clean_name);          $clean_name = str_replace(".", "_", $clean_name);
347            $clean_name = str_replace("(", "_", $clean_name);
348            $clean_name = str_replace(")", "_", $clean_name);
349                    
350    
351          foreach ($vm["VBDs"] as $vbds) {          foreach ($vm["VBDs"] as $vbds) {
# Line 270  foreach($vms_array as $vm) { Line 363  foreach($vms_array as $vm) {
363          <table width='99%' cellpadding='3' cellspacing='0' border='0' class='vps' id='vm_<?php echo $clean_name;?>'>          <table width='99%' cellpadding='3' cellspacing='0' border='0' class='vps' id='vm_<?php echo $clean_name;?>'>
364                  <tr background='gfx/vps_topbg.png'  >                  <tr background='gfx/vps_topbg.png'  >
365                          <td width='10' class='small state'>&nbsp;</td>                          <td width='10' class='small state'>&nbsp;</td>
366                          <td colspan='2' class='small'><b><?php echo $name; ?></b><span class='os'></span></td>                          <td colspan='2' class='small' title='<?php echo $description;?>'><b><?php echo $name; ?></b><span class='os'></span></td>
367                          <td colspan='2' class='small' align='right'>                          <td colspan='2' class='small' align='right'>
368                                  <span class='network'></span>                                  <span class='network'></span>
369                                  <a href='#' style='display:none;' class='console'>                                  <a href='#' style='display:none;' class='console'>
370                                          <img src='gfx/icon-terminal.png' style='vertical-align: middle;'>                                          <img src='gfx/icon-terminal.png' style='vertical-align: middle;'>
371                                  </a>                                  </a>
372                                    <a href='#' style='display:none;' class='settings' uuid='<?php echo $uuid;?>'>
373                                            <img src='gfx/icon-settings16.png' style='vertical-align: middle;'>
374                                    </a>
375                          </td>                          </td>
376                  </tr>                  </tr>
377    
# Line 300  foreach($vms_array as $vm) { Line 396  foreach($vms_array as $vm) {
396                  <td width='100' align='right' class='small' valign='top'>                  <td width='100' align='right' class='small' valign='top'>
397                          <img src='usagebar.php?usage=1' width='102' height='16' title='static dummy data' class='cpu_graph'><br>                          <img src='usagebar.php?usage=1' width='102' height='16' title='static dummy data' class='cpu_graph'><br>
398                          <img src='gfx/icon-cpu.png' style='vertical-align: middle;'>                          <img src='gfx/icon-cpu.png' style='vertical-align: middle;'>
399                          <span id='vps_cpu_usage_txt_UID'><?php echo $cpu_count; ?> VCPU</span>                          <span class='vps_cpu_usage_txt_UID'><?php echo $cpu_count; ?> VCPU</span>
400                  </td>                  </td>
401                  <td width='100' align='right' class='small'>                  <td width='100' align='right' class='small'>
402                          <img src='usagebar.php?usage=1' width='102' height='16' title='static dummy data' class='mem_graph'><br>                          <img src='usagebar.php?usage=1' width='102' height='16' title='static dummy data' class='mem_graph'><br>
403                          <img src='gfx/icon-memory.png' style='vertical-align: middle;'>                          <img src='gfx/icon-memory.png' style='vertical-align: middle;'>
404                          <span id='vps_memory_usage_txt_UID'><?php echo format_memory($memory); ?></span>                          <span class='vps_memory_usage_txt_UID'><?php echo format_memory($memory); ?></span>
405                  </td>                  </td>
406  <!--  <!--
407                  <td width='100' align='right' class='small'>                  <td width='100' align='right' class='small'>
# Line 313  foreach($vms_array as $vm) { Line 409  foreach($vms_array as $vm) {
409                          <span id='vps_net_usage_txt_UID'>na</span>                          <span id='vps_net_usage_txt_UID'>na</span>
410                  </td>                  </td>
411  -->  -->
412                  <td width='100' align='right' class='small' valign='top'>                  <td width='100' align='right' class='small' valign='bottom'>
413                          <img src='gfx/icon-disk.png' style='vertical-align: middle;'>                          <img src='gfx/icon-disk.png' style='vertical-align: middle;'>
414                          <span id='vps_disk_usage_txt_UID'><?php echo format_storage($harddrive_size); ?></span>                          <span id='vps_disk_usage_txt_UID'><?php echo format_storage($harddrive_size); ?></span>
415                  </td>                  </td>
# Line 325  foreach($vms_array as $vm) { Line 421  foreach($vms_array as $vm) {
421    
422  <?PHP } ?>  <?PHP } ?>
423  </td></tr></table>  </td></tr></table>
424    
425    <br>
426    
427    <ul id="menu">
428            <li action="memory"><a href="#">Set Memory Size</a></li>
429            <li action="cpu"><a href="#">Set CPU Count</a></li>
430    
431    
432    <!--    <li><a href="#">Item 3</a>
433                    <ul>
434                            <li><a href="#">Item 3-1</a></li>
435                            <li><a href="#">Item 3-2</a></li>
436                            <li><a href="#">Item 3-3</a></li>
437                            <li><a href="#">Item 3-4</a></li>
438                            <li><a href="#">Item 3-5</a></li>
439                    </ul>
440            </li>
441            <li><a href="#">Item 4</a></li>
442            <li><a href="#">Item 5</a></li>-->
443    </ul>
444    
445  </body></html>  </body></html>
446    

Legend:
Removed from v.1895  
changed lines
  Added in v.2014

  ViewVC Help
Powered by ViewVC 1.1.20