summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-olsr/luasrc
diff options
context:
space:
mode:
Diffstat (limited to 'applications/luci-olsr/luasrc')
-rw-r--r--applications/luci-olsr/luasrc/controller/olsr.lua167
-rw-r--r--applications/luci-olsr/luasrc/view/status-olsr/hna.htm7
-rw-r--r--applications/luci-olsr/luasrc/view/status-olsr/index.htm6
-rw-r--r--applications/luci-olsr/luasrc/view/status-olsr/routes.htm7
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>