diff options
4 files changed, 153 insertions, 34 deletions
diff --git a/applications/luci-olsr/luasrc/controller/olsr.lua b/applications/luci-olsr/luasrc/controller/olsr.lua index 7e6b3e8fd8..83f77582ba 100644 --- a/applications/luci-olsr/luasrc/controller/olsr.lua +++ b/applications/luci-olsr/luasrc/controller/olsr.lua @@ -179,52 +179,157 @@ function action_mid() luci.template.render("status-olsr/mid", {mids=data.MID}) end +function action_smartgw() + local data = fetch_txtinfo("gateways") + + if not data or not data.Gateways then + luci.template.render("status-olsr/error_olsr") + return nil + end + + local function compare(a, b) + return a["ETX"] < b["ETX"] + end + + table.sort(data.Gateways, compare) + + luci.template.render("status-olsr/smartgw", {gws=data.Gateways}) +end + + -- Internal function fetch_txtinfo(otable) require("luci.sys") + local uci = require "luci.model.uci".cursor_state() otable = otable or "" - local rawdata = luci.sys.httpget("http://127.0.0.1:2006/"..otable) + local rawdata = luci.sys.httpget("http://127.0.0.1:2006/"..otable) + local rawdatav6 = luci.sys.httpget("http://[::1]:2006/"..otable) + local data = {} + local dataindex = 0 + local name = "" + + if #rawdata ~= 0 then + local tables = luci.util.split(luci.util.trim(rawdata), "\r?\n\r?\n", nil, true) + + for i, tbl in ipairs(tables) do + local lines = luci.util.split(tbl, "\r?\n", nil, true) + name = table.remove(lines, 1):sub(8) + local keys = luci.util.split(table.remove(lines, 1), "\t") + local split = #keys - 1 + if not data[name] then + data[name] = {} + end - if #rawdata == 0 then - if nixio.fs.access("/proc/net/ipv6_route", "r") then - rawdata = luci.sys.httpget("http://[::1]:2006/"..otable) - if #rawdata == 0 then - return nil + for j, line in ipairs(lines) do + dataindex = ( dataindex + 1 ) + di = dataindex + local fields = luci.util.split(line, "\t", split) + data[name][di] = {} + for k, key in pairs(keys) do + if key == "Remote IP" or key == "Dest. IP" or key == "Gateway IP" or key == "Gateway" then + hostname = nixio.getnameinfo(fields[k], "inet") + if hostname then + data[name][di][key] = fields[k] + data[name][di]["Hostname"] = hostname + else + data[name][di][key] = fields[k] + end + elseif key == "Local IP" then + data[name][di][key] = fields[k] + data[name][di]['Local Device'] = fields[k] + uci:foreach("network", "interface", + function(s) + localip = string.gsub(fields[k], ' ', '') + if s.ipaddr == localip then + data[name][di]['Local Device'] = s['.name'] or interface + end + end) + elseif key == "Interface" then + data[name][di][key] = fields[k] + uci:foreach("network", "interface", + function(s) + interface = string.gsub(fields[k], ' ', '') + if s.ifname == interface then + data[name][di][key] = s['.name'] or interface + end + end) + else + data[name][di][key] = fields[k] + end + end + if data[name][di].Linkcost then + data[name][di].LinkQuality, + data[name][di].NLQ, + data[name][di].ETX = + data[name][di].Linkcost:match("([%w.]+)/([%w.]+)[%s]+([%w.]+)") + end end - else - return nil end end - local data = {} - - local tables = luci.util.split(luci.util.trim(rawdata), "\r?\n\r?\n", nil, true) - - - for i, tbl in ipairs(tables) do - local lines = luci.util.split(tbl, "\r?\n", nil, true) - local name = table.remove(lines, 1):sub(8) - local keys = luci.util.split(table.remove(lines, 1), "\t") - local split = #keys - 1 - - data[name] = {} - - for j, line in ipairs(lines) do + if #rawdatav6 ~= 0 then + local tables = luci.util.split(luci.util.trim(rawdatav6), "\r?\n\r?\n", nil, true) + for i, tbl in ipairs(tables) do + local lines = luci.util.split(tbl, "\r?\n", nil, true) + name = table.remove(lines, 1):sub(8) + local keys = luci.util.split(table.remove(lines, 1), "\t") + local split = #keys - 1 + if not data[name] then + data[name] = {} + end + for j, line in ipairs(lines) do + dataindex = ( dataindex + 1 ) + di = dataindex local fields = luci.util.split(line, "\t", split) - data[name][j] = {} + data[name][di] = {} for k, key in pairs(keys) do - data[name][j][key] = fields[k] + if key == "Remote IP" then + hostname = nixio.getnameinfo(fields[k], "inet6") + if hostname then + data[name][di][key] = "[" .. fields[k] .. "]" + data[name][di]["Hostname"] = hostname + else + data[name][di][key] = "[" .. fields[k] .. "]" + end + elseif key == "Local IP" then + data[name][di][key] = fields[k] + data[name][di]['Local Device'] = fields[k] + uci:foreach("network", "interface", + function(s) + local localip = string.gsub(fields[k], ' ', '') + if s.ip6addr then + local ip6addr = string.gsub(s.ip6addr, '\/.*', '') + if ip6addr == localip then + data[name][di]['Local Device'] = s['.name'] or s.interface + end + end + end) + elseif key == "Dest. IP" then + data[name][di][key] = "[" .. fields[k] .. "]" + elseif key == "Last hop IP" then + data[name][di][key] = "[" .. fields[k] .. "]" + elseif key == "IP address" then + data[name][di][key] = "[" .. fields[k] .. "]" + elseif key == "Gateway" then + data[name][di][key] = "[" .. fields[k] .. "]" + else + data[name][di][key] = fields[k] + end end - - if data[name][j].Linkcost then - data[name][j].LinkQuality, - data[name][j].NLQ, - data[name][j].ETX = - data[name][j].Linkcost:match("([%w.]+)/([%w.]+)[%s]+([%w.]+)") + + if data[name][di].Linkcost then + data[name][di].LinkQuality, + data[name][di].NLQ, + data[name][di].ETX = + data[name][di].Linkcost:match("([%w.]+)/([%w.]+)[%s]+([%w.]+)") end end end +end - return data + + if data then + return data + end end diff --git a/applications/luci-olsr/luasrc/view/status-olsr/hna.htm b/applications/luci-olsr/luasrc/view/status-olsr/hna.htm index 0e153bbbc3..a7a14e4fad 100644 --- a/applications/luci-olsr/luasrc/view/status-olsr/hna.htm +++ b/applications/luci-olsr/luasrc/view/status-olsr/hna.htm @@ -24,7 +24,12 @@ $Id$ <% for k, route in ipairs(routes) do %> <tr> <td><%=route.Destination%></td> -<td><a href="http://<%=route.Gateway%>"><%=route.Gateway%></a></td> +<td> +<a href="http://<%=route.Gateway%>/cgi-bin-status.html"><%=route.Gateway%></a> +<% if route.Hostname then %> + / <a href="http://<%=route.Hostname%>/cgi-bin-status.html"><%=route.Hostname%></a> +<% end %> +</td> </tr> <% end %> </table> diff --git a/applications/luci-olsr/luasrc/view/status-olsr/index.htm b/applications/luci-olsr/luasrc/view/status-olsr/index.htm index fc8f76e2c9..786c859545 100644 --- a/applications/luci-olsr/luasrc/view/status-olsr/index.htm +++ b/applications/luci-olsr/luasrc/view/status-olsr/index.htm @@ -19,7 +19,9 @@ $Id$ <table class="smalltext" cellspacing="0" cellpadding="6"> <tr> <th><%:Neighbour IP%></th> +<th><%:Hostname%></th> <th><%:Local interface IP%></th> +<th><%:Device%></th> <th>LQ</th> <th>NLQ</th> <th>ETX</th> @@ -39,8 +41,10 @@ $Id$ end %> <tr> -<td><a href="http://<%=link["Remote IP"]%>/cgi-bin-nodes.html"><%=link["Remote IP"]%></a></td> +<td><a href="http://<%=link["Remote IP"]%>/cgi-bin-status.html"><%=link["Remote IP"]%></a></td> +<td><a href="http://<%=link["Hostname"]%>/cgi-bin-status.html"><%=link["Hostname"]%></a></td> <td><%=link["Local IP"]%></td> +<td><%=link["Local Device"]%></td> <td><%=link.LQ%></td> <td><%=link.NLQ%></td> <td style="background-color:<%=color%>"><%=string.format("%.3f", link.Cost)%></td> diff --git a/applications/luci-olsr/luasrc/view/status-olsr/routes.htm b/applications/luci-olsr/luasrc/view/status-olsr/routes.htm index 52bf101ccf..cad9c35884 100644 --- a/applications/luci-olsr/luasrc/view/status-olsr/routes.htm +++ b/applications/luci-olsr/luasrc/view/status-olsr/routes.htm @@ -40,7 +40,12 @@ $Id$ %> <tr> <td><%=route.Destination%></td> -<td><%=route["Gateway IP"]%></td> +<td> +<a href="http://<%=route["Gateway IP"]%>/cgi-bin-status.html"><%=route["Gateway IP"]%></a> +<% if route.Hostname then %> + / <a href="http://<%=route.Hostname%>/cgi-bin-status.html"><%=route.Hostname%></a> +<% end %> +</td> <td><%=route.Interface%></td> <td><%=route.Metric%></td> <td style="background-color:<%=color%>"><%=string.format("%.3f", tonumber(route.ETX) or 0)%></td> |