X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fluci.git;a=blobdiff_plain;f=modules%2Fadmin-full%2Fluasrc%2Fmodel%2Fcbi%2Fadmin_network%2Fdhcpleases.lua;h=3f631b38b989169225ab5e2af375f3f749c35da0;hp=70b49d7fa455a583b6e9bec37ed4a389a1a4997d;hb=cb3caa6e3087380291a7fee8ca05d35d89744f27;hpb=e910619bbd67fe259ae5c709bbc78b7fd256fe84;ds=inline diff --git a/modules/admin-full/luasrc/model/cbi/admin_network/dhcpleases.lua b/modules/admin-full/luasrc/model/cbi/admin_network/dhcpleases.lua index 70b49d7fa..3f631b38b 100644 --- a/modules/admin-full/luasrc/model/cbi/admin_network/dhcpleases.lua +++ b/modules/admin-full/luasrc/model/cbi/admin_network/dhcpleases.lua @@ -12,49 +12,14 @@ You may obtain a copy of the License at $Id$ ]]-- -local uci = require "luci.model.uci".cursor() local sys = require "luci.sys" -local wa = require "luci.tools.webadmin" -local fs = require "nixio.fs" m2 = Map("dhcp", translate("DHCP Leases"), translate("Static leases are used to assign fixed IP addresses and symbolic hostnames to " .. "DHCP clients. They are also required for non-dynamic interface configurations where " .. "only hosts with a corresponding lease are served.")) -local leasefn, leasefp, leases -uci:foreach("dhcp", "dnsmasq", - function(section) - leasefn = section.leasefile - end -) -local leasefp = leasefn and fs.access(leasefn) and io.lines(leasefn) -if leasefp then - leases = {} - for lease in leasefp do - table.insert(leases, luci.util.split(lease, " ")) - end -end - -if leases then - v = m2:section(Table, leases, translate("Active Leases")) - - name = v:option(DummyValue, 4, translate("Hostname")) - function name.cfgvalue(self, ...) - local value = DummyValue.cfgvalue(self, ...) - return (value == "*") and "?" or value - end - - ip = v:option(DummyValue, 3, translate("IPv4-Address")) - - mac = v:option(DummyValue, 2, translate("MAC-Address")) - - ltime = v:option(DummyValue, 1, translate("Leasetime remaining")) - function ltime.cfgvalue(self, ...) - local value = DummyValue.cfgvalue(self, ...) - return wa.date_format(os.difftime(tonumber(value), os.time())) - end -end +m2:section(SimpleSection).template = "admin_network/lease_status" s = m2:section(TypedSection, "host", translate("Static Leases"), translate("Use the Add Button to add a new lease entry. The MAC-Address " .. @@ -66,8 +31,13 @@ s.anonymous = true s.template = "cbi/tblsection" name = s:option(Value, "name", translate("Hostname")) + mac = s:option(Value, "mac", translate("MAC-Address")) +mac.datatype = "macaddr" + ip = s:option(Value, "ip", translate("IPv4-Address")) +ip.datatype = "ip4addr" + sys.net.arptable(function(entry) ip:value(entry["IP address"]) mac:value( @@ -76,5 +46,5 @@ sys.net.arptable(function(entry) ) end) - + return m2