2017-03-08 20:53:09 +02:00
|
|
|
{% extends "base.html" %}
|
|
|
|
|
2017-06-02 01:27:17 +03:00
|
|
|
{% block styles %}
|
|
|
|
{{ super() }}
|
2017-10-07 18:39:50 +03:00
|
|
|
<style type="text/css">
|
|
|
|
.panel-transparent {
|
|
|
|
background: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.panel-transparent .panel-heading {
|
|
|
|
background: rgb(255, 255, 255); /* fallback */
|
|
|
|
background: rgba(255, 255, 255, 0.7)!important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.panel-transparent .panel-body{
|
|
|
|
background: rgb(255, 255, 255); /* fallback */
|
|
|
|
background: rgba(255, 255, 255, 0.7)!important;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
2017-06-02 01:27:17 +03:00
|
|
|
<style type="text/css">
|
|
|
|
.tg {border-collapse:collapse;border-spacing:0;}
|
|
|
|
.tg td{font-family:Arial, sans-serif;font-size:14px;padding:1px 1px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;}
|
|
|
|
.tg th{font-family:Arial, sans-serif;font-size:14px;padding:1px 1px;font-weight:normal;padding:border-style:solid;border-width:1px;overflow:hidden;word-break:normal;}
|
|
|
|
.tg .tg-yw4l{vertical-align:top}
|
|
|
|
|
2017-06-08 17:42:09 +03:00
|
|
|
@media only screen and (max-width: 768px) {
|
|
|
|
/* Force table to not be like tables anymore */
|
2017-12-15 01:00:02 +02:00
|
|
|
.no-more-tables table,
|
|
|
|
.no-more-tables thead,
|
|
|
|
.no-more-tables tbody,
|
|
|
|
.no-more-tables th,
|
|
|
|
.no-more-tables td,
|
|
|
|
.no-more-tables tr {
|
2017-06-08 17:42:09 +03:00
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Hide table headers (but not display: none;, for accessibility) */
|
2017-12-15 01:00:02 +02:00
|
|
|
.no-more-tables thead tr {
|
2017-06-08 17:42:09 +03:00
|
|
|
position: absolute;
|
|
|
|
top: -9999px;
|
|
|
|
left: -9999px;
|
|
|
|
}
|
|
|
|
|
2017-12-15 01:00:02 +02:00
|
|
|
.no-more-tables tr { border: 1px solid #ccc; }
|
2017-06-08 17:42:09 +03:00
|
|
|
|
2017-12-15 01:00:02 +02:00
|
|
|
.no-more-tables td {
|
2017-06-08 17:42:09 +03:00
|
|
|
/* Behave like a "row" */
|
|
|
|
border: none;
|
|
|
|
border-bottom: 1px solid #eee;
|
|
|
|
position: relative;
|
|
|
|
padding-left: 50%;
|
|
|
|
white-space: normal;
|
|
|
|
text-align:left;
|
|
|
|
}
|
|
|
|
|
2017-12-15 01:00:02 +02:00
|
|
|
.no-more-tables td:before {
|
2017-06-08 17:42:09 +03:00
|
|
|
/* Now like a table header */
|
2017-12-15 01:00:02 +02:00
|
|
|
/* position: absolute; */
|
2017-06-08 17:42:09 +03:00
|
|
|
/* Top/left values mimic padding */
|
|
|
|
top: 6px;
|
|
|
|
left: 6px;
|
|
|
|
width: 45%;
|
|
|
|
padding-right: 10px;
|
|
|
|
white-space: nowrap;
|
2017-12-15 01:00:02 +02:00
|
|
|
text-align: left;
|
2017-06-08 17:42:09 +03:00
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Label the data
|
|
|
|
*/
|
2017-12-15 01:00:02 +02:00
|
|
|
.no-more-tables td:before { content: attr(data-title); }
|
2017-06-08 17:42:09 +03:00
|
|
|
}
|
2017-06-02 01:27:17 +03:00
|
|
|
</style>
|
|
|
|
{% endblock %}
|
|
|
|
|
2017-05-25 08:54:33 +03:00
|
|
|
{% block scripts %}
|
|
|
|
{{ super() }}
|
|
|
|
<script type="text/javascript">
|
2017-06-02 01:27:17 +03:00
|
|
|
$('a[data-toggle="tooltip"]').tooltip({
|
|
|
|
animated: 'fade',
|
|
|
|
placement: 'bottom',
|
|
|
|
html: true
|
|
|
|
});
|
2017-05-25 08:54:33 +03:00
|
|
|
</script>
|
2017-06-07 18:04:27 +03:00
|
|
|
|
2017-03-08 20:53:09 +02:00
|
|
|
<script>
|
|
|
|
// Only run what comes next *after* the page has loaded
|
|
|
|
addEventListener("DOMContentLoaded", function() {
|
|
|
|
// Grab all of the elements with a class of command
|
|
|
|
// (which all of the buttons we just created have)
|
|
|
|
var commandButtons = document.querySelectorAll(".command");
|
|
|
|
for (var i=0, l=commandButtons.length; i<l; i++) {
|
|
|
|
var button = commandButtons[i];
|
|
|
|
// For each button, listen for the "click" event
|
|
|
|
button.addEventListener("click", function(e) {
|
|
|
|
// When a click happens, stop the button
|
|
|
|
// from submitting our form (if we have one)
|
2017-05-25 08:54:33 +03:00
|
|
|
e.preventDefault();
|
2017-03-08 20:53:09 +02:00
|
|
|
|
2017-05-25 08:54:33 +03:00
|
|
|
if (window.confirm("Are you sure?")) {
|
2017-03-08 20:53:09 +02:00
|
|
|
var clickedButton = e.target;
|
|
|
|
var command = clickedButton.value;
|
|
|
|
var vmid = clickedButton.getAttribute('vmid');
|
|
|
|
|
|
|
|
// Now we need to send the data to our server
|
|
|
|
// without reloading the page - this is the domain of
|
|
|
|
// AJAX (Asynchronous JavaScript And XML)
|
|
|
|
// We will create a new request object
|
|
|
|
// and set up a handler for the response
|
|
|
|
var request = new XMLHttpRequest();
|
|
|
|
request.onload = function() {
|
|
|
|
// We could do more interesting things with the response
|
|
|
|
// or, we could ignore it entirely
|
|
|
|
//alert(request.responseText);
|
|
|
|
};
|
|
|
|
// We point the request at the appropriate command
|
2017-10-15 14:38:38 +03:00
|
|
|
request.open("GET", "/vmanager/command/" + command + "/" + vmid, true);
|
2017-03-08 20:53:09 +02:00
|
|
|
// and then we send it off
|
|
|
|
request.send();
|
2017-06-06 16:49:32 +03:00
|
|
|
alert("command " + command + " executed.");
|
2017-06-04 17:10:38 +03:00
|
|
|
window.location.reload();
|
2017-05-25 08:54:33 +03:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2017-03-08 20:53:09 +02:00
|
|
|
}, true);
|
|
|
|
</script>
|
2017-06-02 01:27:17 +03:00
|
|
|
{% endblock %}
|
2017-03-08 20:53:09 +02:00
|
|
|
|
2017-06-02 01:27:17 +03:00
|
|
|
{% block page_content %}
|
2017-06-14 02:24:39 +03:00
|
|
|
{% if current_user.fresh_user == True %}
|
|
|
|
<div class="row">
|
|
|
|
<center>
|
|
|
|
<img class="img-responsive img-rounded" src="{{ url_for('static', filename='images/createvm.gif') }}" alt="ping">
|
|
|
|
</center><br/>
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
|
|
|
|
2017-03-08 20:53:09 +02:00
|
|
|
<div class="row">
|
2017-12-26 18:00:53 +02:00
|
|
|
|
|
|
|
{% for bridge in inv_bridges %}
|
|
|
|
<div class="col-md-12">
|
|
|
|
<div class="panel panel-info" id="deployments">
|
|
|
|
<div class="panel-heading">Private Network Manager #{{ bridge.bridge_id }}</div>
|
|
|
|
<div class="panel-body"><p>
|
|
|
|
<div class="panel-group" id="deploycubes" role="tablist" aria-multiselectable="true">
|
|
|
|
{% for deploy in bridge.inv_deployments %}
|
2018-01-11 15:19:59 +02:00
|
|
|
{% include "panel/vdc_pool.html" %}
|
2017-12-26 18:00:53 +02:00
|
|
|
{% endfor %}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
{% if inv_legacy != [] %}
|
|
|
|
<div class="col-md-12">
|
|
|
|
<div class="panel panel-info" id="legacy_deployments">
|
|
|
|
<div class="panel-heading">Network Manager</div>
|
|
|
|
<div class="panel-body"><p>
|
|
|
|
<div class="panel-group" id="deploylegacycubes" role="tablist" aria-multiselectable="true">
|
|
|
|
{% for deploy in inv_legacy %}
|
2018-01-11 15:19:59 +02:00
|
|
|
{% include "panel/vdc_pool2.html" %}
|
2017-12-26 18:00:53 +02:00
|
|
|
{% endfor %}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
|
|
|
|
2017-12-15 02:36:32 +02:00
|
|
|
|
2017-06-28 17:42:21 +03:00
|
|
|
{% if inv_domains != [] %}
|
|
|
|
<div class="col-md-12">
|
2017-06-04 17:10:38 +03:00
|
|
|
<div class="panel panel-info" id="domains">
|
2017-03-08 20:53:09 +02:00
|
|
|
<div class="panel-heading">Domains</div>
|
2017-09-21 03:08:58 +03:00
|
|
|
<div class="panel-body">
|
2017-12-15 01:00:02 +02:00
|
|
|
<div class="no-more-tables">
|
2017-06-04 17:10:38 +03:00
|
|
|
<table class="table table-hover table-striped table-condensed cf">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Name</th>
|
|
|
|
<th>Expiry Date</th>
|
2017-07-11 19:20:44 +03:00
|
|
|
<th>Time Left</th>
|
2017-06-04 17:10:38 +03:00
|
|
|
</tr>
|
|
|
|
<tbody>
|
2017-03-08 20:53:09 +02:00
|
|
|
{% for domain in inv_domains %}
|
2017-06-04 17:10:38 +03:00
|
|
|
<tr>
|
2017-06-08 17:42:09 +03:00
|
|
|
<td data-title="Domain"><b><a href="http://{{ domain.fqdn }}">{{ domain.fqdn }}</a></b></td>
|
|
|
|
<td data-title="Expiry Date">{{ domain.date_expire }}</td>
|
2017-07-13 17:32:24 +03:00
|
|
|
{% if domain.enabled == False %}
|
|
|
|
<td data-title="Time Left">EXPIRED</td>
|
|
|
|
{% else %}
|
2017-07-11 19:28:32 +03:00
|
|
|
{% if domain.warning == True %}
|
2017-07-29 04:31:44 +03:00
|
|
|
<td data-title="Time Left"><button class="btn btn-default btn-warning" onclick="window.open('/dmanager/activate/{{ domain.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew </button></td>
|
2017-07-11 19:28:32 +03:00
|
|
|
{% else %}
|
|
|
|
<td data-title="Time Left">{{ domain.daysleft }} day(s)</td>
|
|
|
|
{% endif %}
|
2017-07-11 19:20:44 +03:00
|
|
|
{% endif %}
|
|
|
|
|
2017-06-04 17:10:38 +03:00
|
|
|
</tr>
|
2017-03-08 20:53:09 +02:00
|
|
|
{% endfor %}
|
2017-06-04 17:10:38 +03:00
|
|
|
</tbody>
|
|
|
|
</table>
|
2017-06-08 17:42:09 +03:00
|
|
|
</div>
|
2017-07-29 04:31:44 +03:00
|
|
|
<!-- Address Book icon by Icons8 -->
|
2017-09-21 03:08:58 +03:00
|
|
|
<button class="btn btn-default" onclick="window.open('{{ url_for('dmanager.createdomain') }}','_self')"><img class="icon icons8-Address-Book" width="32" height="32" src=""> Order</button>
|
2017-03-08 20:53:09 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2017-09-21 03:08:58 +03:00
|
|
|
{% else %}
|
|
|
|
<!--<button class="btn btn-default btn-lg btn-block" onclick="window.open('{{ url_for('dmanager.createdomain') }}','_self')"><img class="icon icons8-Address-Book" width="32" height="32" src=""> Order</button>-->
|
2017-06-28 17:42:21 +03:00
|
|
|
{% endif %}
|
2017-03-08 20:53:09 +02:00
|
|
|
|
2017-09-21 03:08:58 +03:00
|
|
|
|
2017-06-28 17:42:21 +03:00
|
|
|
{% if inv_addresses != [] %}
|
|
|
|
<div class="col-md-12">
|
2017-06-04 17:10:38 +03:00
|
|
|
<div class="panel panel-info" id="addresses">
|
2017-10-07 18:39:50 +03:00
|
|
|
<div class="panel-heading">Communications</div>
|
2017-06-04 17:10:38 +03:00
|
|
|
<div class="panel-body"><p>
|
2017-12-15 01:00:02 +02:00
|
|
|
<img width="32" height="32" src=""> Private<br />
|
|
|
|
<div id="bridges" class="no-more-tables">
|
|
|
|
<table class="table table-hover table-striped table-condensed cf">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Unit</th>
|
|
|
|
<th>Network</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{% for bridge in inv_bridges %}
|
|
|
|
<tr>
|
|
|
|
<td data-title="Unit">{{ bridge.bridge_id }}</td>
|
|
|
|
<td data-title="Network">192.168.9.0</td>
|
|
|
|
</tr>
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<img width="32" height="32" src=""> Public<br />
|
|
|
|
<div id="routers" class="no-more-tables">
|
2017-06-04 17:10:38 +03:00
|
|
|
<table class="table table-hover table-striped table-condensed cf">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>IP</th>
|
2017-06-28 17:42:21 +03:00
|
|
|
<th>Region</th>
|
2017-06-07 18:04:27 +03:00
|
|
|
<th>Reverse DNS</th>
|
2017-06-04 17:10:38 +03:00
|
|
|
</tr>
|
2017-12-15 01:00:02 +02:00
|
|
|
</thead>
|
|
|
|
<tbody>
|
2017-06-04 17:10:38 +03:00
|
|
|
{% for address in inv_addresses %}
|
|
|
|
<tr>
|
2017-06-08 17:42:09 +03:00
|
|
|
<td data-title="IP">{{ address.ip }}</td>
|
2017-12-26 18:00:53 +02:00
|
|
|
<td data-title="Region">{{ regions[address.region_id] }}</td>
|
2017-06-08 17:42:09 +03:00
|
|
|
<td data-title="RDNS">{{ address.rdns }}</td>
|
2017-06-04 17:10:38 +03:00
|
|
|
</tr>
|
2017-12-15 01:00:02 +02:00
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
2017-06-04 17:10:38 +03:00
|
|
|
</table>
|
2017-06-08 17:42:09 +03:00
|
|
|
</div>
|
2017-12-15 01:00:02 +02:00
|
|
|
|
|
|
|
<!--<img width="32" height="32" src=""> No Public<br />-->
|
|
|
|
|
|
|
|
|
2018-01-11 15:19:59 +02:00
|
|
|
<!--<button class="btn btn-default" onclick="window.open('{{ url_for('panel.dashboard') }}','_self')"><span class="glyphicon glyphicon-plus" aria-hiddent="true"></span> Assign</button> -->
|
2017-06-04 17:10:38 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2017-06-28 17:42:21 +03:00
|
|
|
{% endif %}
|
2017-03-08 20:53:09 +02:00
|
|
|
|
2017-10-15 14:38:38 +03:00
|
|
|
{% if inv_services != [] %}
|
2017-07-31 00:10:08 +03:00
|
|
|
<div class="col-md-12">
|
|
|
|
<div class="panel panel-info" id="services">
|
|
|
|
<div class="panel-heading">Services</div>
|
2017-09-21 03:08:58 +03:00
|
|
|
<div class="panel-body">
|
2017-07-31 00:10:08 +03:00
|
|
|
<div id="no-more-tables">
|
|
|
|
<table class="table table-hover table-striped table-condensed cf">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Category</th>
|
|
|
|
<th>Description</th>
|
|
|
|
<th>Last Charged</th>
|
|
|
|
<th>Time Left</th>
|
|
|
|
</tr>
|
|
|
|
<tbody>
|
|
|
|
{% for service in inv_services %}
|
|
|
|
{% if service.enabled == False %}
|
|
|
|
<tr class="danger">
|
|
|
|
{% else %}
|
|
|
|
{% if service.warning == True %}
|
|
|
|
<tr class="warning">
|
|
|
|
{% else %}
|
|
|
|
<tr>
|
|
|
|
{% endif %}
|
|
|
|
{% endif %}
|
|
|
|
<td data-title="Category">{{ service.category }}</td>
|
|
|
|
<td data-title="Description" >{{ service.description }}</td>
|
|
|
|
<td data-title="Last Charged">{{ moment(service.date_last_charge).format('lll') }} ({{ moment(service.date_last_charge).fromNow() }})</td>
|
|
|
|
{% if service.enabled == False %}
|
|
|
|
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Activate</button></td>
|
|
|
|
{% else %}
|
|
|
|
{% if service.warning == True %}
|
|
|
|
<td data-title="Time Left"><button class="btn btn-default btn-success" onclick="window.open('/smanager/activate/{{ service.pid }}','_self');"><span class="glyphicon glyphicon-bell" aria-hidden="true"></span> Renew ({{ service.daysleft }} days left)</button></td>
|
|
|
|
{% else %}
|
|
|
|
<td data-title="Time Left">{{ service.daysleft }} day(s)</td>
|
|
|
|
{% endif %}
|
|
|
|
{% endif %}
|
|
|
|
</tr >
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
2017-10-29 23:06:54 +02:00
|
|
|
<!-- <button class="btn btn-default" onclick="window.open('{{ url_for('smanager.requestservice') }}','_self')"><img class="icon icons8-Key-2" width="32" height="32" src="">Request</button>-->
|
2017-09-21 03:08:58 +03:00
|
|
|
{% else %}
|
2017-10-15 14:38:38 +03:00
|
|
|
<!--<button class="btn btn-default btn-lg btn-block" onclick="window.open('{{ url_for('smanager.requestservice') }}','_self')"><img class="icon icons8-Key-2" width="48" height="48" src="">Request</button>-->
|
2017-09-21 03:08:58 +03:00
|
|
|
{% endif %}
|
2017-07-31 00:10:08 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2017-09-21 03:08:58 +03:00
|
|
|
|
2017-07-31 00:10:08 +03:00
|
|
|
|
2017-03-08 20:53:09 +02:00
|
|
|
</div>
|
|
|
|
|
|
|
|
|
2017-06-11 06:26:10 +03:00
|
|
|
<div class="row">
|
|
|
|
</div>
|
2017-03-08 20:53:09 +02:00
|
|
|
|
|
|
|
{% endblock %}
|
|
|
|
|