modules/admin-full: fix wifi join
This commit is contained in:
parent
3386d649ea
commit
ce88550559
3 changed files with 73 additions and 103 deletions
|
@ -19,6 +19,11 @@ local http = require "luci.http"
|
||||||
|
|
||||||
local iw = luci.sys.wifi.getiwinfo(http.formvalue("device"))
|
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 = SimpleForm("network", translate("Join Network: Settings"))
|
||||||
m.cancel = translate("Back to scan results")
|
m.cancel = translate("Back to scan results")
|
||||||
m.reset = false
|
m.reset = false
|
||||||
|
@ -48,6 +53,8 @@ m.hidden = {
|
||||||
if iw and iw.mbssid_support then
|
if iw and iw.mbssid_support then
|
||||||
replace = m:field(Flag, "replace", translate("Replace wireless configuration"),
|
replace = m:field(Flag, "replace", translate("Replace wireless configuration"),
|
||||||
translate("An additional network will be created if you leave this unchecked."))
|
translate("An additional network will be created if you leave this unchecked."))
|
||||||
|
|
||||||
|
function replace.cfgvalue() return "1" end
|
||||||
else
|
else
|
||||||
replace = m:field(DummyValue, "replace", translate("Replace wireless configuration"))
|
replace = m:field(DummyValue, "replace", translate("Replace wireless configuration"))
|
||||||
replace.default = translate("The hardware is not multi-SSID capable and existing " ..
|
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."))
|
translate("Specify the secret encryption key here."))
|
||||||
|
|
||||||
key.password = true
|
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"),
|
key = m:field(Value, "key", translate("WPA passphrase"),
|
||||||
translate("Specify the secret encryption key here."))
|
translate("Specify the secret encryption key here."))
|
||||||
|
|
||||||
key.password = true
|
key.password = true
|
||||||
|
key.datatype = "wpakey"
|
||||||
--m.hidden.wpa_suite = (tonumber(http.formvalue("wpa_version")) or 0) >= 2 and "psk2" or "psk"
|
--m.hidden.wpa_suite = (tonumber(http.formvalue("wpa_version")) or 0) >= 2 and "psk2" or "psk"
|
||||||
end
|
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"),
|
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>, " ..
|
translate("The allowed characters are: <code>A-Z</code>, <code>a-z</code>, " ..
|
||||||
"<code>0-9</code> and <code>_</code>"
|
"<code>0-9</code> and <code>_</code>"
|
||||||
))
|
))
|
||||||
|
|
||||||
newnet:depends("_attach", "")
|
newnet.default = m.hidden.mode == "Ad-Hoc" and "mesh" or "wwan"
|
||||||
newnet.default = m.hidden.mode == "Ad-Hoc" and "mesh"
|
newnet.datatype = "uciname"
|
||||||
|
|
||||||
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")
|
|
||||||
|
|
||||||
fwzone = m:field(Value, "_fwzone",
|
fwzone = m:field(Value, "_fwzone",
|
||||||
translate("Create / Assign firewall-zone"),
|
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."))
|
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.template = "cbi/firewall_zonelist"
|
||||||
fwzone:depends("_attach", "")
|
fwzone.default = m.hidden.mode == "Ad-Hoc" and "mesh" or "wan"
|
||||||
fwzone.default = m.hidden.mode == "Ad-Hoc" and "mesh"
|
|
||||||
|
|
||||||
function attachnet.parse(self, section)
|
function newnet.parse(self, section)
|
||||||
Flag.parse(self, section)
|
local net, zone
|
||||||
|
local value = self:formvalue(section)
|
||||||
|
local zval = fwzone:formvalue(section)
|
||||||
|
|
||||||
if http.formvalue("cbi.submit") then
|
net = nw:add_network(value, { proto = "dhcp" })
|
||||||
local net, zone
|
zone = fw:get_zone(zval)
|
||||||
local value = self:formvalue(section)
|
|
||||||
|
|
||||||
if value == "1" then
|
if not zone and zval == '-' then
|
||||||
net = nw:get_network(addnet:formvalue(section))
|
zval = m:formvalue(fwzone:cbid(section) .. ".newzone")
|
||||||
if net then
|
if zval and #zval > 0 then
|
||||||
net:type("bridge")
|
zone = fw:add_zone(zval)
|
||||||
end
|
end
|
||||||
else
|
end
|
||||||
local zval = fwzone:formvalue(section)
|
|
||||||
|
|
||||||
net = nw:add_network(newnet:formvalue(section), { proto = "dhcp" })
|
if not net then
|
||||||
zone = fw:get_zone(zval)
|
self.error = { [section] = "missing" }
|
||||||
|
else
|
||||||
|
local wdev = nw:get_wifidev(m.hidden.device)
|
||||||
|
|
||||||
if not zone and zval == '-' then
|
wdev:set("disabled", false)
|
||||||
zval = m:formvalue(fwzone:cbid(section) .. ".newzone")
|
wdev:set("channel", m.hidden.channel)
|
||||||
if zval and #zval > 0 then
|
|
||||||
zone = fw:add_zone(zval)
|
if replace:formvalue(section) then
|
||||||
end
|
local n
|
||||||
|
for _, n in ipairs(wdev:get_wifinets()) do
|
||||||
|
wdev:del_wifinet(n)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if not net then
|
local wconf = {
|
||||||
self.error = { [section] = "missing" }
|
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
|
else
|
||||||
local wdev = nw:get_wifidev(m.hidden.device)
|
wconf.encryption = "none"
|
||||||
|
end
|
||||||
|
|
||||||
wdev:set("disabled", false)
|
if wconf.mode == "adhoc" then
|
||||||
wdev:set("channel", m.hidden.channel)
|
wconf.bssid = m.hidden.bssid
|
||||||
|
end
|
||||||
|
|
||||||
if replace:formvalue(section) then
|
local wnet = wdev:add_wifinet(wconf)
|
||||||
local n
|
if wnet then
|
||||||
for _, n in ipairs(wdev:get_wifinets()) do
|
if zone then
|
||||||
wdev:del_wifinet(n)
|
fw:del_network(net:name())
|
||||||
end
|
zone:add_network(net:name())
|
||||||
end
|
end
|
||||||
|
|
||||||
local wconf = {
|
uci:save("wireless")
|
||||||
device = m.hidden.device,
|
uci:save("network")
|
||||||
ssid = m.hidden.join,
|
uci:save("firewall")
|
||||||
mode = (m.hidden.mode == "Ad-Hoc" and "adhoc" or "sta"),
|
|
||||||
network = net:name()
|
|
||||||
}
|
|
||||||
|
|
||||||
if m.hidden.wep == "1" then
|
luci.http.redirect(luci.dispatcher.build_url(
|
||||||
wconf.encryption = "wep"
|
"admin/network/wireless", wdev:name(), wnet:ifname()
|
||||||
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
|
|
||||||
|
|
||||||
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:commit("wireless")
|
|
||||||
uci:commit("network")
|
|
||||||
uci:commit("firewall")
|
|
||||||
|
|
||||||
luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless",
|
|
||||||
wdev:name(), wnet:name()))
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
attachnet.remove = attachnet.write
|
|
||||||
|
|
||||||
function fwzone.cfgvalue(self, section)
|
function fwzone.cfgvalue(self, section)
|
||||||
self.iface = section
|
self.iface = section
|
||||||
local z = fw:get_zone_by_network(section)
|
local z = fw:get_zone_by_network(section)
|
||||||
|
|
|
@ -67,6 +67,11 @@ $Id$
|
||||||
|
|
||||||
local dev = luci.http.formvalue("device")
|
local dev = luci.http.formvalue("device")
|
||||||
local iw = luci.sys.wifi.getiwinfo(dev)
|
local iw = luci.sys.wifi.getiwinfo(dev)
|
||||||
|
|
||||||
|
if not iw then
|
||||||
|
luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless"))
|
||||||
|
return
|
||||||
|
end
|
||||||
-%>
|
-%>
|
||||||
|
|
||||||
<%+header%>
|
<%+header%>
|
||||||
|
|
|
@ -284,7 +284,7 @@ $Id$
|
||||||
</td>
|
</td>
|
||||||
<td class="cbi-value-field" style="width:40px">
|
<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="<%=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>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
Loading…
Reference in a new issue