modules/admin-full: migrate wifi overview page to wireless model
This commit is contained in:
parent
0b71cdaaad
commit
66fe827403
1 changed files with 31 additions and 79 deletions
|
@ -17,7 +17,10 @@ $Id$
|
|||
|
||||
local sys = require "luci.sys"
|
||||
local utl = require "luci.util"
|
||||
local uci = require "luci.model.uci".cursor_state()
|
||||
local uci = require "luci.model.uci".cursor()
|
||||
local wlm = require "luci.model.wireless"
|
||||
|
||||
wlm.init(uci)
|
||||
|
||||
function guess_wifi_hw(ifname)
|
||||
local name, idx = ifname:match("^([a-z]+)(%d+)")
|
||||
|
@ -69,12 +72,10 @@ $Id$
|
|||
end
|
||||
end
|
||||
|
||||
function guess_wifi_signal(info)
|
||||
local snr = -1 * ((info.noise or 0) - (info.signal or 0))
|
||||
local scale = math.floor(snr / 5)
|
||||
function guess_wifi_signal(scale)
|
||||
local icon
|
||||
|
||||
if not info.bssid or info.bssid == "00:00:00:00:00:00" then
|
||||
if scale < 0 then
|
||||
icon = resource .. "/icons/signal-none.png"
|
||||
elseif scale < 1 then
|
||||
icon = resource .. "/icons/signal-0.png"
|
||||
|
@ -91,56 +92,7 @@ $Id$
|
|||
return icon
|
||||
end
|
||||
|
||||
function percent_wifi_signal(info)
|
||||
local qc = info.quality or 0
|
||||
local qm = info.quality_max or 0
|
||||
|
||||
if info.bssid and qc > 0 and qm > 0 then
|
||||
return math.floor((100 / qm) * qc)
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
function find_wifi_devices()
|
||||
local devs = { }
|
||||
uci:foreach("wireless", "wifi-device",
|
||||
function(s)
|
||||
local dev = s['.name']
|
||||
local act = 0
|
||||
devs[dev] = { active = 0, networks = { } }
|
||||
|
||||
uci:foreach("wireless", "wifi-iface",
|
||||
function(s)
|
||||
if s.device == dev then
|
||||
if s.up == "1" then act = act + 1 end
|
||||
devs[dev].networks[#devs[dev].networks+1] = {
|
||||
active = (s.up == "1"),
|
||||
ifname = s.ifname,
|
||||
info = sys.wifi.getiwinfo(s.ifname or s.device)
|
||||
}
|
||||
end
|
||||
end)
|
||||
|
||||
devs[dev].hwname = guess_wifi_hw(dev)
|
||||
devs[dev].active = (act > 0)
|
||||
end)
|
||||
|
||||
return devs
|
||||
end
|
||||
|
||||
function find_wifi_frequency(state)
|
||||
if state and state.active and state.networks[1] and state.networks[1].info then
|
||||
return string.format("%d (%.03f GHz)",
|
||||
state.networks[1].info.channel,
|
||||
state.networks[1].info.frequency / 1000);
|
||||
else
|
||||
return "n/a"
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
local devices = find_wifi_devices()
|
||||
local devices = wlm:get_devices()
|
||||
local arpcache = { }
|
||||
sys.net.arptable(function(e) arpcache[e["HW address"]] = e["IP address"] end)
|
||||
-%>
|
||||
|
@ -151,45 +103,45 @@ $Id$
|
|||
|
||||
<div class="cbi-map">
|
||||
|
||||
<% for dev, state in utl.kspairs(devices) do %>
|
||||
<!-- device <%=dev%> -->
|
||||
<% for _, dev in ipairs(devices) do local nets = dev:get_networks() %>
|
||||
<!-- device <%=dev:name()%> -->
|
||||
<fieldset class="cbi-section">
|
||||
<table class="cbi-section-table" style="margin:10px; empty-cells:hide">
|
||||
<!-- physical device -->
|
||||
<tr>
|
||||
<td style="width:34px"><img src="<%=resource%>/icons/wifi<%=state.active and "" or "_disabled"%>.png" style="float:left; margin-right:10px" /></td>
|
||||
<td style="width:34px"><img src="<%=resource%>/icons/wifi<%=dev:is_up() and "" or "_disabled"%>.png" style="float:left; margin-right:10px" /></td>
|
||||
<td colspan="2" style="text-align:left">
|
||||
<big><strong><%=state.hwname%> (<%=dev%>)</strong></big><br />
|
||||
<% if state.networks[1] and state.networks[1].info then %>
|
||||
<strong>Channel:</strong> <%=find_wifi_frequency(state)%> |
|
||||
<strong>Bitrate:</strong> <%=state.networks[1].info.bitrate and (state.networks[1].info.bitrate / 1000) .. " Mb/s" or "n/a"%>
|
||||
<big><strong><%=guess_wifi_hw(dev:name())%> (<%=dev:name()%>)</strong></big><br />
|
||||
<% if nets[1] then %>
|
||||
<strong>Channel:</strong> <%=nets[1]:channel() or "?"%> (<%=nets[1]:frequency() or "?"%> GHz) |
|
||||
<strong>Bitrate:</strong> <%=nets[1]:bitrate() or "?"%> Mb/s
|
||||
<% end %>
|
||||
</td>
|
||||
<td style="width:40px">
|
||||
<a href="<%=luci.dispatcher.build_url("admin/network/wireless_join?device="..dev)%>"><img style="border:none" src="<%=resource%>/cbi/find.gif" alt="Find and join network" title="Find and join network" /></a>
|
||||
<a href="<%=luci.dispatcher.build_url("admin/network/wireless_join?device="..dev:name())%>"><img style="border:none" src="<%=resource%>/cbi/find.gif" alt="Find and join network" title="Find and join network" /></a>
|
||||
<a href="#"><img style="border:none" src="<%=resource%>/cbi/add.gif" alt="Provide new network" title="Provide new network" /></a>
|
||||
</td>
|
||||
</tr>
|
||||
<!-- /physical device -->
|
||||
|
||||
<!-- network list -->
|
||||
<% if #state.networks > 0 then %>
|
||||
<% for i, net in ipairs(state.networks) do %>
|
||||
<% if #nets > 0 then %>
|
||||
<% for i, net in ipairs(nets) do %>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=1 + ((i-1) % 2)%>">
|
||||
<td></td>
|
||||
<td class="cbi-value-field" style="width:16px; padding:3px">
|
||||
<img src="<%=guess_wifi_signal(net.info)%>" title="Signal: <%=net.info.signal or 0%> dBm / Noise: <%=net.info.noise or 0%> dBm" /><br />
|
||||
<small><%=percent_wifi_signal(net.info)%>%</small>
|
||||
<img src="<%=guess_wifi_signal(net:signal_level())%>" title="Signal: <%=net:signal()%> dBm / Noise: <%=net:noise()%> dBm" /><br />
|
||||
<small><%=net:signal_percent()%>%</small>
|
||||
</td>
|
||||
<td class="cbi-value-field" style="vertical-align:middle; text-align:left; padding:3px">
|
||||
<strong>SSID:</strong> <%=utl.pcdata(net.info.ssid)%> |
|
||||
<strong>Mode:</strong> <%=net.info.mode%><br />
|
||||
<strong>BSSID:</strong> <%=net.info.bssid%> |
|
||||
<strong>Encryption:</strong> <%=net.info.enctype or "None"%>
|
||||
<strong>SSID:</strong> <%=utl.pcdata(net:active_ssid())%> |
|
||||
<strong>Mode:</strong> <%=net:active_mode_i18n()%><br />
|
||||
<strong>BSSID:</strong> <%=net:active_bssid()%> |
|
||||
<strong>Encryption:</strong> <%=net:active_encryption()%>
|
||||
</td>
|
||||
<td class="cbi-value-field" style="width:40px">
|
||||
<a href="<%=REQUEST_URI%>/<%=dev%>"><img style="border:none" src="<%=resource%>/cbi/edit.gif" alt="Edit this network" title="Edit this network" /></a>
|
||||
<a href="#"><img style="border:none" src="<%=resource%>/cbi/remove.gif" alt="Delete this network" title="Delete this network" /></a>
|
||||
<a href="<%=REQUEST_URI%>/<%=dev:name()%>/<%=net:name()%>"><img style="border:none" src="<%=resource%>/cbi/edit.gif" alt="Edit this network" title="Edit this network" /></a>
|
||||
<a href="<%=luci.dispatcher.build_url("admin/network/wireless_delete", net:name())%>"><img style="border:none" src="<%=resource%>/cbi/remove.gif" alt="Delete this network" title="Delete this network" /></a>
|
||||
</td>
|
||||
</tr>
|
||||
<% end %>
|
||||
|
@ -204,7 +156,7 @@ $Id$
|
|||
<!-- /network list -->
|
||||
</table>
|
||||
</fieldset>
|
||||
<!-- /device <%=dev%> -->
|
||||
<!-- /device <%=dev:name()%> -->
|
||||
<% end %>
|
||||
|
||||
|
||||
|
@ -224,12 +176,12 @@ $Id$
|
|||
</tr>
|
||||
|
||||
<% local count = -1 %>
|
||||
<% for dev, state in utl.kspairs(devices) do %>
|
||||
<% for _, net in ipairs(state.networks) do %>
|
||||
<% for mac, info in utl.kspairs(net.info.assoclist) do info.bssid = mac; count = count + 1 %>
|
||||
<% for _, dev in ipairs(devices) do local nets = dev:get_networks() %>
|
||||
<% for _, net in ipairs(nets) do %>
|
||||
<% for mac, info in utl.kspairs(net:assoclist()) do count = count + 1 %>
|
||||
<tr class="cbi-section-table-row cbi-rowstyle-<%=1 + (count % 2)%>">
|
||||
<td class="cbi-value-field"><img src="<%=guess_wifi_signal(info)%>" title="Signal: <%=info.signal%> dBm / Noise: <%=info.noise%> dBm" /></td>
|
||||
<td class="cbi-value-field"><%=net.info.ssid%></td>
|
||||
<td class="cbi-value-field"><img src="<%=guess_wifi_signal(net:signal_level(info.signal, info.noise))%>" title="Signal: <%=info.signal%> dBm / Noise: <%=info.noise%> dBm" /></td>
|
||||
<td class="cbi-value-field"><%=net:active_ssid()%></td>
|
||||
<td class="cbi-value-field"><%=mac%></td>
|
||||
<td class="cbi-value-field"><%=arpcache[mac] or "n/a"%></td>
|
||||
<td class="cbi-value-field"><%=info.signal%> dBm</td>
|
||||
|
|
Loading…
Reference in a new issue