2015-03-06 07:42:25 +00:00
{% extends "base.html" %}
{% load i18n %}
2019-01-24 12:02:19 +00:00
{% load staticfiles %}
2015-03-06 11:59:27 +00:00
{% block title %}{% trans "Network" %} - {{ pool }}{% endblock %}
2015-03-06 07:42:25 +00:00
{% block content %}
<!-- Page Heading -->
< div class = "row" >
< div class = "col-lg-12" >
< h1 class = "page-header" > {% trans "Network:" %} {{ pool }}< / h1 >
< ol class = "breadcrumb" >
< li class = "active" >
< i class = "fa fa-dashboard" > < / i > < a href = "{% url 'overview' compute.id %}" > {% trans "Overview" %}< / a >
< / li >
2018-09-28 10:33:21 +00:00
< li >
< i class = "fa fa-server" > < / i > < a href = "{% url 'instances' compute.id %}" > {% trans "Instances" %}< / a >
< / li >
2015-03-06 07:42:25 +00:00
< li >
< i class = "fa fa-hdd-o" > < / i > < a href = "{% url 'storages' compute.id %}" > {% trans "Storages" %}< / a >
< / li >
< li >
< i class = "fa fa-sitemap" > < / i > < a href = "{% url 'networks' compute.id %}" > {% trans "Networks" %}< / a >
< / li >
< li >
< i class = "fa fa-wifi" > < / i > < a href = "{% url 'interfaces' compute.id %}" > {% trans "Interfaces" %}< / a >
< / li >
2018-09-21 13:50:44 +00:00
< li >
< i class = "fa fa-filter" > < / i > < a href = "{% url 'nwfilters' compute.id %}" > {% trans "NWFilters" %}< / a >
< / li >
2015-03-06 07:42:25 +00:00
< li >
< i class = "fa fa-key" > < / i > < a href = "{% url 'secrets' compute.id %}" > {% trans "Secrets" %}< / a >
< / li >
< / ol >
< / div >
< / div >
<!-- /.row -->
{% include 'errors_block.html' %}
2019-01-22 13:53:10 +00:00
{% include 'messages_block.html' %}
2015-03-06 07:42:25 +00:00
< div class = "row" >
< div class = "col-xs-6 col-sm-4" >
2019-01-24 12:02:19 +00:00
< p > {% trans "Network name" %}:< / p >
< p > {% trans "Device" %}:< / p >
< p > {% trans "State" %}:< / p >
< p > {% trans "Autostart" %}:< / p >
2015-03-06 07:42:25 +00:00
< / div >
< div class = "col-xs-6 col-sm-6" >
< p > {{ pool }}< / p >
< p > {{ device }}< / p >
< p >
< form action = "" method = "post" role = "form" > {% csrf_token %}
{% ifequal state 0 %}
< input type = "submit" class = "btn btn-xs btn-default" name = "start" value = "{% trans " Start " % } " >
< input type = "submit" class = "btn btn-xs btn-default" name = "delete" value = "{% trans " Delete " % } " onclick = "return confirm('{% trans " Are you sure ? " % } ' ) " >
{% else %}
< input type = "submit" class = "btn btn-xs btn-default" name = "stop" value = "{% trans " Stop " % } " onclick = "return confirm('{% trans " Are you sure ? " % } ' ) " >
{% endifequal %}
< / form >
< / p >
< p >
< form action = "" method = "post" role = "form" > {% csrf_token %}
{% ifequal autostart 0 %}
< input type = "submit" class = "btn btn-xs btn-default" name = "set_autostart" value = "{% trans " Enable " % } " >
{% else %}
< input type = "submit" class = "btn btn-xs btn-default" name = "unset_autostart" onclick = "return confirm('{% trans " Are you sure ? " % } ' ) " value = "{% trans " Disable " % } " >
{% endifequal %}
< / form >
< / p >
< / div >
< / div >
2019-01-24 12:02:19 +00:00
< div class = "row" >
< h3 class = "page-header" > < / h3 >
< / div >
< div class = "panel-group" id = "accordion" >
< div class = "panel panel-default" >
< div class = "panel-heading" >
< a data-toggle = "collapse" data-parent = "#accordion" href = "#collapseOne" >
{% trans 'XML' %}
< / a >
< / div >
< div id = "collapseOne" class = "panel-collapse collapse" >
< div class = "panel-body" >
< form class = "form-inline" method = "post" role = "form" > {% csrf_token %}
< div class = "col-xs-12" id = "xmlheight" >
< input type = "hidden" name = "edit_xml" / >
< textarea id = "edit_editor" > {{ xml }}< / textarea >
< / div >
< button type = "submit" class = "btn btn-primary pull-right" name = "edit_network" >
{% trans "Edit" %}
< / button >
< / form >
< / div >
< / div >
2019-01-22 13:53:10 +00:00
< / div >
2019-01-24 12:02:19 +00:00
< / div >
< div class = "row" >
< h3 class = "page-header" > {% trans "IPv4 Configuration" %}< / h3 >
< / div >
< div class = "row" >
2015-03-06 07:42:25 +00:00
< div class = "col-xs-6 col-sm-4" >
< p > {% trans "IPv4 Forwarding:" %}< / p >
< p > {% trans "Network:" %}< / p >
< p > {% trans "DHCP:" %}< / p >
{% if ipv4_dhcp_range_start and ipv4_dhcp_range_end %}
< p > {% trans "Start:" %}< / p >
< p > {% trans "End:" %}< / p >
{% endif %}
< / div >
< div class = "col-xs-6 col-sm-4" >
< p >
{% ifequal ipv4_forward.0 'nat' %}
{% trans "NAT" %}
{% endifequal %}
{% ifequal ipv4_forward.0 'route' %}
{% trans "ROUTE" %}
{% endifequal %}
{% ifequal ipv4_forward.0 'bridge' %}
{% trans "BRIDGE" %}
{% endifequal %}
{% if not ipv4_forward.0 %}
{% trans "ISOLATE" %}
{% endif %}
< / p >
< p > {{ ipv4_network }}< / p >
< p >
{% if ipv4_dhcp_range_start and ipv4_dhcp_range_end %}
< span class = "text-success" > {% trans "ON" %}< / span >
{% else %}
< span class = "text-danger" > {% trans "OFF" %}< / span >
{% endif %}
< / p >
{% if ipv4_dhcp_range_start and ipv4_dhcp_range_end %}
2019-01-22 13:53:10 +00:00
< form method = "post" role = "form" > {% csrf_token %}
{% if state %}
< p > {{ ipv4_dhcp_range_start }}< / p >
< p > {{ ipv4_dhcp_range_end }}< / p >
{% else %}
< p > < input name = "range_start" value = "{{ ipv4_dhcp_range_start }}" / > < / p >
< p > < input name = "range_end" value = "{{ ipv4_dhcp_range_end }}" / > < / p >
< div class = "col-xs-10 col-sm-8" >
< input type = "submit" class = "btn btn-primary btn-block" value = "Apply"
name="modify_dhcp_range"
title="Edit DHCP Range" onclick="return confirm('{% trans "Are you sure?" %}')"/>
< / div >
{% endif %}
< / form >
2015-03-06 07:42:25 +00:00
{% endif %}
< / div >
< / div >
2019-01-24 12:02:19 +00:00
{% ifequal ipv4_forward.0 'nat' %}
{% if state %}
{% include 'modify_fixed_address.html' %}
{% endif %}
< div class = "row" >
< h3 class = "page-header" > {% trans "Fixed Address" %}< / h3 >
< / div >
{% endifequal %}
{% if fixed_address %}
< div class = "row" >
< div class = "col-xs-12" >
< div class = "panel-group" id = "accordion" >
< div class = "panel panel-default" >
< div class = "panel-heading" >
2019-01-25 12:06:51 +00:00
< a data-toggle = "collapse" data-parent = "#accordion" href = "#collapseTwo" >
2019-01-24 12:02:19 +00:00
{% trans 'Show' %}
< / a >
< / div >
2019-01-25 12:06:51 +00:00
< div id = "collapseTwo" class = "panel-collapse collapse" >
2019-01-24 12:02:19 +00:00
< div class = "panel-body" >
2019-01-22 13:53:10 +00:00
2019-01-24 12:02:19 +00:00
< div class = "input-append form-inline pull-right" >
< div class = "form-group" >
< input type = "text" class = "form-control" id = "filter_input" >
2015-03-06 07:42:25 +00:00
< / div >
2019-01-24 12:02:19 +00:00
< input type = "button" class = "btn btn-default" id = "filter_button" value = "Filter" >
< button type = "button" class = "btn btn-default" id = "filter_clear" > {% trans 'Clear' %}< / button >
< / div >
< table class = "table table-hover" >
< thead >
< tr >
< th style = "text-align: center" > {% trans "MAC" %}< / th >
< th style = "text-align: center" > {% trans "Address" %}< / th >
< th style = "text-align: center" > {% trans "Name" %}< / th >
< th style = "text-align: center" > {% trans "Action" %}< / th >
< / tr >
< / thead >
< tbody style = "text-align: center" >
{% for fix in fixed_address %}
2015-03-06 07:42:25 +00:00
< tr >
2019-01-24 12:02:19 +00:00
< form method = "post" role = "form" > {% csrf_token %}
< td > < label class = "form-control" disabled = "true" > {{ fix.mac }}< / label > < / td >
< td > < input class = "form-control" value = "{{ fix.ip }}" name = "address" / > < / td >
< td > < input class = "form-control" value = "{{ fix.name }}" name = "name" / > < / td >
< td >
< input hidden name = "mac" value = "{{ fix.mac }}" / >
< button type = "submit" class = "btn btn-sm btn-primary"
name="modify_fixed_address"
title="Edit entry" onclick="return confirm('{% trans "Are you sure?" %}')">
< i class = "glyphicon glyphicon-save" > < / i >
< / button >
< button type = "submit" class = "btn btn-sm btn-danger"
name="delete_fixed_address"
title="Delete entry" onclick="return confirm('{% trans "Are you sure?" %}')">
< i class = "glyphicon glyphicon-trash" > < / i >
< / button >
< / td >
< / form >
2015-03-06 07:42:25 +00:00
< / tr >
2019-01-24 12:02:19 +00:00
{% endfor %}
< / tbody >
< / table >
2015-03-06 07:42:25 +00:00
< / div >
< / div >
< / div >
< / div >
< / div >
2019-01-24 12:02:19 +00:00
< / div >
2015-03-06 07:42:25 +00:00
{% endif %}
{% endblock %}
{% block script %}
2015-04-06 07:51:50 +00:00
< script >
$.expr[':'].Contains = $.expr.createPseudo(function (arg) {
return function (elem) {
return $(elem).text().toUpperCase().indexOf(arg.toUpperCase()) >= 0;
};
});
$(document).ready(function () {
// add event button labeled "filter"
$('#filter_button').click(function (event) {
// get value
var filter_val = $('#filter_input').val();
if (filter_val == '') {
// show all
$('tbody tr').show();
} else {
// show only matches
$('tbody tr:Contains(\'' + filter_val + '\')').show();
// hide non-matching items
$('tbody tr:not(:Contains(\'' + filter_val + '\'))').hide();
}
2015-03-06 07:42:25 +00:00
});
2015-04-06 07:51:50 +00:00
// add event button labeled "clear"
$('#filter_clear').click(function (event) {
$('#filter_input').val('');
$('#filter_button').click();
});
2015-03-06 07:42:25 +00:00
2015-04-06 07:51:50 +00:00
// trigger filter when enter key pressed
$('#filter_input').keyup(function (event) {
if (event.keyCode == 13) {
2015-03-06 07:42:25 +00:00
$('#filter_button').click();
2015-04-06 07:51:50 +00:00
}
2015-03-06 07:42:25 +00:00
});
2015-04-06 07:51:50 +00:00
});
< / script >
2019-01-24 12:02:19 +00:00
< script src = "{% static " js / ace . js " % } " > < / script >
< script >
var editor = ace.edit("edit_editor");
editor.getSession().setMode("ace/mode/xml");
var edit_input = $('input[name="edit_xml"]');
editor.getSession().on("change", function () {
edit_input.val(editor.getSession().getValue());
});
< / script >
2015-03-06 07:42:25 +00:00
{% endblock %}