modules/admin-full: rewrite wifi join wizzard
[project/luci.git] / modules / admin-full / luasrc / view / admin_network / wifi_overview.htm
index 580fe9a..795edc4 100644 (file)
@@ -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+)")
@@ -65,16 +68,14 @@ $Id$
 
                -- dunno yet
                else
-                       return "Unkown 802.11 Wireless Controller"
+                       return "Generic 802.11 Wireless Controller"
                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,103 +92,56 @@ $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)
 -%>
 
 <%+header%>
 
-<h2><a id="content" name="content"><%:a_s_iw_overview Wireless Overview%></a></h2>
+<h2><a id="content" name="content"><%:Wireless Overview%></a></h2>
 
 <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 />
-                                       <strong>Channel:</strong> <%=find_wifi_frequency(state)%> |
-                                       <strong>Bitrate:</strong> <%=(state and state.networks[1]) 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%> dBm / Noise: <%=net.info.noise%> 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%>
+                                               <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 %>
@@ -202,13 +156,13 @@ $Id$
                        <!-- /network list -->
                </table>
        </fieldset>
-       <!-- /device <%=dev%> -->
+       <!-- /device <%=dev:name()%> -->
        <% end %>
 
 
 
 
-       <h2><a id="content" name="content"><%:a_s_iw_overview2 Associated Stations%></a></h2>
+       <h2><a id="content" name="content"><%:Associated Stations%></a></h2>
 
        <fieldset class="cbi-section">
                <table class="cbi-section-table" style="margin:10px; width:50%">
@@ -222,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>