summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-11-16 00:04:28 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-11-16 00:04:28 +0000
commitce8855055915b91d6a388f9967c0244f8be8921b (patch)
tree7c112aaaced3764d83b8b33d296b167d5c1d795a
parent3386d649ea5c7b98ab654e0ae9c7228615b476b2 (diff)
modules/admin-full: fix wifi join
-rw-r--r--modules/admin-full/luasrc/model/cbi/admin_network/wifi_add.lua169
-rw-r--r--modules/admin-full/luasrc/view/admin_network/wifi_join.htm5
-rw-r--r--modules/admin-full/luasrc/view/admin_network/wifi_overview.htm2
3 files changed, 73 insertions, 103 deletions
diff --git a/modules/admin-full/luasrc/model/cbi/admin_network/wifi_add.lua b/modules/admin-full/luasrc/model/cbi/admin_network/wifi_add.lua
index c16743ddc..b4a442cad 100644
--- a/modules/admin-full/luasrc/model/cbi/admin_network/wifi_add.lua
+++ b/modules/admin-full/luasrc/model/cbi/admin_network/wifi_add.lua
@@ -19,6 +19,11 @@ local http = require "luci.http"
local iw = luci.sys.wifi.getiwinfo(http.formvalue("device"))
+if not iw then
+ luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless"))
+ return
+end
+
m = SimpleForm("network", translate("Join Network: Settings"))
m.cancel = translate("Back to scan results")
m.reset = false
@@ -48,6 +53,8 @@ m.hidden = {
if iw and iw.mbssid_support then
replace = m:field(Flag, "replace", translate("Replace wireless configuration"),
translate("An additional network will be created if you leave this unchecked."))
+
+ function replace.cfgvalue() return "1" end
else
replace = m:field(DummyValue, "replace", translate("Replace wireless configuration"))
replace.default = translate("The hardware is not multi-SSID capable and existing " ..
@@ -61,145 +68,103 @@ if http.formvalue("wep") == "1" then
translate("Specify the secret encryption key here."))
key.password = true
+ key.datatype = "wepkey"
-elseif (tonumber(m.hidden.wpa_version) or 0) > 0 and m.hidden.wpa_suites == "PSK" then
+elseif (tonumber(m.hidden.wpa_version) or 0) > 0 and
+ (m.hidden.wpa_suites == "PSK" or m.hidden.wpa_suites == "PSK2")
+then
key = m:field(Value, "key", translate("WPA passphrase"),
translate("Specify the secret encryption key here."))
key.password = true
+ key.datatype = "wpakey"
--m.hidden.wpa_suite = (tonumber(http.formvalue("wpa_version")) or 0) >= 2 and "psk2" or "psk"
end
-attachnet = m:field(Flag, "_attach", translate("Attach to existing network"),
- translate("If the interface is attached to an existing network it will be <em>bridged</em> " ..
- "to the existing interfaces and is covered by the firewall zone of the choosen network. " ..
- "Uncheck this option to define a new standalone network."
- ))
-
-attachnet.rmempty = false
-attachnet.default = http.formvalue("cbi.submit") and nil or "1"
-
-function attachnet.formvalue(self, section)
- if not http.formvalue("cbi.submit") then
- return m.hidden.mode == "Ad-Hoc" and "0" or "1"
- else
- return Value.formvalue(self, section) and "1" or "0"
- end
-end
-
-attachnet.cfgvalue = attachnet.formvalue
-
newnet = m:field(Value, "_netname_new", translate("Name of the new network"),
translate("The allowed characters are: <code>A-Z</code>, <code>a-z</code>, " ..
"<code>0-9</code> and <code>_</code>"
))
-newnet:depends("_attach", "")
-newnet.default = m.hidden.mode == "Ad-Hoc" and "mesh"
-
-addnet = m:field(Value, "_netname_attach",
- translate("Network to attach interface to"))
-
-addnet.template = "cbi/network_netlist"
-addnet.widget = "radio"
-addnet.default = "wan"
-addnet.nocreate = true
-addnet:depends("_attach", "1")
+newnet.default = m.hidden.mode == "Ad-Hoc" and "mesh" or "wwan"
+newnet.datatype = "uciname"
fwzone = m:field(Value, "_fwzone",
translate("Create / Assign firewall-zone"),
translate("Choose the firewall zone you want to assign to this interface. Select <em>unspecified</em> to remove the interface from the associated zone or fill out the <em>create</em> field to define a new zone and attach the interface to it."))
fwzone.template = "cbi/firewall_zonelist"
-fwzone:depends("_attach", "")
-fwzone.default = m.hidden.mode == "Ad-Hoc" and "mesh"
+fwzone.default = m.hidden.mode == "Ad-Hoc" and "mesh" or "wan"
-function attachnet.parse(self, section)
- Flag.parse(self, section)
+function newnet.parse(self, section)
+ local net, zone
+ local value = self:formvalue(section)
+ local zval = fwzone:formvalue(section)
- if http.formvalue("cbi.submit") then
- local net, zone
- local value = self:formvalue(section)
+ net = nw:add_network(value, { proto = "dhcp" })
+ zone = fw:get_zone(zval)
- if value == "1" then
- net = nw:get_network(addnet:formvalue(section))
- if net then
- net:type("bridge")
- end
- else
- local zval = fwzone:formvalue(section)
+ if not zone and zval == '-' then
+ zval = m:formvalue(fwzone:cbid(section) .. ".newzone")
+ if zval and #zval > 0 then
+ zone = fw:add_zone(zval)
+ end
+ end
+
+ if not net then
+ self.error = { [section] = "missing" }
+ else
+ local wdev = nw:get_wifidev(m.hidden.device)
- net = nw:add_network(newnet:formvalue(section), { proto = "dhcp" })
- zone = fw:get_zone(zval)
+ wdev:set("disabled", false)
+ wdev:set("channel", m.hidden.channel)
- if not zone and zval == '-' then
- zval = m:formvalue(fwzone:cbid(section) .. ".newzone")
- if zval and #zval > 0 then
- zone = fw:add_zone(zval)
- end
+ if replace:formvalue(section) then
+ local n
+ for _, n in ipairs(wdev:get_wifinets()) do
+ wdev:del_wifinet(n)
end
end
- if not net then
- self.error = { [section] = "missing" }
+ local wconf = {
+ device = m.hidden.device,
+ ssid = m.hidden.join,
+ mode = (m.hidden.mode == "Ad-Hoc" and "adhoc" or "sta"),
+ network = net:name()
+ }
+
+ if m.hidden.wep == "1" then
+ wconf.encryption = "wep"
+ wconf.key = key and key:formvalue(section) or ""
+ elseif (tonumber(m.hidden.wpa_version) or 0) > 0 then
+ wconf.encryption = (tonumber(m.hidden.wpa_version) or 0) >= 2 and "psk2" or "psk"
+ wconf.key = key and key:formvalue(section) or ""
else
- local wdev = nw:get_wifidev(m.hidden.device)
-
- wdev:set("disabled", false)
- wdev:set("channel", m.hidden.channel)
-
- if replace:formvalue(section) then
- local n
- for _, n in ipairs(wdev:get_wifinets()) do
- wdev:del_wifinet(n)
- end
- end
+ wconf.encryption = "none"
+ end
- local wconf = {
- device = m.hidden.device,
- ssid = m.hidden.join,
- mode = (m.hidden.mode == "Ad-Hoc" and "adhoc" or "sta"),
- network = net:name()
- }
-
- if m.hidden.wep == "1" then
- wconf.encryption = "wep"
- wconf.key = key and key:formvalue(section) or ""
- elseif (tonumber(m.hidden.wpa_version) or 0) > 0 then
- wconf.encryption = (tonumber(m.hidden.wpa_version) or 0) >= 2 and "psk2" or "psk"
- wconf.key = key and key:formvalue(section) or ""
- else
- wconf.encryption = "none"
- end
+ if wconf.mode == "adhoc" then
+ wconf.bssid = m.hidden.bssid
+ end
- if wconf.mode == "adhoc" then
- wconf.bssid = m.hidden.bssid
+ local wnet = wdev:add_wifinet(wconf)
+ if wnet then
+ if zone then
+ fw:del_network(net:name())
+ zone:add_network(net:name())
end
- local wnet = wdev:add_wifinet(wconf)
- if wnet then
- if zone then
- fw:del_network(net:name())
- zone:add_network(net:name())
- end
-
- uci:save("wireless")
- uci:save("network")
- uci:save("firewall")
+ uci:save("wireless")
+ uci:save("network")
+ uci:save("firewall")
- uci:commit("wireless")
- uci:commit("network")
- uci:commit("firewall")
-
- luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless",
- wdev:name(), wnet:name()))
- end
+ luci.http.redirect(luci.dispatcher.build_url(
+ "admin/network/wireless", wdev:name(), wnet:ifname()
+ ))
end
end
end
-attachnet.remove = attachnet.write
-
function fwzone.cfgvalue(self, section)
self.iface = section
local z = fw:get_zone_by_network(section)
diff --git a/modules/admin-full/luasrc/view/admin_network/wifi_join.htm b/modules/admin-full/luasrc/view/admin_network/wifi_join.htm
index af5f5e107..a1959a4ee 100644
--- a/modules/admin-full/luasrc/view/admin_network/wifi_join.htm
+++ b/modules/admin-full/luasrc/view/admin_network/wifi_join.htm
@@ -67,6 +67,11 @@ $Id$
local dev = luci.http.formvalue("device")
local iw = luci.sys.wifi.getiwinfo(dev)
+
+ if not iw then
+ luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless"))
+ return
+ end
-%>
<%+header%>
diff --git a/modules/admin-full/luasrc/view/admin_network/wifi_overview.htm b/modules/admin-full/luasrc/view/admin_network/wifi_overview.htm
index d23a0853a..d47ad0856 100644
--- a/modules/admin-full/luasrc/view/admin_network/wifi_overview.htm
+++ b/modules/admin-full/luasrc/view/admin_network/wifi_overview.htm
@@ -284,7 +284,7 @@ $Id$
</td>
<td class="cbi-value-field" style="width:40px">
<a href="<%=net:adminlink()%>"><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:ifname())%>"><img style="border:none" src="<%=resource%>/cbi/remove.gif" alt="<%:Delete this network%>" title="<%:Delete this network%>" /></a>
+ <a href="<%=luci.dispatcher.build_url("admin/network/wireless_delete", net:ifname())%>" onclick="return confirm('<%:Really delete this wireless network? The deletion cannot be undone!\nYou might loose access to this router if you are connected via this network.%>')"><img style="border:none" src="<%=resource%>/cbi/remove.gif" alt="<%:Delete this network%>" title="<%:Delete this network%>" /></a>
</td>
</tr>
<% end %>