applications/luci-olsr: Add Hostnames, show v6 infos. Most parts of this are from...
authorManuel Munz <freifunk@somakoma.de>
Sun, 5 Dec 2010 15:02:44 +0000 (15:02 +0000)
committerManuel Munz <freifunk@somakoma.de>
Sun, 5 Dec 2010 15:02:44 +0000 (15:02 +0000)
applications/luci-olsr/luasrc/controller/olsr.lua
applications/luci-olsr/luasrc/view/status-olsr/hna.htm
applications/luci-olsr/luasrc/view/status-olsr/index.htm
applications/luci-olsr/luasrc/view/status-olsr/routes.htm

index 7e6b3e8fd85910038e75de207c91f85aeed12942..83f77582bace3897fb40f1978d7a784126954717 100644 (file)
@@ -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
index 0e153bbbc382824715c4787d7cd5d01300f5762f..a7a14e4fadacd9bbb3e21c30dcf10b8b6b9254c8 100644 (file)
@@ -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>
index fc8f76e2c9bf00eabc18b9a8e7961bf2434ee02d..786c859545d44ec6f471e470f2f50e93427be4b8 100644 (file)
@@ -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>
index 52bf101ccf5822505d9370ad4f20ef196534e65e..cad9c35884ba247a9d2f77217ffb0a1f50a5c560 100644 (file)
@@ -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>