1
0
Fork 0
mirror of https://github.com/Ysurac/openmptcprouter-feeds.git synced 2025-02-13 19:11:51 +00:00
openmptcprouter-feeds/luci-app-openmptcprouter/luasrc/view/openmptcprouter/wanstatus.htm

555 lines
20 KiB
HTML
Raw Normal View History

2018-03-28 08:57:02 +00:00
<%
-- Copyright 2015 OVH (OverTheBox@ovh.net)
-- Simon Lelievre (simon.lelievre@corp.ovh.com)
-- Sebastien Duponcheel (sebastien.duponcheel@ovh.net)
--
-- This file is part of OverTheBox for OpenWrt.
--
-- OverTheBox is free software: you can redistribute it and/or modify
-- it under the terms of the GNU General Public License as published by
-- the Free Software Foundation, either version 3 of the License, or
-- (at your option) any later version.
--
-- OverTheBox is distributed in the hope that it will be useful,
-- but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-- GNU General Public License for more details.
--
-- You should have received a copy of the GNU General Public License
-- along with OverTheBox. If not, see (http://www.gnu.org/licenses/)
-%>
<%
-- Copyright 2018 Ycarus (Yannick Chabanois) ycarus@zugaina.org
--
-- Small changes to make this work with OpenMPTCProuter
-- New features:
-- * DNS detection
-- * IPv6 route received
-- * latest version available
-- * MPTCP server status
-- * Server status, errors,icon,...
-- * Many tests
2018-03-28 08:57:02 +00:00
-%>
<%+header%>
<link rel="stylesheet" type="text/css" href="<%=resource%>/openmptcprouter/css/wanstatus.css?v=git-18.120.38690-2678b12"/>
<script type="text/javascript" src="<%=resource%>/seedrandom.js?v=git-18.120.38690-2678b12"></script>
<script type="text/javascript" src="<%=resource%>/cbi.js?v=git-18.120.38690-2678b12"></script>
2018-03-28 08:57:02 +00:00
<script type="text/javascript">//<![CDATA[
var anonymize = false;
2018-11-29 17:09:59 +00:00
function getCookieValue(a) {
var b = document.cookie.match('(^|;)\\s*' + a + '\\s*=\\s*([^;]+)');
return b ? b.pop() : '';
}
2018-05-18 07:40:50 +00:00
XHR.poll(20, '/cgi-bin/luci/admin/system/openmptcprouter/interfaces_status', null,
2018-03-28 08:57:02 +00:00
function(x, mArray)
{
2018-11-29 17:09:59 +00:00
anonymize=getCookieValue("anonymize");
if (anonymize == "true")
{
mArray.openmptcprouter.wan_addr=replaceLastNChars(mArray.openmptcprouter.wan_addr,"x",6);
mArray.openmptcprouter.wan_addr6=replaceLastNChars(mArray.openmptcprouter.wan_addr6,"x",10);
mArray.openmptcprouter.service_addr=replaceLastNChars(mArray.openmptcprouter.service_addr,"x",6);
2019-08-08 06:12:16 +00:00
document.getElementById("anon").checked = true;
}
2018-03-28 08:57:02 +00:00
var status = document.getElementById('openmptcprouter_status');
var temp = '<figure class="tree">';
temp += '<ul>';
2018-12-18 13:49:18 +00:00
if (mArray !== null && mArray.openmptcprouter)
2018-03-28 08:57:02 +00:00
{
temp += '<li class="remote-from-lease">';
temp += '<a href="#">';
var equipmentIcon = '<img src="<%=resource%>/computer.png" />';
if (mArray.openmptcprouter.remote_addr)
2018-03-28 08:57:02 +00:00
{
if (mArray.openmptcprouter.remote_from_lease)
{
var title = String.format('<br /><strong>%s (%s)</strong>', mArray.openmptcprouter.remote_hostname ? mArray.openmptcprouter.remote_hostname : _('You'), mArray.openmptcprouter.remote_addr)
var statusMessageClass = "";
var statusIcon = "<%=resource%>/openmptcprouter/images/statusOK.png";
var statusMessage = "";
} else {
var title = String.format("%s (%s)",'You', mArray.openmptcprouter.remote_addr);
var statusMessageClass = "warning";
var statusIcon = "<%=resource%>/openmptcprouter/images/statusWarning.png";
var statusMessage = _('Your IP was not leased by this router');
}
} else {
2019-08-09 15:19:05 +00:00
var title = String.format('<br /><strong>%s</strong>', _('Clients'))
2018-03-28 08:57:02 +00:00
var statusMessageClass = "";
var statusIcon = "<%=resource%>/openmptcprouter/images/statusOK.png";
var statusMessage = "";
}
var content = "";
2018-03-28 08:57:02 +00:00
temp += getNetworkNodeTemplate(equipmentIcon, statusIcon, title, statusMessageClass,statusMessage,content);
temp += '</a>';
2018-03-28 08:57:02 +00:00
temp += '<li id="networkRootNode"><table><tr><td><table>';
if (mArray.wans)
{
for( var j = 0; j < mArray.wans.length; j++ )
{
temp += '<tr class="space"><td></td></tr>';
}
}
temp += '<tr><td></td></tr><tr><td><a href="#" id="omr">';
2018-03-28 08:57:02 +00:00
var equipmentIcon = '<img src="<%=resource%>/overthebox.png" style:"top: 0px;" />';
2019-07-12 16:28:36 +00:00
var title = String.format("%s (%s)", mArray.openmptcprouter.hostname, mArray.openmptcprouter.local_addr);
2018-03-28 08:57:02 +00:00
var statusMessageClass = "";
var statusIcon = "<%=resource%>/openmptcprouter/images/statusOK.png";
var statusMessage = "";
var content = "";
if (mArray.openmptcprouter.version)
{
2018-11-02 19:20:53 +00:00
//content += "Version " + mArray.openmptcprouter.version.replace(/\"/g,'');
content += "Version " + mArray.openmptcprouter.version;
if (mArray.openmptcprouter.latest_version_omr != mArray.openmptcprouter.version && mArray.openmptcprouter.latest_version_omr != "")
{
2019-07-17 20:44:26 +00:00
content += "<br><i>(" + _('Latest available version') + " " + mArray.openmptcprouter.latest_version_omr + ")</i>";
}
2018-03-28 08:57:02 +00:00
content += "<br />";
}
if (mArray.openmptcprouter.loadavg)
{
2019-07-17 20:44:26 +00:00
content += _('Load:') + " " + mArray.openmptcprouter.loadavg;
2018-03-28 08:57:02 +00:00
content += "<br />";
}
if (mArray.openmptcprouter.core_temp)
{
2019-07-17 20:44:26 +00:00
content += _('Core temp:') + " " + (mArray.openmptcprouter.core_temp / 1000).toFixed(1) + " &#176;";
2018-07-08 14:43:51 +00:00
content += "<br />";
}
2018-03-28 08:57:02 +00:00
if (mArray.openmptcprouter.uptime)
{
var date = new Date(null);
2019-07-17 20:44:26 +00:00
content += _('Uptime:') + " " + String.format('%t', mArray.openmptcprouter.uptime);
2018-03-28 08:57:02 +00:00
content += "<br />";
}
if (mArray.openmptcprouter.dhcpd)
{
for ( dhcpd in mArray.openmptcprouter.dhcpd )
{
var dhcp = mArray.openmptcprouter.dhcpd[dhcpd];
2019-07-17 20:44:26 +00:00
content += String.format('<span style="text-transform:capitalize;">%s</span> %s %s<br />', dhcp.interface, _('address:') ,dhcp.router);
content += String.format('<span style="text-transform:capitalize;">%s</span> %s %s - %s<br />', dhcp.interface, _('range:'), dhcp.range_start, dhcp.range_end);
2018-03-28 08:57:02 +00:00
}
}
if (mArray.openmptcprouter.socks_service_enabled == true)
{
if (mArray.openmptcprouter.socks_service == false)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('ShadowSocks is not running');
if (mArray.openmptcprouter.socks_service_key == false && mArray.openmptcprouter.socks_service_method !== "none")
{
2019-07-17 20:44:26 +00:00
statusMessage += ' <i>(' + _('empty key') + ')</i>';
}
statusMessage += '<br/>';
}
2018-03-28 08:57:02 +00:00
}
2019-06-11 17:27:45 +00:00
if (mArray.openmptcprouter.fsro == true)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Filesystem is readonly') + '<br/>';
2019-06-11 17:27:45 +00:00
}
2018-03-28 08:57:02 +00:00
if (mArray.openmptcprouter.tun_service == false)
{
2019-08-02 20:37:45 +00:00
statusMessage += _('VPN is not running') + '<br/>';
2018-04-17 12:48:55 +00:00
}
2018-05-13 19:24:00 +00:00
if (mArray.openmptcprouter.dns == false)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('DNS issue: can\'t resolve hostname') + '<br/>';
2018-05-13 19:24:00 +00:00
}
2018-03-28 08:57:02 +00:00
if(statusMessage !== "")
{
statusMessageClass = "error";
statusIcon = "<%=resource%>/openmptcprouter/images/statusError.png";
} else {
if (mArray.openmptcprouter.socks_service_enabled == false)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('ShadowSocks is DISABLED') + '<br/>';
}
if (mArray.openmptcprouter.tun_state == "DOWN")
{
2019-07-17 20:44:26 +00:00
statusMessage += _('VPN tunnel DOWN') + '<br/>';
}
2018-08-08 14:00:11 +00:00
if (mArray.openmptcprouter.ipv6 == "enabled")
2018-07-10 14:19:18 +00:00
{
2018-08-08 14:00:11 +00:00
if (mArray.openmptcprouter.tun6_state == "DOWN")
{
2019-07-17 20:44:26 +00:00
statusMessage += _('VPN IPv6 tunnel DOWN') + '<br/>';
2018-08-08 14:00:11 +00:00
} else if (mArray.openmptcprouter.wan_addr6 == '')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('No IPv6 access') + '<br/>';
2018-08-08 14:00:11 +00:00
}
2018-07-10 14:19:18 +00:00
}
if (statusMessage !== "")
{
statusMessageClass = "warning";
statusIcon = "<%=resource%>/openmptcprouter/images/statusWarning.png";
}
2018-03-28 08:57:02 +00:00
}
temp += getNetworkNodeTemplate(equipmentIcon, statusIcon, title, statusMessageClass,statusMessage,content);
temp += '</a>';
temp += '</td></tr>';
temp += '<tr><td><div class="vertdash" ></div></td></tr>';
temp += '<tr><td>';
temp += '<a href="<%=url('admin/system/openmptcprouter/wizard')%>" id="omr-vps">';
var statusIcon = "<%=resource%>/openmptcprouter/images/statusOK.png";
var equipmentIcon = '<img src="<%=resource%>/server.png" />';
2018-12-17 16:00:24 +00:00
if (mArray.openmptcprouter.wan_addr == mArray.openmptcprouter.service_addr)
{
2019-07-13 12:55:30 +00:00
var title = String.format("%s (%s)", mArray.openmptcprouter.vps_hostname, mArray.openmptcprouter.wan_addr);
2018-12-17 16:00:24 +00:00
} else if (mArray.openmptcprouter.wan_addr != "" && mArray.openmptcprouter.service_addr == "127.0.0.1")
{
2019-07-13 12:55:30 +00:00
var title = String.format("%s (%s)", mArray.openmptcprouter.vps_hostname, mArray.openmptcprouter.wan_addr);
2018-12-17 16:00:24 +00:00
} else if (mArray.openmptcprouter.wan_addr != "")
{
2019-07-17 20:44:26 +00:00
var title = String.format("%s (%s)", _('Direct output'), mArray.openmptcprouter.wan_addr);
2018-12-17 16:00:24 +00:00
} else if (mArray.openmptcprouter.ss_addr != "" && mArray.openmptcprouter.vps_status != "DOWN")
2018-12-14 19:49:07 +00:00
{
2019-07-13 12:55:30 +00:00
var title = String.format("%s (%s)", mArray.openmptcprouter.vps_hostname, mArray.openmptcprouter.ss_addr);
2019-02-25 19:06:54 +00:00
} else if (mArray.openmptcprouter.external_check == false) {
2019-07-13 12:55:30 +00:00
var title = String.format("%s ?", mArray.openmptcprouter.vps_hostname);
} else {
var title = "No output";
}
content = "";
statusMessage = "";
2019-03-08 19:15:51 +00:00
if (mArray.openmptcprouter.wan_addr == "" && mArray.openmptcprouter.ss_addr == "" && mArray.openmptcprouter.external_check == true)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('No VPS IP address, No WAN IP address') + '<br/>';
}
if (mArray.openmptcprouter.wan_addr !== "" && mArray.openmptcprouter.vps_status == "DOWN")
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Can\'t access and use server part') + '<br/>';
}
if (statusMessage !== "")
{
statusMessageClass = "error";
statusIcon = "<%=resource%>/openmptcprouter/images/statusError.png";
}
if (mArray.openmptcprouter.vps_status == "DOWN")
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Can\'t ping server') + '<br/>';
2019-02-25 19:06:54 +00:00
} else if (mArray.openmptcprouter.socks_service_enabled == true && mArray.openmptcprouter.ss_addr == "" && mArray.openmptcprouter.external_check == true)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Can\'t get public IP address from ShadowSocks') + '<br/>';
2019-02-25 19:06:54 +00:00
} else if (mArray.openmptcprouter.wan_addr == "" && mArray.openmptcprouter.external_check == true)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('No WAN IP address detected in less than 1 second') + '<br/>';
}
if (mArray.openmptcprouter.vps_admin == false)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Can\'t contact Server Admin Script');
if (mArray.openmptcprouter.vps_admin_error_msg !== "")
{
2019-01-08 07:46:43 +00:00
statusMessage += ' <i>(' + mArray.openmptcprouter.vps_admin_error_msg + ')</i>';
}
statusMessage += '<br/>';
}
if (mArray.openmptcprouter.vps_mptcp == "0")
{
2019-07-17 20:44:26 +00:00
statusMessage += _('MPTCP is not enabled on the server') + '<br/>';
}
if (statusMessage !== "" && statusMessageClass !== "error")
{
statusMessageClass = "warning";
statusIcon = "<%=resource%>/openmptcprouter/images/statusWarning.png";
}
2018-12-04 18:54:27 +00:00
if (mArray.openmptcprouter.vps_omr_version)
{
2019-07-17 20:44:26 +00:00
content += _('Version') + " " + mArray.openmptcprouter.vps_omr_version;
2019-04-28 06:51:40 +00:00
if (mArray.openmptcprouter.vps_kernel)
{
content += " " + mArray.openmptcprouter.vps_kernel;
}
if (mArray.openmptcprouter.latest_version_vps !== mArray.openmptcprouter.vps_omr_version && mArray.openmptcprouter.latest_version_vps !== "")
{
2019-07-17 20:44:26 +00:00
content += "<br><i>(" + _('Latest available version') + " " + mArray.openmptcprouter.latest_version_vps + ")</i>";
}
2018-11-29 13:47:53 +00:00
content += "<br />";
}
if (mArray.openmptcprouter.vps_loadavg)
{
2019-07-17 20:44:26 +00:00
content += _('Load:') + " " + mArray.openmptcprouter.vps_loadavg;
2018-11-29 13:47:53 +00:00
content += "<br />";
}
if (mArray.openmptcprouter.vps_uptime)
{
var date = new Date(null);
2019-07-17 20:44:26 +00:00
content += _('Uptime:') + " " + String.format('%t', mArray.openmptcprouter.vps_uptime);
2018-11-29 13:47:53 +00:00
content += "<br />";
}
if (mArray.openmptcprouter.server_mptcp == "disabled")
{
2019-07-17 20:44:26 +00:00
statusMessage += _('MPTCP may not be enabled on the server') + '<br/>';
statusMessageClass = "warning";
statusIcon = "<%=resource%>/openmptcprouter/images/statusWarning.png";
}
if (mArray.openmptcprouter.wan_addr6)
{
2019-07-17 20:44:26 +00:00
content += _('IPv6:') + " " + mArray.openmptcprouter.wan_addr6;
content += '<br />';
}
content += '<br />';
temp += getNetworkNodeTemplate(equipmentIcon, statusIcon, title, statusMessageClass,statusMessage,content);
temp += '</a></td></tr></table>';
temp += '</td>';
2018-03-28 08:57:02 +00:00
}
if (mArray.wans)
{
temp += '<td><ul>';
2018-07-24 15:08:27 +00:00
var master = 0;
2018-03-28 08:57:02 +00:00
for( var i = 0; i < mArray.wans.length; i++ )
{
// Get link color
mArray.wans[i].color = stringToColour(mArray.wans[i].name)
// Mwan status infos and colors
var stat = '';
var cssc = '';
switch (mArray.wans[i].status)
{
case 'OK':
stat = 'Online';
cssc = 'rgb(144, 240, 144)';
statusIcon = "<%=resource%>/openmptcprouter/images/statusOK.png";
statusMessageClass = "";
statusMessage = "";
break;
case 'ERROR':
stat = 'Offline';
cssc = 'rgb(240, 144, 144)';
statusIcon = "<%=resource%>/openmptcprouter/images/statusError.png";
statusMessageClass = "error";
statusMessage = "";
break;
default:
stat = 'Unknown';
cssc = 'rgb(144, 240, 144)';
statusIcon = "<%=resource%>/openmptcprouter/images/statusWarning.png";
statusMessageClass = "warning";
statusMessage = "";
}
// Populate info
var wanip = mArray.wans[i].wanip;
2018-11-30 14:33:59 +00:00
if (anonymize == "true")
{
wanip=replaceLastNChars(wanip,"x",6);
}
2018-03-28 08:57:02 +00:00
var ipaddr = mArray.wans[i].ipaddr;
var whois = mArray.wans[i].whois;
var multipath = mArray.wans[i].multipath;
2018-07-24 15:08:27 +00:00
if(multipath == 'master')
{
master++;
}
2018-03-28 08:57:02 +00:00
var latency = mArray.wans[i].latency;
2018-08-24 11:34:59 +00:00
var mtu = mArray.wans[i].mtu;
var gateway = mArray.wans[i].gateway;
var gw_ping = mArray.wans[i].gw_ping;
2018-07-24 15:08:27 +00:00
var server_ping = mArray.wans[i].server_ping;
2018-05-18 07:40:50 +00:00
var ipv6_discover = mArray.wans[i].ipv6_discover;
2018-06-18 08:56:32 +00:00
var multipath_available = mArray.wans[i].multipath_available;
2019-06-26 16:37:48 +00:00
var multipath_state = mArray.wans[i].multipath_state;
var duplicateif = mArray.wans[i].duplicateif;
2018-03-28 08:57:02 +00:00
// Generate template
if(mArray.openmptcprouter.remote_from_lease == true && mArray.wans.length == 1)
{
temp += String.format('<li class="subnode-only-child"><a href="%q">', mArray.wans[i].link);
2019-03-08 19:15:51 +00:00
} else {
2018-03-28 08:57:02 +00:00
temp += String.format('<li><a href="%q">', mArray.wans[i].link);
}
var equipmentIcon = String.format('<embed id="modem_%s" onload="setColorSVG(\'modem_%s\', \'%s\')" src="<%=resource%>/modem.svg" />', mArray.wans[i].name, mArray.wans[i].name, mArray.wans[i].color);
if (mArray.wans[i].gateway !== "")
{
var title = mArray.wans[i].label + " (" + mArray.wans[i].gateway + ")";
} else {
var title = mArray.wans[i].label;
}
var content = "";
2019-03-08 19:15:51 +00:00
if(ipaddr !== '')
2018-12-06 14:49:56 +00:00
{
2019-07-17 20:44:26 +00:00
content += String.format('%s <strong>%s</strong><br />',_('ip address:'), ipaddr);
2018-12-06 14:49:56 +00:00
}
2018-07-24 15:08:27 +00:00
if(wanip !== '')
{
2019-07-17 20:44:26 +00:00
content += String.format('%s <strong>%s</strong><br />',_('wan address:'), wanip);
2018-07-24 15:08:27 +00:00
}
if(whois !== '')
{
2019-07-17 20:44:26 +00:00
content += String.format('%s %s<br />',_('whois:'), whois);
2018-07-24 15:08:27 +00:00
}
if(latency !== '')
{
2019-07-17 20:44:26 +00:00
content += String.format('%s %s ms<br />',_('latency:'), latency);
2018-07-24 15:08:27 +00:00
}
2018-08-24 11:34:59 +00:00
if(mtu !== '')
{
2019-07-17 20:44:26 +00:00
content += String.format('%s %s<br />',_('mtu:'), mtu);
2018-08-24 11:34:59 +00:00
}
2018-05-18 07:40:50 +00:00
if(ipaddr == '')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('No IP defined') + '<br />'
2018-05-18 07:40:50 +00:00
}
2018-05-30 15:39:59 +00:00
if(gateway == '')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('No gateway defined') + '<br />'
2018-05-30 15:39:59 +00:00
} else if(gw_ping == 'DOWN')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Gateway DOWN') + '<br />'
2018-08-26 08:47:48 +00:00
} else if(multipath_available == 'ERROR')
2018-06-18 08:56:32 +00:00
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Multipath seems to be blocked on the connection') + '<br />'
}
2018-07-24 15:08:27 +00:00
if(server_ping == 'DOWN')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('No Server ping response after 1 second') + '<br />'
2018-07-24 15:08:27 +00:00
}
if (stat == 'Offline' && ipaddr != '' && ipaddr == mArray.wans[i].gateway)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Wan IP and gateway are identical') + '<br />';
statusMessageClass = "error";
}
2019-07-13 21:23:01 +00:00
if(multipath == 'master')
2018-07-24 15:08:27 +00:00
{
2019-07-13 21:23:01 +00:00
if (master > 1)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Multipath master already defined') + '<br />';
2019-07-13 21:23:01 +00:00
statusMessageClass = "error";
}
if(multipath_state !== 'on' && multipath_state !== '')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Multipath current state is ') + multipath_state + '<br />';
2019-07-13 21:23:01 +00:00
statusMessageClass = "error";
}
} else {
if(multipath !== multipath_state && multipath_state !== '')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Multipath current state is ') + multipath_state + '<br />';
2019-07-13 21:23:01 +00:00
statusMessageClass = "error";
}
2019-06-26 16:37:48 +00:00
}
if(duplicateif)
{
2019-07-17 20:44:26 +00:00
statusMessage += _('Network interface duplicated') + '<br />';
statusMessageClass = "error";
}
2018-05-18 07:40:50 +00:00
if(ipv6_discover == 'DETECTED')
{
2019-07-17 20:44:26 +00:00
statusMessage += _('IPv6 route received') + '<br />'
2018-05-18 07:40:50 +00:00
}
2018-07-24 15:08:27 +00:00
content += String.format('multipath: %s<br />',multipath);
2018-03-28 08:57:02 +00:00
if(mArray.wans[i].qos && mArray.wans[i].download > 0 && mArray.wans[i].upload > 0)
{
2019-07-17 20:44:26 +00:00
content += String.format('%s %s/%s kbps (%s)',_('traffic control:'), mArray.wans[i].download, mArray.wans[i].upload, mArray.wans[i].qos)
2018-03-28 08:57:02 +00:00
}
temp += getNetworkNodeTemplate(equipmentIcon, statusIcon, title, statusMessageClass,statusMessage,content);
temp += '</a></li>';
}
temp += '</ul></td>';
temp += '</tr></table>';
2018-03-28 08:57:02 +00:00
}
temp += '</li>';
// Close tree
temp += '</ul>';
temp += '</figure>';
status.innerHTML = temp;
}
);
function setColorSVG(embed_id, color)
{
var embed = document.getElementById(embed_id);
try {
svg = embed.getSVGDocument ? embed.getSVGDocument() : embed.contentDocument;
}
catch(e) {
svg = document.embeds[embed_id].getSVGDocument();
}
if(svg)
{
var back = svg.getElementById('backgound_modem');
back.setAttribute('style', 'fill: ' + color + ';fill-opacity:0.6;');
}
}
function getNetworkNodeTemplate(equipmentIcon, statusIcon, title, statusMessageClass, statusMessage, content)
{
return String.format('<div class="network-node">' +
'<div class="equipment-icon">%s</div>' +
'<div class="status-icon"><img src="%s" /></div>' +
'<div class="info">' +
'<div class="title">%s</div>' +
'<div class="status-message %s">%s</div>' +
'<div class="content">%s</div>' +
'<div class="clear"></div>' +
'</div>' +
'<div class="clear"></div>' +
'</div>',
equipmentIcon, statusIcon, title, statusMessageClass, statusMessage, content);
2018-03-28 08:57:02 +00:00
}
function stringToColour(str) {
if(str == "wan1")
return "BlueViolet";
if(str == "wan2")
return "DeepSkyBlue";
if(str == "wan3")
return "LightGreen";
if(str == "wan4")
return "PowderBlue";
if(str == "wan5")
return "PaleGreen";
if(str == "wan6")
return "YellowGreen";
if(str == "wan7")
return "SeaGreen";
if(str == "wan8")
return "SteelBlue";
// Generate a color folowing the name
Math.seedrandom(str);
var rand = Math.random() * Math.pow(255,3);
Math.seedrandom(); // don't leave a non-random seed in the generator
for (var i = 0, colour = "#"; i < 3; colour += ("00" + ((rand >> i++ * 8) & 0xFF).toString(16)).slice(-2));
return colour;
}
2018-11-29 17:09:59 +00:00
function setAnonymize(data)
{
2018-11-29 17:09:59 +00:00
document.cookie="anonymize=" + data.checked + "; path=/cgi-bin/luci/";
location.reload();
}
var replaceLastNChars = function(str, replace, num) {
if (str == "") return str;
return str.slice(0, -num) + Array(num + 1).join(replace);
};
2018-03-28 08:57:02 +00:00
//]]></script>
<h2><%:Network overview%></h2>
<fieldset id="interface_field" class="cbi-section">
<!-- <legend><%:Network overview%></legen> -->
2018-05-18 07:40:50 +00:00
<div id="openmptcprouter_status"><img src="<%=resource%>/spinner.gif" /></div>
2018-03-28 08:57:02 +00:00
</fieldset>
<form class="inline">
<div class="cbi-map">
<h3>Settings</h3>
<fieldset class="cbi-section">
<div class="cbi-value">
2019-08-09 15:19:05 +00:00
<label class="cbi-value-title">Anonymize public IPs</label>
<div class="cbi-value-field">
2019-08-08 06:12:16 +00:00
<input type="checkbox" name="anon" id="anon" class="cbi-input-checkbox" value="1" onclick="setAnonymize(this)" \>
</div>
</div>
</fieldset>
</div>
</form>
2018-03-28 08:57:02 +00:00
<%+footer%>