2017-10-30 02:21:34 +08:00
|
|
|
function msgShow(retcode,msg) {
|
|
|
|
if(retcode == 0) {
|
|
|
|
var alertType = 'success';
|
|
|
|
} else if(retcode == 2 || retcode == 1) {
|
|
|
|
var alertType = 'danger';
|
|
|
|
}
|
|
|
|
var htmlMsg = '<div class="alert alert-'+alertType+' alert-dismissible" role="alert"><button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">×</span></button>'+msg+'</div>';
|
|
|
|
return htmlMsg;
|
|
|
|
}
|
|
|
|
|
2017-10-28 02:40:30 +08:00
|
|
|
function createNetmaskAddr(bitCount) {
|
|
|
|
var mask=[];
|
|
|
|
for(i=0;i<4;i++) {
|
|
|
|
var n = Math.min(bitCount, 8);
|
|
|
|
mask.push(256 - Math.pow(2, 8-n));
|
|
|
|
bitCount -= n;
|
|
|
|
}
|
|
|
|
return mask.join('.');
|
|
|
|
}
|
|
|
|
|
|
|
|
function loadSummary(strInterface) {
|
2019-07-30 19:57:35 +02:00
|
|
|
$.post('/ajax/networking/get_ip_summary.php',{interface:strInterface},function(data){
|
2017-10-28 02:40:30 +08:00
|
|
|
jsonData = JSON.parse(data);
|
|
|
|
console.log(jsonData);
|
|
|
|
if(jsonData['return'] == 0) {
|
|
|
|
$('#'+strInterface+'-summary').html(jsonData['output'].join('<br />'));
|
|
|
|
} else if(jsonData['return'] == 2) {
|
|
|
|
$('#'+strInterface+'-summary').append('<div class="alert alert-danger alert-dismissible" role="alert"><button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">×</span></button>'+jsonData['output'].join('<br />')+'</div>');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function getAllInterfaces() {
|
|
|
|
$.get('/ajax/networking/get_all_interfaces.php',function(data){
|
|
|
|
jsonData = JSON.parse(data);
|
2017-10-30 02:21:34 +08:00
|
|
|
$.each(jsonData,function(ind,value){
|
|
|
|
loadSummary(value)
|
|
|
|
});
|
2017-10-28 02:40:30 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function setupTabs() {
|
|
|
|
$('a[data-toggle="tab"]').on('shown.bs.tab',function(e){
|
|
|
|
var target = $(e.target).attr('href');
|
|
|
|
if(!target.match('summary')) {
|
|
|
|
var int = target.replace("#","");
|
|
|
|
loadCurrentSettings(int);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function loadCurrentSettings(strInterface) {
|
2019-07-30 19:57:35 +02:00
|
|
|
$.post('/ajax/networking/get_int_config.php',{interface:strInterface},function(data){
|
2017-10-28 02:40:30 +08:00
|
|
|
jsonData = JSON.parse(data);
|
|
|
|
$.each(jsonData['output'],function(i,v) {
|
|
|
|
var int = v['interface'];
|
|
|
|
$.each(v,function(i2,v2) {
|
|
|
|
switch(i2) {
|
|
|
|
case "static":
|
2017-10-29 12:31:51 +08:00
|
|
|
if(v2 == 'true') {
|
2017-10-28 02:40:30 +08:00
|
|
|
$('#'+int+'-static').click();
|
2017-10-30 02:21:34 +08:00
|
|
|
$('#'+int+'-nofailover').click();
|
|
|
|
} else {
|
|
|
|
$('#'+int+'-dhcp').click();
|
2017-10-28 02:40:30 +08:00
|
|
|
}
|
|
|
|
break;
|
2017-10-30 02:21:34 +08:00
|
|
|
case "failover":
|
|
|
|
if(v2 === 'true') {
|
|
|
|
$('#'+int+'-failover').click();
|
|
|
|
} else {
|
|
|
|
$('#'+int+'-nofailover').click();
|
|
|
|
}
|
2017-10-28 02:40:30 +08:00
|
|
|
break;
|
|
|
|
case "ip_address":
|
|
|
|
var arrIPNetmask = v2.split('/');
|
|
|
|
$('#'+int+'-ipaddress').val(arrIPNetmask[0]);
|
|
|
|
$('#'+int+'-netmask').val(createNetmaskAddr(arrIPNetmask[1]));
|
|
|
|
break;
|
|
|
|
case "routers":
|
|
|
|
$('#'+int+'-gateway').val(v2);
|
|
|
|
break;
|
|
|
|
case "domain_name_server":
|
|
|
|
svrsDNS = v2.split(" ");
|
|
|
|
$('#'+int+'-dnssvr').val(svrsDNS[0]);
|
|
|
|
$('#'+int+'-dnssvralt').val(svrsDNS[1]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-10-30 02:21:34 +08:00
|
|
|
function saveNetworkSettings(int) {
|
|
|
|
|
2017-10-28 02:40:30 +08:00
|
|
|
var frmInt = $('#frm-'+int).find(':input');
|
|
|
|
var arrFormData = {};
|
|
|
|
$.each(frmInt,function(i3,v3){
|
|
|
|
if($(v3).attr('type') == 'radio') {
|
|
|
|
arrFormData[$(v3).attr('id')] = $(v3).prop('checked');
|
|
|
|
} else {
|
|
|
|
arrFormData[$(v3).attr('id')] = $(v3).val();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
arrFormData['interface'] = int;
|
|
|
|
$.post('/ajax/networking/save_int_config.php',arrFormData,function(data){
|
2017-10-30 02:21:34 +08:00
|
|
|
//console.log(data);
|
|
|
|
var jsonData = JSON.parse(data);
|
|
|
|
$('#msgNetworking').html(msgShow(jsonData['return'],jsonData['output']));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function applyNetworkSettings() {
|
|
|
|
var int = $(this).data('int');
|
|
|
|
arrFormData = {};
|
|
|
|
arrFormData['generate'] = '';
|
|
|
|
$.post('/ajax/networking/gen_int_config.php',arrFormData,function(data){
|
2017-10-28 02:40:30 +08:00
|
|
|
console.log(data);
|
2017-10-30 02:21:34 +08:00
|
|
|
var jsonData = JSON.parse(data);
|
|
|
|
$('#msgNetworking').html(msgShow(jsonData['return'],jsonData['output']));
|
2017-10-28 02:40:30 +08:00
|
|
|
});
|
2017-10-30 02:21:34 +08:00
|
|
|
}
|
|
|
|
|
2019-08-01 16:31:11 +02:00
|
|
|
$(document).on("click", ".js-add-dhcp-static-lease", function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
var container = $(".js-new-dhcp-static-lease");
|
|
|
|
var mac = $("input[name=mac]", container).val().trim();
|
|
|
|
var ip = $("input[name=ip]", container).val().trim();
|
|
|
|
if (mac == "" || ip == "") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var row = $("#js-dhcp-static-lease-row").html()
|
|
|
|
.replace("{{ mac }}", mac)
|
|
|
|
.replace("{{ ip }}", ip);
|
|
|
|
$(".js-dhcp-static-lease-container").append(row);
|
|
|
|
|
|
|
|
$("input[name=mac]", container).val("");
|
|
|
|
$("input[name=ip]", container).val("");
|
|
|
|
});
|
|
|
|
|
|
|
|
$(document).on("click", ".js-remove-dhcp-static-lease", function(e) {
|
|
|
|
e.preventDefault();
|
|
|
|
$(this).parents(".js-dhcp-static-lease-row").remove();
|
|
|
|
});
|
|
|
|
|
2019-08-01 17:37:48 +02:00
|
|
|
$(document).on("submit", ".js-dhcp-settings-form", function(e) {
|
|
|
|
$(".js-add-dhcp-static-lease").trigger("click");
|
|
|
|
});
|
|
|
|
|
2017-10-30 02:21:34 +08:00
|
|
|
function setupBtns() {
|
|
|
|
$('#btnSummaryRefresh').click(function(){getAllInterfaces();});
|
|
|
|
|
|
|
|
$('.intsave').click(function(){
|
|
|
|
var int = $(this).data('int');
|
|
|
|
saveNetworkSettings(int);
|
|
|
|
});
|
|
|
|
|
|
|
|
$('.intapply').click(function(){
|
|
|
|
applyNetworkSettings();
|
2017-10-28 02:40:30 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-08-06 22:41:29 +02:00
|
|
|
function setCSRFTokenHeader(event, xhr, settings) {
|
|
|
|
var csrfToken = $('meta[name=csrf_token]').attr('content');
|
|
|
|
if (/^(POST|PATCH|PUT|DELETE)$/i.test(settings.type)) {
|
|
|
|
xhr.setRequestHeader("X-CSRF-Token", csrfToken);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-06 22:42:50 +02:00
|
|
|
function contentLoaded() {
|
2017-10-28 02:40:30 +08:00
|
|
|
pageCurrent = window.location.href.split("?")[1].split("=")[1];
|
|
|
|
pageCurrent = pageCurrent.replace("#","");
|
2017-10-30 02:21:34 +08:00
|
|
|
$('#side-menu').metisMenu();
|
2017-10-28 02:40:30 +08:00
|
|
|
switch(pageCurrent) {
|
|
|
|
case "network_conf":
|
|
|
|
getAllInterfaces();
|
|
|
|
setupTabs();
|
|
|
|
setupBtns();
|
|
|
|
break;
|
|
|
|
}
|
2019-08-06 22:42:50 +02:00
|
|
|
}
|
2017-10-28 02:40:30 +08:00
|
|
|
|
2019-08-08 02:10:40 +02:00
|
|
|
function loadWifiStations(refresh) {
|
|
|
|
return function() {
|
|
|
|
var complete = function() { $(this).removeClass('loading-spinner'); }
|
|
|
|
var qs = refresh === true ? '?refresh' : '';
|
|
|
|
$('.js-wifi-stations')
|
|
|
|
.addClass('loading-spinner')
|
|
|
|
.empty()
|
|
|
|
.load('/ajax/networking/wifi_stations.php'+qs, complete);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
$(".js-reload-wifi-stations").on("click", loadWifiStations(true));
|
|
|
|
|
2019-08-06 22:42:50 +02:00
|
|
|
$(document)
|
|
|
|
.ajaxSend(setCSRFTokenHeader)
|
2019-08-08 02:10:40 +02:00
|
|
|
.ready(contentLoaded)
|
|
|
|
.ready(loadWifiStations());
|