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) { |
58 |
|
|
59 |
<script type='text/javascript'> |
<script type='text/javascript'> |
60 |
var menu = 0; |
var menu = 0; |
61 |
|
var menu_uuid = ''; |
62 |
|
|
63 |
|
var user = ""; |
64 |
|
var password = ""; |
65 |
|
var loggedin = false; |
66 |
|
|
67 |
|
function isLoggedIn() { |
68 |
|
if (loggedin == false) { |
69 |
|
alert("You need to login to perform this operation"); |
70 |
|
} |
71 |
|
return loggedin; |
72 |
|
} |
73 |
|
|
74 |
|
|
75 |
$(document).ready( function() { |
$(document).ready( function() { |
76 |
$("#menu").hide(); |
$("#menu").hide(); |
80 |
var session = $(this).data('session'); |
var session = $(this).data('session'); |
81 |
var conurl = $(this).data('conurl'); |
var conurl = $(this).data('conurl'); |
82 |
var name = $(this).data('name'); |
var name = $(this).data('name'); |
83 |
console(conurl,session,name); |
openConsole(conurl,session,name); |
84 |
}); |
}); |
85 |
|
|
86 |
$('#logo').click( function(event) { |
$('#logo').click( function() { |
87 |
//refreshData(); |
refreshData(); |
88 |
$('#menu').show().position( {my: "left top", of: event} ); |
}); |
89 |
|
|
90 |
|
$('.settings').click( function(event) { |
91 |
|
menu_uuid = $(this).attr('uuid'); |
92 |
|
|
93 |
$('#menu').menu( { |
$('#menu').menu( { |
94 |
select: function(event2,ui) { |
select: function(event2,ui) { |
95 |
alert( ui.item.text() ); |
var action = $(ui.item).attr("action"); |
96 |
//closeMenu(); |
if (action == "memory") { |
97 |
|
doAction("setMemory", menu_uuid, ""); |
98 |
|
} |
99 |
|
if (action == "cpu") { |
100 |
|
doAction("setCPU", menu_uuid, ""); |
101 |
|
} |
102 |
}, |
}, |
103 |
create: function(event3,ui) { |
create: function(event3,ui) { |
104 |
menu = 1; |
menu = 1; |
107 |
my: "left", of: event |
my: "left", of: event |
108 |
}*/ |
}*/ |
109 |
}); |
}); |
110 |
|
$('#menu').show().position( {my: "left top", of: event} ); |
111 |
event.stopPropagation(); |
event.stopPropagation(); |
112 |
}); |
}); |
113 |
|
|
114 |
|
$('.cd').click( function(event) { |
115 |
|
var uuid = $(this).attr('uuid'); |
116 |
|
cdSelectorDialog(uuid); |
117 |
|
}); |
118 |
|
$('#loginlink').click( function(event) { |
119 |
|
loginDialog(); |
120 |
|
}); |
121 |
|
|
122 |
$(document).click( function(event) { |
$(document).click( function(event) { |
123 |
closeMenu(); |
closeMenu(); |
124 |
}); |
}); |
125 |
|
$('#dialog-login').keypress(function(e) { |
126 |
|
if (e.keyCode == $.ui.keyCode.ENTER) { |
127 |
|
loginDialogSubmit(); |
128 |
|
} |
129 |
|
}); |
130 |
}); |
}); |
131 |
|
|
132 |
|
function loginDialog() { |
133 |
|
$('#dialog-login').dialog({ |
134 |
|
modal: true, |
135 |
|
height: 210, |
136 |
|
width: 350, |
137 |
|
buttons: { |
138 |
|
Login: loginDialogSubmit |
139 |
|
} |
140 |
|
}); |
141 |
|
} |
142 |
|
function loginDialogSubmit() { |
143 |
|
var params = $('#loginform').serialize(); |
144 |
|
|
145 |
|
$.get('login.php?' + params, function(data) { |
146 |
|
if (data == "OK") { |
147 |
|
loggedin = true; |
148 |
|
username = $('#username').val(); |
149 |
|
password = $('#password').val(); |
150 |
|
|
151 |
|
$('#login').html("Logged in as <i>" + username + "</i>"); |
152 |
|
refreshData(); |
153 |
|
} else { |
154 |
|
alert(data); |
155 |
|
} |
156 |
|
$("#dialog-login").dialog( "close" ); |
157 |
|
}); |
158 |
|
} |
159 |
|
|
160 |
|
function cdSelectorDialog(uuid) { |
161 |
|
if (isLoggedIn() == false) |
162 |
|
return; |
163 |
|
|
164 |
|
$('#cdselector').html(''); |
165 |
|
$('#cdselector').load( 'getisolist.php' ); |
166 |
|
var cddata; |
167 |
|
|
168 |
|
$.getJSON('getcdinfo.php?uuid=' + uuid, function(data) { |
169 |
|
cddata = data; |
170 |
|
if (data.ISO != '') { |
171 |
|
$('#cdcurrent').html( data.ISO ); |
172 |
|
$(":button:contains('Mount')").prop("disabled", true).addClass("ui-state-disabled"); |
173 |
|
} else { |
174 |
|
$('#cdcurrent').html('<i>No ISO currently mounted</i>'); |
175 |
|
$(":button:contains('Eject')").prop("disabled", true).addClass("ui-state-disabled"); |
176 |
|
} |
177 |
|
}); |
178 |
|
|
179 |
|
$('#dialog-cd').dialog({ |
180 |
|
modal: true, |
181 |
|
width: 800, |
182 |
|
height: 300, |
183 |
|
buttons: { |
184 |
|
Mount: function() { |
185 |
|
$( this ).dialog( "close" ); |
186 |
|
var vdi = $("#cdselector").val(); |
187 |
|
cdAction("mount", cddata.VBD, vdi); |
188 |
|
}, |
189 |
|
Eject: function() { |
190 |
|
$( this ).dialog( "close" ); |
191 |
|
cdAction("eject", cddata.VBD, ""); |
192 |
|
}, |
193 |
|
Cancel: function() { |
194 |
|
$( this ).dialog( "close" ); |
195 |
|
} |
196 |
|
|
197 |
|
} |
198 |
|
}); |
199 |
|
} |
200 |
|
|
201 |
function closeMenu() { |
function closeMenu() { |
202 |
if (menu > 0) { |
if (menu > 0) { |
203 |
$("#menu").menu("destroy").hide(); |
$("#menu").menu("destroy").hide(); |
243 |
var cpuavg = $(this).find('cpuavg').text(); |
var cpuavg = $(this).find('cpuavg').text(); |
244 |
var curmem = $(this).find('curmem').text(); |
var curmem = $(this).find('curmem').text(); |
245 |
var maxmem = $(this).find('maxmem').text(); |
var maxmem = $(this).find('maxmem').text(); |
246 |
|
var cpus = $(this).find('cpus').text(); |
247 |
|
|
248 |
var mempercent = Math.round( (curmem*100) / maxmem ); |
var mempercent = Math.round( (curmem*100) / maxmem ); |
249 |
|
|
250 |
name = name.replace(" ", "_"); |
name = name.replace(/ /g, "_"); |
251 |
name = name.replace(".", "_"); |
name = name.replace(/\./g, "_"); |
252 |
|
name = name.replace(/\(/g, "_"); |
253 |
|
name = name.replace(/\)/g, "_"); |
254 |
|
|
255 |
var id = "#vm_" + name; |
var id = "#vm_" + name; |
256 |
|
|
261 |
} |
} |
262 |
|
|
263 |
vm.find('.vps_memory_usage_txt_UID').text( maxmem + " MB"); |
vm.find('.vps_memory_usage_txt_UID').text( maxmem + " MB"); |
264 |
|
vm.find('.vps_cpu_usage_txt_UID').text( cpus + " VCPU"); |
265 |
|
|
266 |
if (state == "Running") { |
if (state == "Running") { |
267 |
vm.find('.state').css("background-image", "url('gfx/vps_topgreen.png')"); |
vm.find('.state').css("background-image", "url('gfx/vps_topgreen.png')"); |
271 |
vm.find('.console').data('conurl', conurl); |
vm.find('.console').data('conurl', conurl); |
272 |
vm.find('.console').data('session', session); |
vm.find('.console').data('session', session); |
273 |
vm.find('.console').data('name', name); |
vm.find('.console').data('name', name); |
274 |
vm.find('.actionstop').show(); |
vm.find('.settings').hide(); |
275 |
vm.find('.actionstart').hide(); |
if (loggedin) { |
276 |
|
vm.find('.actionstop').show(); |
277 |
|
vm.find('.actionstart').hide(); |
278 |
|
} |
279 |
vm.find('.os').text(' - ' + os); |
vm.find('.os').text(' - ' + os); |
280 |
|
|
281 |
|
|
296 |
|
|
297 |
vm.find('.network').hide(); |
vm.find('.network').hide(); |
298 |
vm.find('.console').hide(); |
vm.find('.console').hide(); |
299 |
vm.find('.actionstop').hide(); |
vm.find('.settings').show(); |
300 |
vm.find('.actionstart').show(); |
if (loggedin) { |
301 |
|
vm.find('.actionstop').hide(); |
302 |
|
vm.find('.actionstart').show(); |
303 |
|
} |
304 |
vm.find('.cpu_graph').hide(); |
vm.find('.cpu_graph').hide(); |
305 |
vm.find('.mem_graph').hide(); |
vm.find('.mem_graph').hide(); |
306 |
} |
} |
313 |
function doAction(action, uuid, vm) { |
function doAction(action, uuid, vm) { |
314 |
var val=""; |
var val=""; |
315 |
|
|
316 |
var key = prompt("Key"); |
if (isLoggedIn() == false) |
|
if (key == "" || key == null) { |
|
317 |
return; |
return; |
318 |
} |
|
319 |
document.body.style.cursor = 'wait'; |
document.body.style.cursor = 'wait'; |
320 |
$('#vm_' + vm).find('.state').css("background-image", "url('gfx/vps_topyellow.png')"); |
$('#vm_' + vm).find('.state').css("background-image", "url('gfx/vps_topyellow.png')"); |
321 |
|
|
322 |
if (action == "setMemory") { |
if (action == "setMemory") { |
323 |
val = prompt("Set memory target"); |
val = prompt("Set memory target"); |
324 |
|
val *= (1024*1024); |
325 |
|
if (val == "" || val == null) { |
326 |
|
return; |
327 |
|
} |
328 |
|
} |
329 |
|
if (action == "setCPU") { |
330 |
|
val = prompt("Set CPU count"); |
331 |
if (val == "" || val == null) { |
if (val == "" || val == null) { |
|
alert("" + val); |
|
332 |
return; |
return; |
333 |
} |
} |
334 |
} |
} |
335 |
|
|
336 |
var url = "action.php?action=" + action + "&uuid=" + uuid + "&key=" + key + "&val=" + val;; |
var url = "action.php?action=" + action + "&uuid=" + uuid + "&key=" + password + "&val=" + val;; |
337 |
var response = $.get(url, function(data) { |
var response = $.get(url, function(data) { |
338 |
if (data != 'OK') { |
if (data != 'OK') { |
339 |
alert(data); |
alert(data); |
344 |
}); |
}); |
345 |
} |
} |
346 |
|
|
347 |
function console(url, session, name) { |
function cdAction(action, vbd,vdi) { |
348 |
|
if (isLoggedIn() == false) |
349 |
|
return; |
350 |
|
|
351 |
|
document.body.style.cursor = 'wait'; |
352 |
|
var url = "cdaction.php?action=" + action + "&VBD=" + vbd + "&key=" + password + "&VDI=" + vdi; |
353 |
|
var response = $.get(url, function(data) { |
354 |
|
if (data != 'OK') { |
355 |
|
alert(data); |
356 |
|
} |
357 |
|
document.body.style.cursor = 'default' |
358 |
|
}); |
359 |
|
|
360 |
|
} |
361 |
|
|
362 |
|
function openConsole(url, session, name) { |
363 |
if (url == '') |
if (url == '') |
364 |
return; |
return; |
365 |
|
|
366 |
var key = prompt("Key"); |
if (isLoggedIn() == false) |
|
if (key == "" || key == null) { |
|
367 |
return; |
return; |
368 |
} |
|
369 |
var url = "console.php?url=" + url + "&session=" + session + "&key=" + key + "&name=" + name; |
var url = "console.php?url=" + url + "&session=" + session + "&key=" + password + "&name=" + name; |
370 |
|
|
371 |
//window.location = url; |
//window.location = url; |
372 |
//$('#mainwindow').load(url); |
//$('#mainwindow').load(url); |
419 |
<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> |
420 |
</tr> |
</tr> |
421 |
<tr> |
<tr> |
422 |
<td width='150'></td> |
<td width='150'> |
423 |
|
<span id="login" class='small'><i>Not <a href="#" id="loginlink">logged in</a></i> |
424 |
|
</span> |
425 |
|
</td> |
426 |
<td width='150'></td> |
<td width='150'></td> |
427 |
<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'> |
428 |
<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> |
457 |
|
|
458 |
$clean_name = str_replace(" ", "_", $name); |
$clean_name = str_replace(" ", "_", $name); |
459 |
$clean_name = str_replace(".", "_", $clean_name); |
$clean_name = str_replace(".", "_", $clean_name); |
460 |
|
$clean_name = str_replace("(", "_", $clean_name); |
461 |
|
$clean_name = str_replace(")", "_", $clean_name); |
462 |
|
|
463 |
|
|
464 |
foreach ($vm["VBDs"] as $vbds) { |
foreach ($vm["VBDs"] as $vbds) { |
479 |
<td colspan='2' class='small' title='<?php echo $description;?>'><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> |
480 |
<td colspan='2' class='small' align='right'> |
<td colspan='2' class='small' align='right'> |
481 |
<span class='network'></span> |
<span class='network'></span> |
482 |
|
<a href='#' class='cd' uuid='<?php echo $uuid;?>' > |
483 |
|
<img src='gfx/icon-cd.gif' style='vertical-align: middle;'></a> |
484 |
<a href='#' style='display:none;' class='console'> |
<a href='#' style='display:none;' class='console'> |
485 |
<img src='gfx/icon-terminal.png' style='vertical-align: middle;'> |
<img src='gfx/icon-terminal.png' style='vertical-align: middle;'> |
486 |
</a> |
</a> |
487 |
|
|
488 |
|
<a href='#' style='display:none;' class='settings' uuid='<?php echo $uuid;?>'> |
489 |
|
<img src='gfx/icon-settings16.png' style='vertical-align: middle;'> |
490 |
|
</a> |
491 |
</td> |
</td> |
492 |
</tr> |
</tr> |
493 |
|
|
498 |
<span class="actionstop" style='display:none'> |
<span class="actionstop" style='display:none'> |
499 |
start | |
start | |
500 |
<a href='#' onclick="doAction('shutdown','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >stop</a> | |
<a href='#' onclick="doAction('shutdown','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >stop</a> | |
501 |
<a href='#' onclick="doAction('hardshutdown','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >force shutdown</a> | |
<a href='#' onclick="doAction('hardshutdown','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >force shutdown</a> |
|
set memory |
|
502 |
</span> |
</span> |
503 |
|
|
504 |
<span class="actionstart"> |
<span class="actionstart" style='display:none'> |
505 |
<a href='#' onclick="doAction('start','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >start</a> | |
<a href='#' onclick="doAction('start','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >start</a> | |
506 |
stop | |
stop | |
507 |
force shutdown | |
force shutdown |
|
|
|
|
<a href='#' onclick="doAction('setMemory','<?php echo $uuid;?>','<?php echo $clean_name;?>')" >set memory</a> |
|
508 |
</span> |
</span> |
509 |
|
|
510 |
</td> |
</td> |
512 |
<td width='100' align='right' class='small' valign='top'> |
<td width='100' align='right' class='small' valign='top'> |
513 |
<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> |
514 |
<img src='gfx/icon-cpu.png' style='vertical-align: middle;'> |
<img src='gfx/icon-cpu.png' style='vertical-align: middle;'> |
515 |
<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> |
516 |
</td> |
</td> |
517 |
<td width='100' align='right' class='small'> |
<td width='100' align='right' class='small'> |
518 |
<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> |
538 |
<?PHP } ?> |
<?PHP } ?> |
539 |
</td></tr></table> |
</td></tr></table> |
540 |
|
|
541 |
|
<br> |
542 |
|
|
543 |
|
<div style="display: none;"> |
544 |
|
|
545 |
|
<div id="dialog-login" title="Login"> |
546 |
|
<form id="loginform"> |
547 |
|
<table border="0"> |
548 |
|
<tr> |
549 |
|
<td>Username: </td> |
550 |
|
<td><input type="text" id="username" name="username"></td> |
551 |
|
<tr> |
552 |
|
<tr> |
553 |
|
<td>Password: </td> |
554 |
|
<td><input type="password" id="password" name="password"></td> |
555 |
|
</tr> |
556 |
|
</table> |
557 |
|
</form> |
558 |
|
</div> |
559 |
|
|
560 |
|
<div id="dialog-cd" title="Select CD"> |
561 |
|
|
562 |
|
<table border=0> |
563 |
|
<tr> |
564 |
|
<td>Current: <span id="cdcurrent"></span></td> |
565 |
|
</tr> |
566 |
|
<tr> |
567 |
|
<td> |
568 |
|
CD: <select id="cdselector"></select> |
569 |
|
</td> |
570 |
|
</tr> |
571 |
|
</table> |
572 |
|
</div> |
573 |
|
|
574 |
|
</div> |
575 |
|
|
576 |
<ul id="menu"> |
<ul id="menu"> |
577 |
<li><a href="#">Item 1</a></li> |
<li action="memory"><a href="#">Set Memory Size</a></li> |
578 |
<li><a href="#">Item 2</a></li> |
<li action="cpu"><a href="#">Set CPU Count</a></li> |
579 |
<li><a href="#">Item 3</a> |
|
580 |
|
|
581 |
|
<!-- <li><a href="#">Item 3</a> |
582 |
<ul> |
<ul> |
583 |
<li><a href="#">Item 3-1</a></li> |
<li><a href="#">Item 3-1</a></li> |
584 |
<li><a href="#">Item 3-2</a></li> |
<li><a href="#">Item 3-2</a></li> |
588 |
</ul> |
</ul> |
589 |
</li> |
</li> |
590 |
<li><a href="#">Item 4</a></li> |
<li><a href="#">Item 4</a></li> |
591 |
<li><a href="#">Item 5</a></li> |
<li><a href="#">Item 5</a></li>--> |
592 |
</ul> |
</ul> |
593 |
|
|
594 |
</body></html> |
</body></html> |