diff options
Diffstat (limited to 'modules')
8 files changed, 0 insertions, 813 deletions
diff --git a/modules/luci-base/luasrc/controller/admin/index.lua b/modules/luci-base/luasrc/controller/admin/index.lua index 928faa14b4..0cebfa4f57 100644 --- a/modules/luci-base/luasrc/controller/admin/index.lua +++ b/modules/luci-base/luasrc/controller/admin/index.lua @@ -71,27 +71,6 @@ function index() page.index = true toplevel_page(page, false, false) - if nixio.fs.access("/etc/config/dhcp") then - page = entry({"admin", "dhcplease_status"}, call("lease_status"), nil) - page.leaf = true - end - - local has_wifi = false - - uci:foreach("wireless", "wifi-device", - function(s) - has_wifi = true - return false - end) - - if has_wifi then - page = entry({"admin", "wireless_assoclist"}, call("wifi_assoclist"), nil) - page.leaf = true - - page = entry({"admin", "wireless_deauth"}, post("wifi_deauth"), nil) - page.leaf = true - end - page = entry({"admin", "translations"}, call("action_translations"), nil) page.leaf = true @@ -282,36 +261,3 @@ function action_ubus() luci.http.prepare_content("application/json") luci.http.write_json(response) end - -function lease_status() - local s = require "luci.tools.status" - - luci.http.prepare_content("application/json") - luci.http.write('[') - luci.http.write_json(s.dhcp_leases()) - luci.http.write(',') - luci.http.write_json(s.dhcp6_leases()) - luci.http.write(']') -end - -function wifi_assoclist() - local s = require "luci.tools.status" - - luci.http.prepare_content("application/json") - luci.http.write_json(s.wifi_assoclist()) -end - -function wifi_deauth() - local iface = luci.http.formvalue("iface") - local bssid = luci.http.formvalue("bssid") - - if iface and bssid then - luci.util.ubus("hostapd.%s" % iface, "del_client", { - addr = bssid, - deauth = true, - reason = 5, - ban_time = 60000 - }) - end - luci.http.status(200, "OK") -end diff --git a/modules/luci-base/luasrc/tools/status.lua b/modules/luci-base/luasrc/tools/status.lua deleted file mode 100644 index dc30c064c0..0000000000 --- a/modules/luci-base/luasrc/tools/status.lua +++ /dev/null @@ -1,250 +0,0 @@ --- Copyright 2011 Jo-Philipp Wich <jow@openwrt.org> --- Licensed to the public under the Apache License 2.0. - -module("luci.tools.status", package.seeall) - -local uci = require "luci.model.uci".cursor() -local ipc = require "luci.ip" - -local function dhcp_leases_common(family) - local rv = { } - local nfs = require "nixio.fs" - local sys = require "luci.sys" - local leasefile = "/tmp/dhcp.leases" - - uci:foreach("dhcp", "dnsmasq", - function(s) - if s.leasefile and nfs.access(s.leasefile) then - leasefile = s.leasefile - return false - end - end) - - local fd = io.open(leasefile, "r") - if fd then - while true do - local ln = fd:read("*l") - if not ln then - break - else - local ts, mac, ip, name, duid = ln:match("^(%d+) (%S+) (%S+) (%S+) (%S+)") - local expire = tonumber(ts) or 0 - if ts and mac and ip and name and duid then - if family == 4 and not ip:match(":") then - rv[#rv+1] = { - expires = (expire ~= 0) and os.difftime(expire, os.time()), - macaddr = ipc.checkmac(mac) or "00:00:00:00:00:00", - ipaddr = ip, - hostname = (name ~= "*") and name - } - elseif family == 6 and ip:match(":") then - rv[#rv+1] = { - expires = (expire ~= 0) and os.difftime(expire, os.time()), - ip6addr = ip, - duid = (duid ~= "*") and duid, - hostname = (name ~= "*") and name - } - end - end - end - end - fd:close() - end - - local lease6file = "/tmp/hosts/odhcpd" - uci:foreach("dhcp", "odhcpd", - function(t) - if t.leasefile and nfs.access(t.leasefile) then - lease6file = t.leasefile - return false - end - end) - local fd = io.open(lease6file, "r") - if fd then - while true do - local ln = fd:read("*l") - if not ln then - break - else - local iface, duid, iaid, name, ts, id, length, ip = ln:match("^# (%S+) (%S+) (%S+) (%S+) (-?%d+) (%S+) (%S+) (.*)") - local expire = tonumber(ts) or 0 - if ip and iaid ~= "ipv4" and family == 6 then - rv[#rv+1] = { - expires = (expire >= 0) and os.difftime(expire, os.time()), - duid = duid, - ip6addr = ip, - hostname = (name ~= "-") and name - } - elseif ip and iaid == "ipv4" and family == 4 then - rv[#rv+1] = { - expires = (expire >= 0) and os.difftime(expire, os.time()), - macaddr = sys.net.duid_to_mac(duid) or "00:00:00:00:00:00", - ipaddr = ip, - hostname = (name ~= "-") and name - } - end - end - end - fd:close() - end - - if family == 6 then - local _, lease - local hosts = sys.net.host_hints() - for _, lease in ipairs(rv) do - local mac = sys.net.duid_to_mac(lease.duid) - local host = mac and hosts[mac] - if host then - if not lease.name then - lease.host_hint = host.name or host.ipv4 or host.ipv6 - elseif host.name and lease.hostname ~= host.name then - lease.host_hint = host.name - end - end - end - end - - return rv -end - -function dhcp_leases() - return dhcp_leases_common(4) -end - -function dhcp6_leases() - return dhcp_leases_common(6) -end - -function wifi_networks() - local rv = { } - local ntm = require "luci.model.network".init() - - local dev - for _, dev in ipairs(ntm:get_wifidevs()) do - local rd = { - up = dev:is_up(), - device = dev:name(), - name = dev:get_i18n(), - networks = { } - } - - local net - for _, net in ipairs(dev:get_wifinets()) do - local a, an = nil, 0 - for _, a in pairs(net:assoclist() or {}) do - an = an + 1 - end - - rd.networks[#rd.networks+1] = { - name = net:shortname(), - link = net:adminlink(), - up = net:is_up(), - mode = net:active_mode(), - ssid = net:active_ssid(), - bssid = net:active_bssid(), - encryption = net:active_encryption(), - frequency = net:frequency(), - channel = net:channel(), - signal = net:signal(), - quality = net:signal_percent(), - noise = net:noise(), - bitrate = net:bitrate(), - ifname = net:ifname(), - country = net:country(), - txpower = net:txpower(), - txpoweroff = net:txpower_offset(), - num_assoc = an, - disabled = (dev:get("disabled") == "1" or - net:get("disabled") == "1") - } - end - - rv[#rv+1] = rd - end - - return rv -end - -function wifi_network(id) - local ntm = require "luci.model.network".init() - local net = ntm:get_wifinet(id) - if net then - local dev = net:get_device() - if dev then - return { - id = id, - name = net:shortname(), - link = net:adminlink(), - up = net:is_up(), - mode = net:active_mode(), - ssid = net:active_ssid(), - bssid = net:active_bssid(), - encryption = net:active_encryption(), - frequency = net:frequency(), - channel = net:channel(), - signal = net:signal(), - quality = net:signal_percent(), - noise = net:noise(), - bitrate = net:bitrate(), - ifname = net:ifname(), - country = net:country(), - txpower = net:txpower(), - txpoweroff = net:txpower_offset(), - disabled = (dev:get("disabled") == "1" or - net:get("disabled") == "1"), - device = { - up = dev:is_up(), - device = dev:name(), - name = dev:get_i18n() - } - } - end - end - return { } -end - -function wifi_assoclist() - local sys = require "luci.sys" - local ntm = require "luci.model.network".init() - local hosts = sys.net.host_hints() - - local assoc = {} - local _, dev, net, bss - - for _, dev in ipairs(ntm:get_wifidevs()) do - local radioname = dev:get_i18n() - - for _, net in ipairs(dev:get_wifinets()) do - local netname = net:shortname() - local netlink = net:adminlink() - local ifname = net:ifname() - - for _, bss in pairs(net:assoclist() or {}) do - local host = hosts[_] - - bss.bssid = _ - bss.ifname = ifname - bss.radio = radioname - bss.name = netname - bss.link = netlink - - bss.host_name = (host) and (host.name or host.ipv4 or host.ipv6) - bss.host_hint = (host and host.name and (host.ipv4 or host.ipv6)) and (host.ipv4 or host.ipv6) - - assoc[#assoc+1] = bss - end - end - end - - table.sort(assoc, function(a, b) - if a.radio ~= b.radio then - return a.radio < b.radio - elseif a.ifname ~= b.ifname then - return a.ifname < b.ifname - else - return a.bssid < b.bssid - end - end) - - return assoc -end diff --git a/modules/luci-base/luasrc/view/lease_status.htm b/modules/luci-base/luasrc/view/lease_status.htm deleted file mode 100644 index bbaf5986ba..0000000000 --- a/modules/luci-base/luasrc/view/lease_status.htm +++ /dev/null @@ -1,102 +0,0 @@ -<script type="text/javascript">//<![CDATA[ - XHR.poll(-1, '<%=url('admin/dhcplease_status')%>', null, - function(x, st) - { - var tb = document.getElementById('lease_status_table'); - if (st && st[0] && tb) - { - var rows = []; - - for (var i = 0; i < st[0].length; i++) - { - var timestr; - - if (st[0][i].expires === false) - timestr = '<em><%:unlimited%></em>'; - else if (st[0][i].expires <= 0) - timestr = '<em><%:expired%></em>'; - else - timestr = String.format('%t', st[0][i].expires); - - rows.push([ - st[0][i].hostname || '?', - st[0][i].ipaddr, - st[0][i].macaddr, - timestr - ]); - } - - cbi_update_table(tb, rows, '<em><%:There are no active leases.%></em>'); - } - - var tb6 = document.getElementById('lease6_status_table'); - if (st && st[1] && tb6) - { - tb6.parentNode.style.display = 'block'; - - var rows = []; - - for (var i = 0; i < st[1].length; i++) - { - var timestr; - - if (st[1][i].expires === false) - timestr = '<em><%:unlimited%></em>'; - else if (st[1][i].expires <= 0) - timestr = '<em><%:expired%></em>'; - else - timestr = String.format('%t', st[1][i].expires); - - var name = st[1][i].hostname, - hint = st[1][i].host_hint; - - rows.push([ - hint ? '%h (%h)'.format(name || '?', hint) : (name || '?'), - st[1][i].ip6addr, - st[1][i].duid, - timestr - ]); - } - - cbi_update_table(tb6, rows, '<em><%:There are no active leases.%></em>'); - } - } - ); -//]]></script> - -<div class="cbi-section"> - <h3><%:Active DHCP Leases%></h3> - <div class="table" id="lease_status_table"> - <div class="tr table-titles"> - <div class="th"><%:Hostname%></div> - <div class="th"><%:IPv4-Address%></div> - <div class="th"><%:MAC-Address%></div> - <div class="th"><%:Leasetime remaining%></div> - </div> - <div class="tr placeholder"> - <div class="td"><em><%:Collecting data...%></em></div> - </div> - </div> -</div> - -<% - local fs = require "nixio.fs" - local has_ipv6 = fs.access("/proc/net/ipv6_route") - - if has_ipv6 then --%> - <div class="cbi-section" style="display:none"> - <h3><%:Active DHCPv6 Leases%></h3> - <div class="table" id="lease6_status_table"> - <div class="tr table-titles"> - <div class="th"><%:Host%></div> - <div class="th"><%:IPv6-Address%></div> - <div class="th"><%:DUID%></div> - <div class="th"><%:Leasetime remaining%></div> - </div> - <div class="tr placeholder"> - <div class="td"><em><%:Collecting data...%></em></div> - </div> - </div> - </div> -<% end -%> diff --git a/modules/luci-base/luasrc/view/wifi_assoclist.htm b/modules/luci-base/luasrc/view/wifi_assoclist.htm deleted file mode 100644 index f6f66fbbc6..0000000000 --- a/modules/luci-base/luasrc/view/wifi_assoclist.htm +++ /dev/null @@ -1,120 +0,0 @@ -<% - local supports_deauth = {} - - local _, v - for _, v in ipairs(luci.util.ubus()) do - local iface = v:match("^hostapd%.(.+)$") - if iface then - local funcs = luci.util.ubus(v) - if type(funcs) == "table" and funcs.del_client then - supports_deauth[iface] = true - end - end - end -%> - -<script type="text/javascript">//<![CDATA[ - var supports_deauth = <%= luci.http.write_json(supports_deauth) %>; - - function wifirate(bss, rx) { - var p = rx ? 'rx_' : 'tx_', - s = '%.1f <%:Mbit/s%>, %d<%:MHz%>' - .format(bss[p+'rate'] / 1000, bss[p+'mhz']), - ht = bss[p+'ht'], vht = bss[p+'vht'], - mhz = bss[p+'mhz'], nss = bss[p+'nss'], - mcs = bss[p+'mcs'], sgi = bss[p+'short_gi']; - - if (ht || vht) { - if (vht) s += ', VHT-MCS %d'.format(mcs); - if (nss) s += ', VHT-NSS %d'.format(nss); - if (ht) s += ', MCS %s'.format(mcs); - if (sgi) s += ', <%:Short GI%>'; - } - - return s; - } - - function handleDeauth(ev) { - (new XHR()).post('<%=url('admin/wireless_deauth')%>', { - token: '<%=token%>', - iface: ev.target.getAttribute('data-iface'), - bssid: ev.target.getAttribute('data-bssid') - }, function() { - ev.target.disabled = true; - }); - } - - XHR.poll(-1, '<%=url('admin/wireless_assoclist')%>', null, - function(x, st) - { - var tb = document.getElementById('wifi_assoclist_table'); - if (st && tb) - { - var rows = []; - - st.forEach(function(bss) { - var icon; - var q = (-1 * (bss.noise - bss.signal)) / 5; - if (q < 1) - icon = "<%=resource%>/icons/signal-0.png"; - else if (q < 2) - icon = "<%=resource%>/icons/signal-0-25.png"; - else if (q < 3) - icon = "<%=resource%>/icons/signal-25-50.png"; - else if (q < 4) - icon = "<%=resource%>/icons/signal-50-75.png"; - else - icon = "<%=resource%>/icons/signal-75-100.png"; - - rows.push([ - '<span class="ifacebadge" title="%q"><img src="<%=resource%>/icons/wifi.png" /> <a href="%s">%h</a><small> (%h)</small></span>'.format( - bss.radio, - bss.link, - bss.name, - bss.ifname), - bss.bssid, - bss.host_hint ? '%h (%h)'.format(bss.host_name || '?', bss.host_hint) : (bss.host_name || '?'), - '<span class="ifacebadge" title="<%:Signal%>: %d <%:dBm%> / <%:Noise%>: %d <%:dBm%> / <%:SNR%>: %d"><img src="%s" /> %d / %d <%:dBm%></span>'.format( - bss.signal, - bss.noise, - bss.signal - bss.noise, - icon, - bss.signal, - bss.noise), - E('span', {}, [ - E('span', wifirate(bss, true)), - E('br'), - E('span', wifirate(bss, false)) - ]), - supports_deauth[bss.ifname] ? E('input', { - type: 'button', - class: 'cbi-button cbi-button-remove', - value: '<%:Disconnect%>', - 'data-bssid': bss.bssid, - 'data-iface': bss.ifname, - click: handleDeauth - }) : '-' - ]); - }); - - cbi_update_table(tb, rows, '<em><%:No information available%></em>'); - } - } - ); -//]]></script> - -<div class="table" id="wifi_assoclist_table"> - <div class="tr table-titles"> - <div class="th nowrap"><%:Network%></div> - <div class="th hide-xs"><%:MAC-Address%></div> - <div class="th nowrap"><%:Host%></div> - <div class="th nowrap"><%:Signal%> / <%:Noise%></div> - <div class="th nowrap"><%:RX Rate%> / <%:TX Rate%></div> - <% if next(supports_deauth) then %> - <div class="th right"><%:Disconnect%></div> - <% end %> - </div> - <div class="tr placeholder"> - <div class="td"><em><%:Collecting data...%></em></div> - </div> -</div> diff --git a/modules/luci-mod-network/htdocs/luci-static/resources/view/network/iface_status.js b/modules/luci-mod-network/htdocs/luci-static/resources/view/network/iface_status.js deleted file mode 100644 index 88f48d189a..0000000000 --- a/modules/luci-mod-network/htdocs/luci-static/resources/view/network/iface_status.js +++ /dev/null @@ -1,42 +0,0 @@ -requestAnimationFrame(function() { - document.querySelectorAll('[data-iface-status]').forEach(function(container) { - var network = container.getAttribute('data-iface-status'), - icon = container.querySelector('img'), - info = container.querySelector('span'); - - L.poll(5, L.url('admin/network/iface_status', network), null, function(xhr, ifaces) { - var ifc = Array.isArray(ifaces) ? ifaces[0] : null; - if (!ifc) - return; - - L.itemlist(info, [ - _('Device'), ifc.ifname, - _('Uptime'), ifc.is_up ? '%t'.format(ifc.uptime) : null, - _('MAC'), ifc.ifname ? ifc.macaddr : null, - _('RX'), ifc.ifname ? '%.2mB (%d %s)'.format(ifc.rx_bytes, ifc.rx_packets, _('Pkts.')) : null, - _('TX'), ifc.ifname ? '%.2mB (%d %s)'.format(ifc.tx_bytes, ifc.tx_packets, _('Pkts.')) : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[0] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[1] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[2] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[3] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[4] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[0] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[1] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[2] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[3] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[4] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[5] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[6] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[7] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[8] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[9] : null, - _('IPv6-PD'), ifc.ip6prefix, - null, ifc.ifname ? null : E('em', _('Interface not present or not connected yet.')) - ]); - - icon.src = L.resource('icons/%s%s.png').format(ifc.type, ifc.is_up ? '' : '_disabled'); - }); - - L.run(); - }); -}); diff --git a/modules/luci-mod-network/htdocs/luci-static/resources/view/network/network.js b/modules/luci-mod-network/htdocs/luci-static/resources/view/network/network.js deleted file mode 100644 index bab23cc3c7..0000000000 --- a/modules/luci-mod-network/htdocs/luci-static/resources/view/network/network.js +++ /dev/null @@ -1,136 +0,0 @@ -function iface_reconnect(id) { - L.halt(); - L.dom.content(document.getElementById(id + '-ifc-description'), E('em', _('Interface is reconnecting...'))); - L.post(L.url('admin/network/iface_reconnect', id), null, L.run); -} - -function iface_delete(ev) { - if (!confirm(_('Really delete this interface? The deletion cannot be undone! You might lose access to this device if you are connected via this interface'))) { - ev.preventDefault(); - return false; - } - - ev.target.previousElementSibling.value = '1'; - return true; -} - -var networks = []; - -document.querySelectorAll('[data-network]').forEach(function(n) { - networks.push(n.getAttribute('data-network')); -}); - -function render_iface(ifc) { - return E('span', { class: 'cbi-tooltip-container' }, [ - E('img', { 'class' : 'middle', 'src': L.resource('icons/%s%s.png').format( - ifc.is_alias ? 'alias' : ifc.type, - ifc.is_up ? '' : '_disabled') }), - E('span', { 'class': 'cbi-tooltip ifacebadge large' }, [ - E('img', { 'src': L.resource('icons/%s%s.png').format( - ifc.type, ifc.is_up ? '' : '_disabled') }), - L.itemlist(E('span', { 'class': 'left' }), [ - _('Type'), ifc.typename, - _('Device'), ifc.ifname, - _('Connected'), ifc.is_up ? _('yes') : _('no'), - _('MAC'), ifc.macaddr, - _('RX'), '%.2mB (%d %s)'.format(ifc.rx_bytes, ifc.rx_packets, _('Pkts.')), - _('TX'), '%.2mB (%d %s)'.format(ifc.tx_bytes, ifc.tx_packets, _('Pkts.')) - ]) - ]) - ]); -} - -L.poll(5, L.url('admin/network/iface_status', networks.join(',')), null, - function(x, ifcs) { - if (ifcs) { - for (var idx = 0; idx < ifcs.length; idx++) { - var ifc = ifcs[idx]; - - var s = document.getElementById(ifc.id + '-ifc-devices'); - if (s) { - var c = [ render_iface(ifc) ]; - - if (ifc.subdevices && ifc.subdevices.length) - { - var sifs = [ ' (' ]; - - for (var j = 0; j < ifc.subdevices.length; j++) - sifs.push(render_iface(ifc.subdevices[j])); - - sifs.push(')'); - - c.push(E('span', {}, sifs)); - } - - c.push(E('br')); - c.push(E('small', {}, ifc.is_alias ? _('Alias of "%s"').format(ifc.is_alias) : ifc.name)); - - L.dom.content(s, c); - } - - var d = document.getElementById(ifc.id + '-ifc-description'); - if (d && ifc.proto && ifc.ifname) { - var desc = null, c = []; - - if (ifc.is_dynamic) - desc = _('Virtual dynamic interface'); - else if (ifc.is_alias) - desc = _('Alias Interface'); - - if (ifc.desc) - desc = desc ? '%s (%s)'.format(desc, ifc.desc) : ifc.desc; - - L.itemlist(d, [ - _('Protocol'), desc || '?', - _('Uptime'), ifc.is_up ? '%t'.format(ifc.uptime) : null, - _('MAC'), (!ifc.is_dynamic && !ifc.is_alias && ifc.macaddr) ? ifc.macaddr : null, - _('RX'), (!ifc.is_dynamic && !ifc.is_alias) ? '%.2mB (%d %s)'.format(ifc.rx_bytes, ifc.rx_packets, _('Pkts.')) : null, - _('TX'), (!ifc.is_dynamic && !ifc.is_alias) ? '%.2mB (%d %s)'.format(ifc.tx_bytes, ifc.tx_packets, _('Pkts.')) : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[0] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[1] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[2] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[3] : null, - _('IPv4'), ifc.ipaddrs ? ifc.ipaddrs[4] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[0] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[1] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[2] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[3] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[4] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[5] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[6] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[7] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[8] : null, - _('IPv6'), ifc.ip6addrs ? ifc.ip6addrs[9] : null, - _('IPv6-PD'), ifc.ip6prefix, - _('Information'), ifc.is_auto ? null : _('Not started on boot'), - _('Error'), ifc.errors ? ifc.errors[0] : null, - _('Error'), ifc.errors ? ifc.errors[1] : null, - _('Error'), ifc.errors ? ifc.errors[2] : null, - _('Error'), ifc.errors ? ifc.errors[3] : null, - _('Error'), ifc.errors ? ifc.errors[4] : null, - ]); - } - else if (d && !ifc.proto) { - var e = document.getElementById(ifc.id + '-ifc-edit'); - if (e) e.disabled = true; - - var link = L.url('admin/system/opkg') + '?query=luci-proto'; - L.dom.content(d, [ - E('em', _('Unsupported protocol type.')), E('br'), - E('a', { href: link }, _('Install protocol extensions...')) - ]); - } - else if (d && !ifc.ifname) { - var link = L.url('admin/network/network', ifc.name) + '?tab.network.%s=physical'.format(ifc.name); - L.dom.content(d, [ - E('em', _('Network without interfaces.')), E('br'), - E('a', { href: link }, _('Assign interfaces...')) - ]); - } - else if (d) { - L.dom.content(d, E('em' ,_('Interface not present or not connected yet.'))); - } - } - } - } -); diff --git a/modules/luci-mod-network/luasrc/controller/admin/network.lua b/modules/luci-mod-network/luasrc/controller/admin/network.lua index f8623be93e..662fe8cf88 100644 --- a/modules/luci-mod-network/luasrc/controller/admin/network.lua +++ b/modules/luci-mod-network/luasrc/controller/admin/network.lua @@ -31,9 +31,6 @@ function index() end) if has_wifi then - page = entry({"admin", "network", "wireless_status"}, call("wifi_status"), nil) - page.leaf = true - page = entry({"admin", "network", "wireless_reconnect"}, post("wifi_reconnect"), nil) page.leaf = true @@ -42,9 +39,6 @@ function index() end - page = entry({"admin", "network", "iface_status"}, call("iface_status"), nil) - page.leaf = true - page = entry({"admin", "network", "iface_reconnect"}, post("iface_reconnect"), nil) page.leaf = true @@ -95,77 +89,6 @@ function index() -- end end -function iface_status(ifaces) - local netm = require "luci.model.network".init() - local rv = { } - - local iface - for iface in ifaces:gmatch("[%w%.%-_]+") do - local net = netm:get_network(iface) - local device = net and net:get_interface() - if device then - local data = { - id = iface, - desc = net:get_i18n(), - proto = net:proto(), - uptime = net:uptime(), - gwaddr = net:gwaddr(), - ipaddrs = net:ipaddrs(), - ip6addrs = net:ip6addrs(), - dnsaddrs = net:dnsaddrs(), - ip6prefix = net:ip6prefix(), - errors = net:errors(), - name = device:shortname(), - type = device:type(), - typename = device:get_type_i18n(), - ifname = device:name(), - macaddr = device:mac(), - is_up = net:is_up() and device:is_up(), - is_alias = net:is_alias(), - is_dynamic = net:is_dynamic(), - is_auto = net:is_auto(), - rx_bytes = device:rx_bytes(), - tx_bytes = device:tx_bytes(), - rx_packets = device:rx_packets(), - tx_packets = device:tx_packets(), - - subdevices = { } - } - - for _, device in ipairs(net:get_interfaces() or {}) do - data.subdevices[#data.subdevices+1] = { - name = device:shortname(), - type = device:type(), - typename = device:get_type_i18n(), - ifname = device:name(), - macaddr = device:mac(), - is_up = device:is_up(), - rx_bytes = device:rx_bytes(), - tx_bytes = device:tx_bytes(), - rx_packets = device:rx_packets(), - tx_packets = device:tx_packets(), - } - end - - rv[#rv+1] = data - else - rv[#rv+1] = { - id = iface, - name = iface, - type = "ethernet" - } - end - end - - if #rv > 0 then - luci.http.prepare_content("application/json") - luci.http.write_json(rv) - return - end - - luci.http.status(404, "No such device") -end - function iface_reconnect(iface) local netmd = require "luci.model.network".init() local net = netmd:get_network(iface) @@ -235,26 +158,6 @@ function iface_down(iface, force) luci.http.status(404, "No such interface") end -function wifi_status(devs) - local s = require "luci.tools.status" - local rv = { } - - if type(devs) == "string" then - local dev - for dev in devs:gmatch("[%w%.%-]+") do - rv[#rv+1] = s.wifi_network(dev) - end - end - - if #rv > 0 then - luci.http.prepare_content("application/json") - luci.http.write_json(rv) - return - end - - luci.http.status(404, "No such device") -end - function wifi_reconnect(radio) local rc = luci.sys.call("env -i /sbin/wifi up %s >/dev/null" % luci.util.shellquote(radio)) diff --git a/modules/luci-mod-network/luasrc/view/admin_network/iface_status.htm b/modules/luci-mod-network/luasrc/view/admin_network/iface_status.htm deleted file mode 100644 index a75b2755cd..0000000000 --- a/modules/luci-mod-network/luasrc/view/admin_network/iface_status.htm +++ /dev/null @@ -1,12 +0,0 @@ -<%+cbi/valueheader%> - -<span class="ifacebadge large"<%=attr("data-iface-status", self.network)%>> - <img src="<%=resource%>/icons/ethernet_disabled.png" /> - <span> - <em class="spinning"><%:Collecting data...%></em> - </span> -</span> - -<script type="text/javascript" src="<%=resource%>/view/network/iface_status.js"></script> - -<%+cbi/valuefooter%> |