From 38aa51a39141af9432a957579dffc0e6932c63c9 Mon Sep 17 00:00:00 2001 From: Patrick Grimm Date: Tue, 2 Jul 2013 22:31:04 +0000 Subject: [PATCH] luci-olsr: add interface and wifi stats to public olsr-neighb site --- .../luci-olsr/luasrc/controller/olsr.lua | 136 ++++++++++++++---- .../luasrc/view/status-olsr/neighbors.htm | 52 ++++--- 2 files changed, 137 insertions(+), 51 deletions(-) diff --git a/applications/luci-olsr/luasrc/controller/olsr.lua b/applications/luci-olsr/luasrc/controller/olsr.lua index 20bf25ba1c..4623f132c1 100644 --- a/applications/luci-olsr/luasrc/controller/olsr.lua +++ b/applications/luci-olsr/luasrc/controller/olsr.lua @@ -9,7 +9,7 @@ function index() local uci = luci.model.uci.cursor_state() uci:foreach("olsrd", "olsrd", function(s) - if s.SmartGateway and s.SmartGateway == "yes" then has_smartgw = true end + if s.SmartGateway and s.SmartGateway == "yes" then has_smartgw = true end end) local page = node("admin", "status", "olsr") @@ -56,9 +56,9 @@ function index() end local page = node("admin", "status", "olsr", "interfaces") - page.target = call("action_interfaces") - page.title = _("Interfaces") - page.order = 70 + page.target = call("action_interfaces") + page.title = _("Interfaces") + page.order = 70 local ol = entry( {"admin", "services", "olsrd"}, @@ -84,7 +84,7 @@ function index() odsp = entry( {"admin", "services", "olsrd", "display"}, cbi("olsr/olsrddisplay"), _("Display") - ) + ) oplg.leaf = true oplg.subindex = true @@ -106,8 +106,8 @@ function action_json() local http = require "luci.http" local utl = require "luci.util" - local jsonreq4 = utl.exec("echo /status | nc 127.0.0.1 9090") - local jsonreq6 = utl.exec("echo /status | nc ::1 9090") + local jsonreq4 = utl.exec("echo /status | nc 127.0.0.1 9090") + local jsonreq6 = utl.exec("echo /status | nc ::1 9090") http.prepare_content("application/json") if #jsonreq4 < 1 then @@ -130,7 +130,16 @@ function action_neigh(json) local uci = require "luci.model.uci".cursor_state() local resolve = uci:get("luci_olsr", "general", "resolve") - luci.sys.net.routes(function(r) if r.dest:prefix() == 0 then defaultgw = r.gateway:string() end end) + local ntm = require "luci.model.network".init() + local devices = ntm:get_wifidevs() + local sys = require "luci.sys" + local assoclist = {} + + luci.sys.net.routes(function(r) + if r.dest:prefix() == 0 then + defaultgw = r.gateway:string() + end + end) local function compare(a,b) if a.proto == b.proto then @@ -140,13 +149,80 @@ function action_neigh(json) end end + for _, dev in ipairs(devices) do + for _, net in ipairs(dev:get_wifinets()) do + assoclist[#assoclist+1] = {} + assoclist[#assoclist]['ifname'] = net.iwdata.ifname + assoclist[#assoclist]['network'] = net.iwdata.network + assoclist[#assoclist]['device'] = net.iwdata.device + assoclist[#assoclist]['list'] = net.iwinfo.assoclist + end + end + for k, v in ipairs(data) do + local interface + local snr = 1 + local signal = 1 + local noise = 1 + local arptable = sys.net.arptable() + local mac + local rmac + local lmac + local ip + if resolve == "1" then hostname = nixio.getnameinfo(v.remoteIP, nil, 100) if hostname then v.hostname = hostname end end + if v.proto == '4' then + uci:foreach("network", "interface",function(vif) + if vif.ipaddr and vif.ipaddr == v.localIP then + interface = vif['.name'] or vif.interface + lmac = string.lower(vif.macaddr or "") + return + end + end) + for _, arpt in ipairs(arptable) do + ip = arpt['IP address'] + if ip == v.remoteIP then + rmac = string.lower(arpt['HW address'] or "") + end + end + for _, val in ipairs(assoclist) do + if val.network == interface and val.list then + for assocmac, assot in pairs(val.list) do + assocmac = string.lower(assocmac or "") + if rmac == assocmac then + signal = tonumber(assot.signal) + noise = tonumber(assot.noise) + snr = signal/noise + end + end + end + end + elseif v.proto == '6' then + uci:foreach("network", "interface",function(vif) + if vif.ip6addr and string.gsub(vif.ip6addr, "/64", "") == v.localIP then + interface = vif['.name'] or vif.interface + return + end + end) + end + if interface then + v.interface = interface + end + v.snr = snr + v.signal = signal + v.noise = noise + if rmac then + v.remoteMAC = rmac + end + if lmac then + v.localMAC = lmac + end + if defaultgw == v.remoteIP then v.defaultgw = 1 end @@ -229,7 +305,7 @@ function action_hna() end end if v.validityTime then - v.validityTime = tonumber(string.format("%.0f", v.validityTime / 1000)) + v.validityTime = tonumber(string.format("%.0f", v.validityTime / 1000)) end end @@ -289,12 +365,13 @@ end -- Internal function fetch_jsoninfo(otable) + local uci = require "luci.model.uci".cursor_state() local utl = require "luci.util" local json = require "luci.json" - local jsonreq4 = utl.exec("echo /" .. otable .. " | nc 127.0.0.1 9090") - local jsondata4 = {} - local jsonreq6 = utl.exec("echo /" .. otable .. " | nc ::1 9090") - local jsondata6 = {} + local jsonreq4 = utl.exec("echo /" .. otable .. " | nc 127.0.0.1 9090") + local jsondata4 = {} + local jsonreq6 = utl.exec("echo /" .. otable .. " | nc ::1 9090") + local jsondata6 = {} local data4 = {} local data6 = {} local has_v4 = False @@ -305,36 +382,37 @@ function fetch_jsoninfo(otable) return nil, 0, 0, true end - if #jsonreq4 ~= 0 then + if #jsonreq4 ~= 0 then has_v4 = 1 - jsondata4 = json.decode(jsonreq4) + jsondata4 = json.decode(jsonreq4) if otable == 'status' then - data4 = jsondata4 + data4 = jsondata4 or {} else - data4 = jsondata4[otable] + data4 = jsondata4[otable] or {} end - for k, v in ipairs(data4) do - data4[k]['proto'] = '4' + for k, v in ipairs(data4) do + data4[k]['proto'] = '4' end - end - if #jsonreq6 ~= 0 then + + end + if #jsonreq6 ~= 0 then has_v6 = 1 - jsondata6 = json.decode(jsonreq6) + jsondata6 = json.decode(jsonreq6) if otable == 'status' then - data6 = jsondata6 + data6 = jsondata6 or {} else - data6 = jsondata6[otable] + data6 = jsondata6[otable] or {} end - for k, v in ipairs(data6) do - data6[k]['proto'] = '6' - end - end + for k, v in ipairs(data6) do + data6[k]['proto'] = '6' + end + end for k, v in ipairs(data6) do table.insert(data4, v) end - return data4, has_v4, has_v6, false + return data4, has_v4, has_v6, false end diff --git a/applications/luci-olsr/luasrc/view/status-olsr/neighbors.htm b/applications/luci-olsr/luasrc/view/status-olsr/neighbors.htm index 4d84241fbd..ab61fb5b4b 100644 --- a/applications/luci-olsr/luasrc/view/status-olsr/neighbors.htm +++ b/applications/luci-olsr/luasrc/view/status-olsr/neighbors.htm @@ -3,7 +3,7 @@ LuCI - Lua Configuration Interface Copyright 2008 Steven Barth Copyright 2008 Jo-Philipp Wich Copyright 2011 Manuel Munz - + Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at @@ -31,11 +31,17 @@ if luci.http.formvalue("status") == "1" then rv[#rv+1] = { rip = link.remoteIP, + rmac = link.remoteMAC, hn = link.hostname, lip = link.localIP, + lmac = link.localMAC, + ifn = link.interface, lq = string.format("%.3f", link.linkQuality), nlq = string.format("%.3f",link.neighborLinkQuality), cost = string.format("%.3f", link.linkCost), + snr = string.format("%.3f", link.snr), + signal = string.format("%.3f", link.signal), + noise = string.format("%.3f", link.noise), color = color, dfgcolor = defaultgw_color, proto = link.proto @@ -66,36 +72,36 @@ end if (neigh.proto == '6') { s += String.format( '' + - '%s', - neigh.proto, neigh.dfgcolor, neigh.rip, neigh.rip + '%s/%s', + neigh.proto, neigh.dfgcolor, neigh.rip, neigh.rip, neigh.rmac ); } else { s += String.format( '' + - '%s', - neigh.proto, neigh.dfgcolor, neigh.rip, neigh.rip + '%s/%s', + neigh.proto, neigh.dfgcolor, neigh.rip, neigh.rip, neigh.rmac ); } if (neigh.hn) { - s += String.format( - '%s', + s += String.format( + '%s' + neigh.dfgcolor, neigh.hn, neigh.hn ); } else { s += String.format( - '?', + '?', neigh.dfgcolor ); } s += String.format( - '%s' + - '%s' + - '%s' + - '%s' + - '', - - neigh.dfgcolor, neigh.lip, neigh.dfgcolor, neigh.lq, neigh.dfgcolor, neigh.nlq, neigh.color, neigh.cost || '?' + '%s/%s/%s' + + '%s' + + '%s' + + '%s' + + '%s' + + '', + neigh.dfgcolor, neigh.ifn, neigh.lip, neigh.lmac, neigh.dfgcolor, neigh.lq, neigh.dfgcolor, neigh.nlq, neigh.color, neigh.cost, neigh.color, neigh.signal, neigh.noise, neigh.snr || '?' ); } @@ -122,6 +128,7 @@ end LQ NLQ ETX + SNR @@ -143,15 +150,16 @@ end <% if link.proto == "6" then %> - <%=link.remoteIP%> + <%=link.remoteIP%>/<%=link.remoteMAC%> <% else %> - <%=link.remoteIP%> + <%=link.remoteIP%>/<%=link.remoteMAC%> <% end %> - <%=link.hostname%> - <%=link.localIP%> - <%=string.format("%.3f", link.linkQuality)%> - <%=string.format("%.3f", link.neighborLinkQuality)%> - <%=string.format("%.3f", link.linkCost)%> + <%=link.hostname%> + <%=link.interface%>/<%=link.localIP%>/<%=link.localMAC%> + <%=string.format("%.3f", link.linkQuality)%> + <%=string.format("%.3f", link.neighborLinkQuality)%> + <%=string.format("%.3f", link.linkCost)%> + Noise: <%=string.format("%.3f", link.noise)%>"><%=string.format("%.3f", link.snr)%> <% i = ((i % 2) + 1) -- 2.30.2