modules/admin-full: switch static lease page to /etc/config/dhcp, add better labels...
[project/luci.git] / modules / admin-full / luasrc / model / cbi / admin_network / dhcp.lua
index af018ea..13a00ab 100644 (file)
@@ -15,16 +15,22 @@ require("luci.tools.webadmin")
 require("luci.model.uci")
 require("luci.util")
 
-m = Map("dhcp", "DHCP")
+m = Map("dhcp",
+       translate("DHCP"),
+       translate("With <abbr title=\"Dynamic Host Configuration Protocol\">DHCP</abbr> network " ..
+               "members can automatically receive their network settings (<abbr title=" ..
+               "\"Internet Protocol\">IP</abbr>-address, netmask, <abbr title=\"Domain Name " ..
+               "System\">DNS</abbr>-server, ...)."))
 
 s = m:section(TypedSection, "dhcp", "")
 s.addremove = true
 s.anonymous = true
 
-iface = s:option(ListValue, "interface", translate("interface"))
+iface = s:option(ListValue, "interface", translate("Interface"))
 luci.tools.webadmin.cbi_add_networks(iface)
 
-luci.model.uci.foreach("network", "interface",
+local uci = luci.model.uci.cursor()
+uci:foreach("network", "interface",
        function (section)
                if section[".name"] ~= "loopback" then
                        iface.default = iface.default or section[".name"]
@@ -32,33 +38,40 @@ luci.model.uci.foreach("network", "interface",
                end
        end)
 
-luci.model.uci.foreach("network", "alias",
+uci:foreach("network", "alias",
        function (section)
                iface:value(section[".name"])
                s:depends("interface", section[".name"])
        end)
 
-s:option(Value, "start", translate("start")).rmempty = true
+s:option(Value, "start", translate("Start")).rmempty = true
 
-s:option(Value, "limit", translate("limit")).rmempty = true
+s:option(Value, "limit", translate("Limit")).rmempty = true
 
-s:option(Value, "leasetime").rmempty = true
+s:option(Value, "leasetime", translate("Leasetime")).rmempty = true
 
-s:option(Flag, "dynamicdhcp").rmempty = true
+local dd = s:option(Flag, "dynamicdhcp",
+       translate("Dynamic <abbr title=\"Dynamic Host Configuration Protocol\">DHCP</abbr>"))
 
-s:option(Value, "name", translate("name")).optional = true
+dd.rmempty = false
+function dd.cfgvalue(self, section)
+       return Flag.cfgvalue(self, section) or "1"
+end
+
+s:option(Value, "name", translate("Name")).optional = true
+
+ignore = s:option(Flag, "ignore",
+       translate("Ignore interface"),
+       translate("disable <abbr title=\"Dynamic Host Configuration Protocol\">DHCP</abbr> for " ..
+               "this interface"))
 
-ignore = s:option(Flag, "ignore")
 ignore.optional = true
 
-s:option(Value, "netmask", translate("netmask")).optional = true
+s:option(Value, "netmask", translate("<abbr title=\"Internet Protocol Version 4\">IPv4</abbr>-Netmask")).optional = true
 
-s:option(Flag, "force").optional = true
+s:option(Flag, "force", translate("Force")).optional = true
 
-for i, line in pairs(luci.util.execl("dnsmasq --help dhcp")) do
-       k, v = line:match("([^ ]+) +([^ ]+)")
-       s:option(Value, "dhcp"..k, v).optional = true
-end
+s:option(DynamicList, "dhcp_option", translate("DHCP-Options")).optional = true
 
 
 for i, n in ipairs(s.children) do
@@ -67,4 +80,4 @@ for i, n in ipairs(s.children) do
        end
 end
 
-return m
\ No newline at end of file
+return m