Revert "Pull package/{luci,system,network} from upstream"
[librecmc/librecmc.git] / package / luci / modules / luci-mod-admin-full / luasrc / model / cbi / admin_network / wifi.lua
index 222b3627316fdd37b9cd8885d01e2a7103461895..2dff4ddc81189de19272226c1f6af1472e0a37dc 100644 (file)
@@ -42,9 +42,6 @@ end
 
 -- wireless toggle was requested, commit and reload page
 function m.parse(map)
-       local new_cc = m:formvalue("cbid.wireless.%s.country" % wdev:name())
-       local old_cc = m:get(wdev:name(), "country")
-
        if m:formvalue("cbid.wireless.%s.__toggle" % wdev:name()) then
                if wdev:get("disabled") == "1" or wnet:get("disabled") == "1" then
                        wnet:set("disabled", nil)
@@ -59,14 +56,7 @@ function m.parse(map)
                luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless", arg[1]))
                return
        end
-
        Map.parse(map)
-
-       if m:get(wdev:name(), "type") == "mac80211" and new_cc and new_cc ~= old_cc then
-               luci.sys.call("iw reg set %q" % new_cc)
-               luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless", arg[1]))
-               return
-       end
 end
 
 m.title = luci.util.pcdata(wnet:get_i18n())
@@ -104,7 +94,7 @@ local function txpower_current(pwr, list)
                        end
                end
        end
