modules/admin-full: speed up network controller by using inreq flag
This commit is contained in:
parent
0b7eb82eb6
commit
905e682bb7
1 changed files with 115 additions and 101 deletions
|
@ -17,16 +17,6 @@ module("luci.controller.admin.network", package.seeall)
|
||||||
|
|
||||||
function index()
|
function index()
|
||||||
local uci = require("luci.model.uci").cursor()
|
local uci = require("luci.model.uci").cursor()
|
||||||
local net = require "luci.model.network".init(uci)
|
|
||||||
local has_wifi = nixio.fs.stat("/etc/config/wireless")
|
|
||||||
local has_switch = false
|
|
||||||
|
|
||||||
uci:foreach("network", "switch",
|
|
||||||
function(s)
|
|
||||||
has_switch = true
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
)
|
|
||||||
|
|
||||||
local page
|
local page
|
||||||
|
|
||||||
|
@ -36,112 +26,136 @@ function index()
|
||||||
page.order = 50
|
page.order = 50
|
||||||
page.index = true
|
page.index = true
|
||||||
|
|
||||||
if has_switch then
|
if page.inreq then
|
||||||
page = node("admin", "network", "vlan")
|
local has_switch = false
|
||||||
page.target = cbi("admin_network/vlan")
|
|
||||||
page.title = _("Switch")
|
|
||||||
page.order = 20
|
|
||||||
end
|
|
||||||
|
|
||||||
if has_wifi and has_wifi.size > 0 then
|
uci:foreach("network", "switch",
|
||||||
page = entry({"admin", "network", "wireless"}, arcombine(template("admin_network/wifi_overview"), cbi("admin_network/wifi")), _("Wifi"), 15)
|
function(s)
|
||||||
|
has_switch = true
|
||||||
|
return false
|
||||||
|
end)
|
||||||
|
|
||||||
|
if has_switch then
|
||||||
|
page = node("admin", "network", "vlan")
|
||||||
|
page.target = cbi("admin_network/vlan")
|
||||||
|
page.title = _("Switch")
|
||||||
|
page.order = 20
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
local has_wifi = false
|
||||||
|
|
||||||
|
uci:foreach("wireless", "wifi-device",
|
||||||
|
function(s)
|
||||||
|
has_wifi = true
|
||||||
|
return false
|
||||||
|
end)
|
||||||
|
|
||||||
|
if has_wifi then
|
||||||
|
page = entry({"admin", "network", "wireless_join"}, call("wifi_join"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "wireless_add"}, call("wifi_add"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "wireless_delete"}, call("wifi_delete"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "wireless_status"}, call("wifi_status"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "wireless_reconnect"}, call("wifi_reconnect"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "wireless_shutdown"}, call("wifi_reconnect"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "wireless"}, arcombine(template("admin_network/wifi_overview"), cbi("admin_network/wifi")), _("Wifi"), 15)
|
||||||
|
page.leaf = true
|
||||||
|
page.subindex = true
|
||||||
|
|
||||||
|
if page.inreq then
|
||||||
|
local wdev
|
||||||
|
local net = require "luci.model.network".init(uci)
|
||||||
|
for _, wdev in ipairs(net:get_wifidevs()) do
|
||||||
|
local wnet
|
||||||
|
for _, wnet in ipairs(wdev:get_wifinets()) do
|
||||||
|
entry(
|
||||||
|
{"admin", "network", "wireless", wnet:id()},
|
||||||
|
alias("admin", "network", "wireless"),
|
||||||
|
wdev:name() .. ": " .. wnet:shortname()
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "iface_add"}, cbi("admin_network/iface_add"), nil)
|
||||||
page.leaf = true
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "iface_delete"}, call("iface_delete"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "iface_status"}, call("iface_status"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "iface_reconnect"}, call("iface_reconnect"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "iface_shutdown"}, call("iface_shutdown"), nil)
|
||||||
|
page.leaf = true
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "network"}, arcombine(cbi("admin_network/network"), cbi("admin_network/ifaces")), _("Interfaces"), 10)
|
||||||
|
page.leaf = true
|
||||||
page.subindex = true
|
page.subindex = true
|
||||||
|
|
||||||
page = entry({"admin", "network", "wireless_join"}, call("wifi_join"), nil)
|
if page.inreq then
|
||||||
page.leaf = true
|
uci:foreach("network", "interface",
|
||||||
|
function (section)
|
||||||
page = entry({"admin", "network", "wireless_add"}, call("wifi_add"), nil)
|
local ifc = section[".name"]
|
||||||
page.leaf = true
|
if ifc ~= "loopback" then
|
||||||
|
entry({"admin", "network", "network", ifc},
|
||||||
page = entry({"admin", "network", "wireless_delete"}, call("wifi_delete"), nil)
|
true, ifc:upper())
|
||||||
page.leaf = true
|
end
|
||||||
|
end)
|
||||||
page = entry({"admin", "network", "wireless_status"}, call("wifi_status"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "wireless_reconnect"}, call("wifi_reconnect"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "wireless_shutdown"}, call("wifi_reconnect"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
local wdev
|
|
||||||
for _, wdev in ipairs(net:get_wifidevs()) do
|
|
||||||
local wnet
|
|
||||||
for _, wnet in ipairs(wdev:get_wifinets()) do
|
|
||||||
entry(
|
|
||||||
{"admin", "network", "wireless", wnet:id()},
|
|
||||||
alias("admin", "network", "wireless"),
|
|
||||||
wdev:name() .. ": " .. wnet:shortname()
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "network"}, arcombine(cbi("admin_network/network"), cbi("admin_network/ifaces")), _("Interfaces"), 10)
|
|
||||||
page.leaf = true
|
|
||||||
page.subindex = true
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "iface_add"}, cbi("admin_network/iface_add"), nil)
|
if nixio.fs.access("/etc/config/dhcp") then
|
||||||
page.leaf = true
|
page = node("admin", "network", "dhcp")
|
||||||
|
page.target = cbi("admin_network/dhcp")
|
||||||
|
page.title = _("DHCP and DNS")
|
||||||
|
page.order = 30
|
||||||
|
|
||||||
page = entry({"admin", "network", "iface_delete"}, call("iface_delete"), nil)
|
page = entry({"admin", "network", "dhcplease_status"}, call("lease_status"), nil)
|
||||||
page.leaf = true
|
page.leaf = true
|
||||||
|
|
||||||
page = entry({"admin", "network", "iface_status"}, call("iface_status"), nil)
|
page = node("admin", "network", "hosts")
|
||||||
page.leaf = true
|
page.target = cbi("admin_network/hosts")
|
||||||
|
page.title = _("Hostnames")
|
||||||
page = entry({"admin", "network", "iface_reconnect"}, call("iface_reconnect"), nil)
|
page.order = 40
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "iface_shutdown"}, call("iface_shutdown"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
uci:foreach("network", "interface",
|
|
||||||
function (section)
|
|
||||||
local ifc = section[".name"]
|
|
||||||
if ifc ~= "loopback" then
|
|
||||||
entry({"admin", "network", "network", ifc},
|
|
||||||
true,
|
|
||||||
ifc:upper())
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
)
|
|
||||||
|
|
||||||
if nixio.fs.access("/etc/config/dhcp") then
|
page = node("admin", "network", "routes")
|
||||||
page = node("admin", "network", "dhcp")
|
page.target = cbi("admin_network/routes")
|
||||||
page.target = cbi("admin_network/dhcp")
|
page.title = _("Static Routes")
|
||||||
page.title = _("DHCP and DNS")
|
page.order = 50
|
||||||
page.order = 30
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "dhcplease_status"}, call("lease_status"), nil)
|
page = node("admin", "network", "diagnostics")
|
||||||
|
page.target = template("admin_network/diagnostics")
|
||||||
|
page.title = _("Diagnostics")
|
||||||
|
page.order = 60
|
||||||
|
|
||||||
|
page = entry({"admin", "network", "diag_ping"}, call("diag_ping"), nil)
|
||||||
page.leaf = true
|
page.leaf = true
|
||||||
|
|
||||||
page = node("admin", "network", "hosts")
|
page = entry({"admin", "network", "diag_nslookup"}, call("diag_nslookup"), nil)
|
||||||
page.target = cbi("admin_network/hosts")
|
page.leaf = true
|
||||||
page.title = _("Hostnames")
|
|
||||||
page.order = 40
|
page = entry({"admin", "network", "diag_traceroute"}, call("diag_traceroute"), nil)
|
||||||
|
page.leaf = true
|
||||||
end
|
end
|
||||||
|
|
||||||
page = node("admin", "network", "routes")
|
|
||||||
page.target = cbi("admin_network/routes")
|
|
||||||
page.title = _("Static Routes")
|
|
||||||
page.order = 50
|
|
||||||
|
|
||||||
page = node("admin", "network", "diagnostics")
|
|
||||||
page.target = template("admin_network/diagnostics")
|
|
||||||
page.title = _("Diagnostics")
|
|
||||||
page.order = 60
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "diag_ping"}, call("diag_ping"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "diag_nslookup"}, call("diag_nslookup"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
|
|
||||||
page = entry({"admin", "network", "diag_traceroute"}, call("diag_traceroute"), nil)
|
|
||||||
page.leaf = true
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function wifi_join()
|
function wifi_join()
|
||||||
|
|
Loading…
Reference in a new issue