modules/freifunk: Wifi status was not showing on brcm47xx.
This commit is contained in:
parent
698f7fde5e
commit
3f7179869f
1 changed files with 70 additions and 91 deletions
|
@ -1,11 +1,12 @@
|
|||
<%
|
||||
local sys = require "luci.sys"
|
||||
local twa = require "luci.tools.webadmin"
|
||||
require "luci.sys"
|
||||
require "luci.tools.webadmin"
|
||||
|
||||
-- System
|
||||
local system, model, memtotal, memcached, membuffers, memfree = sys.sysinfo()
|
||||
local uptime = twa.date_format(tonumber(sys.uptime()))
|
||||
local_time = os.date("%c")
|
||||
local load1, load5, load15 = sys.loadavg()
|
||||
|
||||
local system, model, memtotal, memcached, membuffers, memfree = luci.sys.sysinfo()
|
||||
local uptime = luci.sys.uptime()
|
||||
local load1, load5, load15 = luci.sys.loadavg()
|
||||
local load = string.format("%.2f, %.2f, %.2f", load1, load5, load15)
|
||||
local memory = string.format("%.2f MB (%.0f%% %s, %.0f%% %s, %.0f%% %s)",
|
||||
tonumber(memtotal) / 1024,
|
||||
|
@ -16,18 +17,24 @@ local memory = string.format("%.2f MB (%.0f%% %s, %.0f%% %s, %.0f%% %s)",
|
|||
100 * memfree / memtotal,
|
||||
tostring(translate("free"))
|
||||
)
|
||||
local_time = os.date("%c")
|
||||
local uptime = luci.tools.webadmin.date_format(tonumber(uptime))
|
||||
|
||||
-- wireless
|
||||
local ntm = require "luci.model.network".init()
|
||||
local devices = ntm:get_wifidevs()
|
||||
local netlist = { }
|
||||
local netdevs = { }
|
||||
local dev
|
||||
local has_iwinfo = pcall(require, "iwinfo")
|
||||
-- Wireless
|
||||
local uci = require "luci.model.uci".cursor()
|
||||
ifaces = {}
|
||||
uci:foreach("wireless", "wifi-iface", function(s)
|
||||
if s.network then
|
||||
table.insert(ifaces, s.network)
|
||||
if (uci:get("network", s.network, "ifname")) then
|
||||
has_ifaces = true
|
||||
end
|
||||
end
|
||||
end)
|
||||
|
||||
-- Routes
|
||||
local defroutev4 = sys.net.defaultroute()
|
||||
local defroutev6 = sys.net.defaultroute6 ()
|
||||
local defroutev4 = luci.sys.net.defaultroute()
|
||||
local defroutev6 = luci.sys.net.defaultroute6 ()
|
||||
|
||||
%>
|
||||
<%+header%>
|
||||
|
@ -44,18 +51,9 @@ local defroutev6 = sys.net.defaultroute6 ()
|
|||
</div>
|
||||
</div>
|
||||
|
||||
<% if devices[1] then %>
|
||||
|
||||
<% if has_ifaces == true then %>
|
||||
<div class="cbi-map">
|
||||
<h2><%:Wireless Overview%></h2>
|
||||
|
||||
<% if not has_iwinfo then %>
|
||||
<div class="errorbox">
|
||||
<strong><%:Package libiwinfo required!%></strong><br />
|
||||
<%_The <em>libiwinfo</em> package is not installed. You must install this component for working wireless configuration!%>
|
||||
</div>
|
||||
<% end %>
|
||||
|
||||
<div class="cbi-section">
|
||||
<div class="cbi-section-node">
|
||||
<table class="cbi-section-table">
|
||||
|
@ -65,22 +63,18 @@ local defroutev6 = sys.net.defaultroute6 ()
|
|||
<th class="cbi-section-table-cell"><%:SSID%></th>
|
||||
<th class="cbi-section-table-cell"><%:BSSID%></th>
|
||||
<th class="cbi-section-table-cell"><%:Channel%></th>
|
||||
<th class="cbi-section-table-cell"><%:Mode%></th>
|
||||
<th class="cbi-section-table-cell"><%:TX%>-<%:Power%></th>
|
||||
<th class="cbi-section-table-cell"><%:Interface%></th>
|
||||
<th class="cbi-section-table-cell"><%:Mode%></th><th><%:TX%>-<%:Power%></th>
|
||||
</tr>
|
||||
<%
|
||||
for _, dev in ipairs(devices) do
|
||||
local net
|
||||
for _, net in ipairs(dev:get_wifinets()) do
|
||||
netlist[#netlist+1] = net:ifname()
|
||||
netdevs[net:ifname()] = dev:name()
|
||||
|
||||
if net.iwdata.ifname then
|
||||
local signal = net.iwinfo.signal or "N/A"
|
||||
local noise = net.iwinfo.noise or "N/A"
|
||||
local q = net.iwinfo.quality or "0"
|
||||
local qmax = net.iwinfo.quality_max or "100"
|
||||
|
||||
<% for k,v in pairs(ifaces) do
|
||||
local iface = uci:get("network", v, "ifname")
|
||||
if iface then
|
||||
iwinf = luci.sys.wifi.getiwinfo(iface)
|
||||
local signal = iwinf.signal
|
||||
local noise = iwinf.noise
|
||||
local q = iwinf.quality
|
||||
local qmax = iwinf.quality_max
|
||||
local qperc = q / qmax * 100
|
||||
|
||||
if qperc == 0 then
|
||||
|
@ -99,19 +93,12 @@ local defroutev6 = sys.net.defaultroute6 ()
|
|||
|
||||
signal_string = "<img src='"..resource.."/icons/"..icon.."' title='Signal: "..signal.." db / Noise: "..noise.." db' alt='Signal Quality'></img>"
|
||||
|
||||
local ssid = net.iwinfo.ssid or "N/A"
|
||||
local bssid = net.iwinfo.bssid or "N/A"
|
||||
local chan = net.iwinfo.channel or "N/A"
|
||||
local mode = net.iwinfo.mode or "N/A"
|
||||
local txpwr = net.iwinfo.txpower or "N/A"
|
||||
if txpwr ~= "N/A" then
|
||||
txpwr = txpwr.." dbm"
|
||||
end
|
||||
local bitrate = net.iwinfo.bitrate or "N/A"
|
||||
if bitrate ~= "N/A" then
|
||||
bitrate = ( bitrate / 1000 ).."Mb/s"
|
||||
end
|
||||
local interface = net.iwdata.ifname or "N/A"
|
||||
local ssid = iwinf.ssid
|
||||
local bssid = iwinf.bssid
|
||||
local chan = iwinf.channel
|
||||
local mode = iwinf.mode
|
||||
local txpwr = iwinf.txpower.." dbm"
|
||||
local bitrate = (iwinf.bitrate / 1000).."Mb/s"
|
||||
%>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-1">
|
||||
<td class="cbi-value-field"><%=signal_string%></td>
|
||||
|
@ -119,13 +106,10 @@ local defroutev6 = sys.net.defaultroute6 ()
|
|||
<td class="cbi-value-field"><%=ssid%></td>
|
||||
<td class="cbi-value-field"><%=bssid%></td>
|
||||
<td class="cbi-value-field"><%=chan%></td>
|
||||
<td class="cbi-value-field"><%=mode%></td>
|
||||
<td class="cbi-value-field"><%=txpwr%></td>
|
||||
<td class="cbi-value-field"><%=interface%></td>
|
||||
<td class="cbi-value-field"><%=mode%></td><td><%=txpwr%></td>
|
||||
</tr>
|
||||
<% end
|
||||
end
|
||||
end %>
|
||||
<% end %>
|
||||
<% end %>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -137,42 +121,37 @@ local defroutev6 = sys.net.defaultroute6 ()
|
|||
<div class="cbi-section">
|
||||
<div class="cbi-section-node">
|
||||
<table class="cbi-section-table">
|
||||
|
||||
<% if not defroutev4 and not defroutev6 then %>
|
||||
<%:No default routes known.%>
|
||||
<%else%>
|
||||
<% if not defroutev4 and not defroutev6 then %>
|
||||
<%:No defaultroutes known.%>
|
||||
<%else%>
|
||||
<tr class="cbi-section-table-titles">
|
||||
<th class="cbi-section-table-cell"><%:Network%></th>
|
||||
<th class="cbi-section-table-cell"><%:Interface%></th>
|
||||
<th class="cbi-section-table-cell"><%:Gateway%></th>
|
||||
<th class="cbi-section-table-cell"><%:Metric%></th>
|
||||
</tr>
|
||||
|
||||
<% if defroutev4 then %>
|
||||
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-1">
|
||||
<td class="cbi-value-field"><%=defroutev4.dest:string()%></td>
|
||||
<td class="cbi-value-field"><%=defroutev4.device%></td>
|
||||
<td class="cbi-value-field"><%=defroutev4.gateway:string()%></td>
|
||||
<td class="cbi-value-field"><%=defroutev4.metric%></td>
|
||||
</tr>
|
||||
|
||||
<% end
|
||||
if defroutev6 then %>
|
||||
|
||||
<% end %>
|
||||
<% if defroutev6 then %>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-2">
|
||||
<td class="cbi-value-field"><%=defroutev6.dest:string()%></td>
|
||||
<td class="cbi-value-field"><%=defroutev6.device%></td>
|
||||
<td class="cbi-value-field"><%=defroutev6.nexthop:string()%></td>
|
||||
<td class="cbi-value-field"><%=defroutev6.metric%></td>
|
||||
</tr>
|
||||
|
||||
<% end %>
|
||||
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<% end %>
|
||||
|
||||
<%+footer%>
|
||||
|
||||
|
|
Loading…
Reference in a new issue