require("luci.i18n")
local uci = require("luci.model.uci").cursor()
local i18n = luci.i18n.translate
+ local has_wifi = nixio.fs.stat("/etc/config/wireless")
local page = node("admin", "network")
page.target = alias("admin", "network", "network")
- page.title = i18n("network")
+ page.title = i18n("Network")
page.order = 50
page.index = true
local page = node("admin", "network", "vlan")
page.target = cbi("admin_network/vlan")
- page.title = i18n("a_n_switch")
+ page.title = i18n("Switch")
page.order = 20
- local page = entry({"admin", "network", "wireless"}, arcombine(template("admin_network/wifi_overview"), cbi("admin_network/wifi")), i18n("wifi"), 15)
- page.i18n = "wifi"
- page.leaf = true
- page.subindex = true
+ if has_wifi and has_wifi.size > 0 then
+ local page = entry({"admin", "network", "wireless"}, arcombine(template("admin_network/wifi_overview"), cbi("admin_network/wifi")), i18n("Wifi"), 15)
+ page.leaf = true
+ page.subindex = true
- uci:foreach("wireless", "wifi-device",
- function (section)
- local ifc = section[".name"]
- entry({"admin", "network", "wireless", ifc},
- true,
- ifc:upper()).i18n = "wifi"
- end
- )
+ local page = entry({"admin", "network", "wireless_join"}, call("wifi_join"), nil, 16)
+ page.leaf = true
- local page = entry({"admin", "network", "wireless_join"}, call("wifi_join"), nil, 16)
- page.i18n = "wifi"
- page.leaf = true
+ local page = entry({"admin", "network", "wireless_add"}, call("wifi_add"), nil, 16)
+ page.leaf = true
+
+ local page = entry({"admin", "network", "wireless_delete"}, call("wifi_delete"), nil, 16)
+ page.leaf = true
+ end
- local page = entry({"admin", "network", "network"}, arcombine(cbi("admin_network/network"), cbi("admin_network/ifaces")), i18n("interfaces", "Schnittstellen"), 10)
+ local page = entry({"admin", "network", "network"}, arcombine(cbi("admin_network/network"), cbi("admin_network/ifaces")), i18n("Interfaces"), 10)
page.leaf = true
page.subindex = true
+ local page = entry({"admin", "network", "add"}, cbi("admin_network/iface_add"), nil)
+ page.leaf = true
+
uci:foreach("network", "interface",
function (section)
local ifc = section[".name"]
end
)
- local page = node("admin", "network", "dhcp")
- page.target = cbi("admin_network/dhcp")
- page.title = "DHCP"
- page.order = 30
- page.subindex = true
-
- entry(
- {"admin", "network", "dhcp", "leases"},
- cbi("admin_network/dhcpleases"),
- i18n("dhcp_leases")
- )
+ if nixio.fs.access("/etc/config/dhcp") then
+ local page = node("admin", "network", "dhcpleases")
+ page.target = cbi("admin_network/dhcpleases")
+ page.title = i18n("DHCP Leases")
+ page.order = 30
+ end
local page = node("admin", "network", "hosts")
page.target = cbi("admin_network/hosts")
- page.title = i18n("hostnames", "Hostnames")
+ page.title = i18n("Hostnames")
page.order = 40
local page = node("admin", "network", "routes")
page.target = cbi("admin_network/routes")
- page.title = i18n("a_n_routes_static")
+ page.title = i18n("Static Routes")
page.order = 50
end
local ssid = param("join")
if dev and ssid then
- local wep = (tonumber(param("wep")) == 1)
- local wpa = tonumber(param("wpa_version")) or 0
- local channel = tonumber(param("channel"))
- local mode = param("mode")
- local bssid = param("bssid")
-
- local confirm = (param("confirm") == "1")
- local cancel = param("cancel") and true or false
-
- if confirm and not cancel then
- local fixed_bssid = (param("fixed_bssid") == "1")
- local replace_net = (param("replace_net") == "1")
- local autoconnect = (param("autoconnect") == "1")
- local attach_intf = param("attach_intf")
-
- local uci = require "luci.model.uci".cursor()
+ local cancel = (param("cancel") or param("cbi.cancel")) and true or false
- if replace_net then
- uci:delete_all("wireless", "wifi-iface")
+ if cancel then
+ luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless_join?device=" .. dev))
+ else
+ local cbi = require "luci.cbi"
+ local tpl = require "luci.template"
+ local map = luci.cbi.load("admin_network/wifi_add")[1]
+
+ if map:parse() ~= cbi.FORM_DONE then
+ tpl.render("header")
+ map:render()
+ tpl.render("footer")
end
+ end
+ else
+ luci.template.render("admin_network/wifi_join")
+ end
+end
- local wificonf = {
- device = dev,
- mode = (mode == "Ad-Hoc" and "adhoc" or "sta"),
- ssid = ssid
- }
-
- if attach_intf and uci:get("network", attach_intf, "ifname") then
- -- target network already has a interface, make it a bridge
- uci:set("network", attach_intf, "type", "bridge")
- uci:save("network")
- uci:commit("network")
-
- if autoconnect then
- require "luci.sys".call("/sbin/ifup " .. attach_intf)
- end
- end
+function wifi_add()
+ local dev = luci.http.formvalue("device")
+ local uci = require "luci.model.uci".cursor()
+ local wlm = require "luci.model.wireless"
- if fixed_bssid then
- wificonf.bssid = bssid
- end
+ if dev then
+ wlm.init(uci)
- if wep then
- wificonf.encryption = "wep"
- wificonf.key = param("key")
- elseif wpa > 0 then
- wificonf.encryption = param("wpa_suite")
- wificonf.key = param("key")
- end
+ local net = wlm:add_network({
+ device = dev,
+ mode = "ap",
+ ssid = "OpenWrt",
+ encryption = "none"
+ })
- uci:section("wireless", "wifi-iface", nil, wificonf)
- uci:delete("wireless", dev, "disabled")
- uci:set("wireless", dev, "channel", channel)
+ uci:save("wireless")
+ luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless", dev, net:name()))
+ end
+end
- uci:save("wireless")
- uci:commit("wireless")
+function wifi_delete(network)
+ local uci = require "luci.model.uci".cursor()
+ local wlm = require "luci.model.wireless"
- if autoconnect then
- require "luci.sys".call("/sbin/wifi")
- end
+ wlm.init(uci)
+ wlm:del_network(network)
- luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless", dev))
- elseif cancel then
- luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless_join?device=" .. dev))
- else
- luci.template.render("admin_network/wifi_join_settings")
- end
- else
- luci.template.render("admin_network/wifi_join")
- end
+ uci:save("wireless")
+ luci.http.redirect(luci.dispatcher.build_url("admin/network/wireless"))
end