mirror of
https://github.com/cytopia/devilbox.git
synced 2025-01-10 15:03:32 +00:00
115 lines
3.0 KiB
PHP
115 lines
3.0 KiB
PHP
<?php require '../config.php'; ?>
|
|
<?php loadClass('Helper')->authPage(); ?>
|
|
<?php
|
|
// Also required for JS calls (see bottom of this page)
|
|
$len_table = 4;
|
|
$len_size = 9;
|
|
?>
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<?php echo loadClass('Html')->getHead(); ?>
|
|
</head>
|
|
|
|
<body>
|
|
<?php echo loadClass('Html')->getNavbar(); ?>
|
|
|
|
<div class="container">
|
|
|
|
<h1>MySQL Databases</h1>
|
|
<br/>
|
|
<br/>
|
|
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
|
|
<?php if (!loadClass('Mysql')->isAvailable()): ?>
|
|
<p>MySQL container is not running.</p>
|
|
<?php else: ?>
|
|
<table class="table table-striped ">
|
|
<thead class="thead-inverse ">
|
|
<tr>
|
|
<th>Name</th>
|
|
<th>Charset</th>
|
|
<th>Collation</th>
|
|
<th>Tables</th>
|
|
<th>Size</th>
|
|
</th>
|
|
</thead>
|
|
<tbody>
|
|
<?php foreach (loadClass('Mysql')->getDatabases() as $name => $keys): ?>
|
|
<tr>
|
|
<td><?php echo $name;?></td>
|
|
<td><?php echo $keys['charset'];?></td>
|
|
<td><?php echo $keys['collation'];?></td>
|
|
<td><code><span class="table" id="table-<?php echo $name;?>"><?php echo str_repeat(' ', $len_table);?></span></code></td>
|
|
<td><code><span class="size" id="size-<?php echo $name;?>"><?php echo str_repeat(' ', $len_size);?></span></code></td>
|
|
</tr>
|
|
<input type="hidden" name="database[]" class="database" value="<?php echo $name;?>" />
|
|
<?php endforeach; ?>
|
|
</tbody>
|
|
</table>
|
|
<?php endif; ?>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
</div><!-- /.container -->
|
|
|
|
<?php echo loadClass('Html')->getFooter(); ?>
|
|
<script>
|
|
// self executing function here
|
|
(function() {
|
|
// your page initialization code here
|
|
// the DOM will be available here
|
|
|
|
function updateData(database) {
|
|
var xhttp = new XMLHttpRequest();
|
|
|
|
xhttp.onreadystatechange = function() {
|
|
var res = null;
|
|
var size = 0;
|
|
var tables = 0;
|
|
var i;
|
|
|
|
if (this.readyState == 4 && this.status == 200) {
|
|
res = JSON.parse(this.response);
|
|
|
|
// Normalize size output
|
|
size = res.size == 0 ? '0sss MB' : res.size + ' MB';
|
|
if (size.length < <?php echo $len_size;?>) {
|
|
for (i = size.length; i < <?php echo $len_size;?>; ++i) {
|
|
size = ' ' + size;
|
|
}
|
|
}
|
|
size = size.replace('sss', ' ');
|
|
|
|
// Normalize tables output
|
|
tables = res.table;
|
|
if (tables.length < <?php echo $len_table;?>) {
|
|
for (i = tables.length; i < <?php echo $len_table;?>; ++i) {
|
|
tables = ' ' + tables;
|
|
}
|
|
}
|
|
|
|
document.getElementById('size-' + database).innerHTML = size;
|
|
document.getElementById('table-' + database).innerHTML = tables;
|
|
}
|
|
};
|
|
xhttp.open('GET', '_ajax_callback.php?type=mysql&database=' + database, true);
|
|
xhttp.send();
|
|
}
|
|
|
|
var databases = document.getElementsByName('database[]');
|
|
var database;
|
|
|
|
for (i = 0; i < databases.length; i++) {
|
|
database = databases[i].value;
|
|
updateData(database);
|
|
}
|
|
})();
|
|
</script>
|
|
|
|
</body>
|
|
</html>
|