-       return pwr or ""
+       return (list[#list] and list[#list].driver_dbm) or pwr or 0
 end
 
 local iw = luci.sys.wifi.getiwinfo(arg[1])
@@ -201,7 +191,7 @@ end
 ------------------- MAC80211 Device ------------------
 
 if hwtype == "mac80211" then
-       if #tx_power_list > 0 then
+       if #tx_power_list > 1 then
                tp = s:taboption("general", ListValue,
                        "txpower", translate("Transmit Power"), "dBm")
                tp.rmempty = true
@@ -210,7 +200,6 @@ if hwtype == "mac80211" then
                        return txpower_current(Value.cfgvalue(...), tx_power_list)
                end
 
-               tp:value("", translate("auto"))
                for _, p in ipairs(tx_power_list) do
                        tp:value(p.driver_dbm, "%i dBm (%i mW)"
                                %{ p.display_dbm, p.display_mw })
@@ -262,7 +251,6 @@ if hwtype == "atheros" then
                return txpower_current(Value.cfgvalue(...), tx_power_list)
        end
 
-       tp:value("", translate("auto"))
        for _, p in ipairs(tx_power_list) do
                tp:value(p.driver_dbm, "%i dBm (%i mW)"
                        %{ p.display_dbm, p.display_mw })
@@ -320,7 +308,6 @@ if hwtype == "broadcom" then
                return txpower_current(Value.cfgvalue(...), tx_power_list)
        end
 
-       tp:value("", translate("auto"))
        for _, p in ipairs(tx_power_list) do
                tp:value(p.driver_dbm, "%i dBm (%i mW)"
                        %{ p.display_dbm, p.display_mw })
@@ -900,91 +887,13 @@ end
 
 
 if hwtype == "atheros" or hwtype == "mac80211" or hwtype == "prism2" then
-
-       -- Probe 802.11r support (and EAP support as a proxy for Openwrt)
-       local has_80211r = (os.execute("hostapd -v11r 2>/dev/null || hostapd -veap 2>/dev/null") == 0)
-
-       ieee80211r = s:taboption("encryption", Flag, "ieee80211r",
-               translate("802.11r Fast Transition"),
-               translate("Enables fast roaming among access points that belong " ..
-                       "to the same Mobility Domain"))
-       ieee80211r:depends({mode="ap", encryption="wpa"})
-       ieee80211r:depends({mode="ap", encryption="wpa2"})
-       ieee80211r:depends({mode="ap-wds", encryption="wpa"})
-       ieee80211r:depends({mode="ap-wds", encryption="wpa2"})
-       if has_80211r then
-               ieee80211r:depends({mode="ap", encryption="psk"})
-               ieee80211r:depends({mode="ap", encryption="psk2"})
-               ieee80211r:depends({mode="ap", encryption="psk-mixed"})
-       end
-       ieee80211r.rmempty = true
-
-       nasid = s:taboption("encryption", Value, "nasid", translate("NAS ID"),
-               translate("Used for two different purposes: RADIUS NAS ID and " ..
-                       "802.11r R0KH-ID. Not needed with normal WPA(2)-PSK."))
+       nasid = s:taboption("encryption", Value, "nasid", translate("NAS ID"))
        nasid:depends({mode="ap", encryption="wpa"})
        nasid:depends({mode="ap", encryption="wpa2"})
        nasid:depends({mode="ap-wds", encryption="wpa"})
        nasid:depends({mode="ap-wds", encryption="wpa2"})
-       nasid:depends({ieee80211r="1"})
        nasid.rmempty = true
 
-       mobility_domain = s:taboption("encryption", Value, "mobility_domain",
-                       translate("Mobility Domain"),
-                       translate("4-character hexadecimal ID"))
-       mobility_domain:depends({ieee80211r="1"})
-       mobility_domain.placeholder = "4f57"
-       mobility_domain.datatype = "and(hexstring,rangelength(4,4))"
-       mobility_domain.rmempty = true
-
-       r0_key_lifetime = s:taboption("encryption", Value, "r0_key_lifetime",
-                       translate("R0 Key Lifetime"), translate("minutes"))
-       r0_key_lifetime:depends({ieee80211r="1"})
-       r0_key_lifetime.placeholder = "10000"
-       r0_key_lifetime.datatype = "uinteger"
-       r0_key_lifetime.rmempty = true
-
-       r1_key_holder = s:taboption("encryption", Value, "r1_key_holder",
-                       translate("R1 Key Holder"),
-                       translate("6-octet identifier as a hex string - no colons"))
-       r1_key_holder:depends({ieee80211r="1"})
-       r1_key_holder.placeholder = "00004f577274"
-       r1_key_holder.datatype = "and(hexstring,rangelength(12,12))"
-       r1_key_holder.rmempty = true
-
-       reassociation_deadline = s:taboption("encryption", Value, "reassociation_deadline",
-               translate("Reassociation Deadline"),
-               translate("time units (TUs / 1.024 ms) [1000-65535]"))
-       reassociation_deadline:depends({ieee80211r="1"})
-       reassociation_deadline.placeholder = "1000"
-       reassociation_deadline.datatype = "range(1000,65535)"
-       reassociation_deadline.rmempty = true
-
-       pmk_r1_push = s:taboption("encryption", Flag, "pmk_r1_push", translate("PMK R1 Push"))
-       pmk_r1_push:depends({ieee80211r="1"})
-       pmk_r1_push.placeholder = "0"
-       pmk_r1_push.rmempty = true
-
-       r0kh = s:taboption("encryption", DynamicList, "r0kh", translate("External R0 Key Holder List"),
-               translate("List of R0KHs in the same Mobility Domain. " ..
-                       "<br />Format: MAC-address,NAS-Identifier,128-bit key as hex string. " ..
-                       "<br />This list is used to map R0KH-ID (NAS Identifier) to a destination " ..
-                       "MAC address when requesting PMK-R1 key from the R0KH that the STA " ..
-                       "used during the Initial Mobility Domain Association."))
-
-       r0kh:depends({ieee80211r="1"})
-       r0kh.rmempty = true
-
-       r1kh = s:taboption("encryption", DynamicList, "r1kh", translate("External R1 Key Holder List"),
-               translate ("List of R1KHs in the same Mobility Domain. "..
-                       "<br />Format: MAC-address,R1KH-ID as 6 octets with colons,128-bit key as hex string. "..
-                       "<br />This list is used to map R1KH-ID to a destination MAC address " ..
-                       "when sending PMK-R1 key from the R0KH. This is also the " ..
-                       "list of authorized R1KHs in the MD that can request PMK-R1 keys."))
-       r1kh:depends({ieee80211r="1"})
-       r1kh.rmempty = true
-       -- End of 802.11r options
-
        eaptype = s:taboption("encryption", ListValue, "eap_type", translate("EAP-Method"))
        eaptype:value("tls",  "TLS")
        eaptype:value("ttls", "TTLS")
@@ -1123,47 +1032,6 @@ if hwtype == "atheros" or hwtype == "mac80211" or hwtype == "prism2" then
        password.password = true
 end
 
--- ieee802.11w options
-if hwtype == "mac80211" then
-   local has_80211w = (os.execute("hostapd -v11w 2>/dev/null || hostapd -veap 2>/dev/null") == 0)
-   if has_80211w then
-       ieee80211w = s:taboption("encryption", ListValue, "ieee80211w",
-               translate("802.11w Management Frame Protection"),
-               translate("Requires the 'full' version of wpad/hostapd " ..
-                       "and support from the wifi driver <br />(as of Feb 2017: " ..
-                       "ath9k and ath10k, in LEDE also mwlwifi and mt76)"))
-       ieee80211w.default = ""
-       ieee80211w.rmempty = true
-       ieee80211w:value("", translate("Disabled (default)"))
-       ieee80211w:value("1", translate("Optional"))
-       ieee80211w:value("2", translate("Required"))
-       ieee80211w:depends({mode="ap", encryption="wpa2"})
-       ieee80211w:depends({mode="ap-wds", encryption="wpa2"})
-       ieee80211w:depends({mode="ap", encryption="psk2"})
-       ieee80211w:depends({mode="ap", encryption="psk-mixed"})
-       ieee80211w:depends({mode="ap-wds", encryption="psk2"})
-       ieee80211w:depends({mode="ap-wds", encryption="psk-mixed"})
-
-       max_timeout = s:taboption("encryption", Value, "ieee80211w_max_timeout",
-                       translate("802.11w maximum timeout"),
-                       translate("802.11w Association SA Query maximum timeout"))
-       max_timeout:depends({ieee80211w="1"})
-       max_timeout:depends({ieee80211w="2"})
-       max_timeout.datatype = "uinteger"
-       max_timeout.placeholder = "1000"
-       max_timeout.rmempty = true
-
-       retry_timeout = s:taboption("encryption", Value, "ieee80211w_retry_timeout",
-                       translate("802.11w retry timeout"),
-                       translate("802.11w Association SA Query retry timeout"))
-       retry_timeout:depends({ieee80211w="1"})
-       retry_timeout:depends({ieee80211w="2"})
-       retry_timeout.datatype = "uinteger"
-       retry_timeout.placeholder = "201"
-       retry_timeout.rmempty = true
-   end
-end
-
 if hwtype == "atheros" or hwtype == "mac80211" or hwtype == "prism2" then
        local wpasupplicant = fs.access("/usr/sbin/wpa_supplicant")
        local hostcli = fs.access("/usr/sbin/hostapd_cli")