applications/luci-olsr: Add Hostnames, show v6 infos. Most parts of this are from patrick(at)lunatiki(dot)de again, thanks.
This commit is contained in:
parent
7d9af5b7bb
commit
8a37f56006
4 changed files with 156 additions and 37 deletions
|
@ -179,52 +179,157 @@ function action_mid()
|
||||||
luci.template.render("status-olsr/mid", {mids=data.MID})
|
luci.template.render("status-olsr/mid", {mids=data.MID})
|
||||||
end
|
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
|
-- Internal
|
||||||
function fetch_txtinfo(otable)
|
function fetch_txtinfo(otable)
|
||||||
require("luci.sys")
|
require("luci.sys")
|
||||||
|
local uci = require "luci.model.uci".cursor_state()
|
||||||
otable = otable or ""
|
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)
|
||||||
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
|
|
||||||
end
|
|
||||||
else
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local data = {}
|
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)
|
local tables = luci.util.split(luci.util.trim(rawdata), "\r?\n\r?\n", nil, true)
|
||||||
|
|
||||||
|
|
||||||
for i, tbl in ipairs(tables) do
|
for i, tbl in ipairs(tables) do
|
||||||
local lines = luci.util.split(tbl, "\r?\n", nil, true)
|
local lines = luci.util.split(tbl, "\r?\n", nil, true)
|
||||||
local name = table.remove(lines, 1):sub(8)
|
name = table.remove(lines, 1):sub(8)
|
||||||
local keys = luci.util.split(table.remove(lines, 1), "\t")
|
local keys = luci.util.split(table.remove(lines, 1), "\t")
|
||||||
local split = #keys - 1
|
local split = #keys - 1
|
||||||
|
if not data[name] then
|
||||||
data[name] = {}
|
data[name] = {}
|
||||||
|
end
|
||||||
|
|
||||||
for j, line in ipairs(lines) do
|
for j, line in ipairs(lines) do
|
||||||
|
dataindex = ( dataindex + 1 )
|
||||||
|
di = dataindex
|
||||||
local fields = luci.util.split(line, "\t", split)
|
local fields = luci.util.split(line, "\t", split)
|
||||||
data[name][j] = {}
|
data[name][di] = {}
|
||||||
for k, key in pairs(keys) do
|
for k, key in pairs(keys) do
|
||||||
data[name][j][key] = fields[k]
|
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
|
||||||
|
|
||||||
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.]+)")
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
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][di] = {}
|
||||||
|
for k, key in pairs(keys) do
|
||||||
|
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][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
|
||||||
|
|
||||||
|
|
||||||
|
if data then
|
||||||
return data
|
return data
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
|
@ -24,7 +24,12 @@ $Id$
|
||||||
<% for k, route in ipairs(routes) do %>
|
<% for k, route in ipairs(routes) do %>
|
||||||
<tr>
|
<tr>
|
||||||
<td><%=route.Destination%></td>
|
<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>
|
</tr>
|
||||||
<% end %>
|
<% end %>
|
||||||
</table>
|
</table>
|
||||||
|
|
|
@ -19,7 +19,9 @@ $Id$
|
||||||
<table class="smalltext" cellspacing="0" cellpadding="6">
|
<table class="smalltext" cellspacing="0" cellpadding="6">
|
||||||
<tr>
|
<tr>
|
||||||
<th><%:Neighbour IP%></th>
|
<th><%:Neighbour IP%></th>
|
||||||
|
<th><%:Hostname%></th>
|
||||||
<th><%:Local interface IP%></th>
|
<th><%:Local interface IP%></th>
|
||||||
|
<th><%:Device%></th>
|
||||||
<th>LQ</th>
|
<th>LQ</th>
|
||||||
<th>NLQ</th>
|
<th>NLQ</th>
|
||||||
<th>ETX</th>
|
<th>ETX</th>
|
||||||
|
@ -39,8 +41,10 @@ $Id$
|
||||||
end
|
end
|
||||||
%>
|
%>
|
||||||
<tr>
|
<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 IP"]%></td>
|
||||||
|
<td><%=link["Local Device"]%></td>
|
||||||
<td><%=link.LQ%></td>
|
<td><%=link.LQ%></td>
|
||||||
<td><%=link.NLQ%></td>
|
<td><%=link.NLQ%></td>
|
||||||
<td style="background-color:<%=color%>"><%=string.format("%.3f", link.Cost)%></td>
|
<td style="background-color:<%=color%>"><%=string.format("%.3f", link.Cost)%></td>
|
||||||
|
|
|
@ -40,7 +40,12 @@ $Id$
|
||||||
%>
|
%>
|
||||||
<tr>
|
<tr>
|
||||||
<td><%=route.Destination%></td>
|
<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.Interface%></td>
|
||||||
<td><%=route.Metric%></td>
|
<td><%=route.Metric%></td>
|
||||||
<td style="background-color:<%=color%>"><%=string.format("%.3f", tonumber(route.ETX) or 0)%></td>
|
<td style="background-color:<%=color%>"><%=string.format("%.3f", tonumber(route.ETX) or 0)%></td>
|
||||||
|
|
Loading…
Reference in a new issue