applications/luci-wol: use net.mac_hints() instead of net.arptable() and other sources
This commit is contained in:
parent
0eb010a754
commit
2026f53881
1 changed files with 3 additions and 36 deletions
|
@ -10,8 +10,6 @@ You may obtain a copy of the License at
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
]]--
|
]]--
|
||||||
|
|
||||||
local uci = require "luci.model.uci".cursor()
|
|
||||||
local utl = require "luci.util"
|
|
||||||
local sys = require "luci.sys"
|
local sys = require "luci.sys"
|
||||||
local fs = require "nixio.fs"
|
local fs = require "nixio.fs"
|
||||||
|
|
||||||
|
@ -28,9 +26,6 @@ local has_wol = fs.access("/usr/bin/wol")
|
||||||
|
|
||||||
s = m:section(SimpleSection)
|
s = m:section(SimpleSection)
|
||||||
|
|
||||||
local arp = { }
|
|
||||||
local e, ip, mac, name
|
|
||||||
|
|
||||||
if has_ewk and has_wol then
|
if has_ewk and has_wol then
|
||||||
bin = s:option(ListValue, "binary", translate("WoL program"),
|
bin = s:option(ListValue, "binary", translate("WoL program"),
|
||||||
translate("Sometimes only one of both tools work. If one of fails, try the other one"))
|
translate("Sometimes only one of both tools work. If one of fails, try the other one"))
|
||||||
|
@ -55,40 +50,12 @@ if has_ewk then
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
for _, e in ipairs(sys.net.arptable()) do
|
|
||||||
arp[e["HW address"]:upper()] = { e["IP address"] }
|
|
||||||
end
|
|
||||||
|
|
||||||
for e in io.lines("/etc/ethers") do
|
|
||||||
mac, ip = e:match("^([a-f0-9]%S+) (%S+)")
|
|
||||||
if mac and ip then arp[mac:upper()] = { ip } end
|
|
||||||
end
|
|
||||||
|
|
||||||
for e in io.lines("/var/dhcp.leases") do
|
|
||||||
mac, ip, name = e:match("^%d+ (%S+) (%S+) (%S+)")
|
|
||||||
if mac and ip then arp[mac:upper()] = { ip, name ~= "*" and name } end
|
|
||||||
end
|
|
||||||
|
|
||||||
uci:foreach("dhcp", "host",
|
|
||||||
function(s)
|
|
||||||
if s.mac and s.ip then
|
|
||||||
if type(s.mac) == "table" then
|
|
||||||
local m
|
|
||||||
for _, m in ipairs(s.mac) do
|
|
||||||
arp[m:upper()] = { s.ip, s.name }
|
|
||||||
end
|
|
||||||
else
|
|
||||||
arp[s.mac:upper()] = { s.ip, s.name }
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
|
|
||||||
host = s:option(Value, "mac", translate("Host to wake up"),
|
host = s:option(Value, "mac", translate("Host to wake up"),
|
||||||
translate("Choose the host to wake up or enter a custom MAC address to use"))
|
translate("Choose the host to wake up or enter a custom MAC address to use"))
|
||||||
|
|
||||||
for mac, ip in utl.kspairs(arp) do
|
sys.net.mac_hints(function(mac, name)
|
||||||
host:value(mac, "%s (%s)" %{ mac, ip[2] or ip[1] })
|
host:value(mac, "%s (%s)" %{ mac, name })
|
||||||
end
|
end)
|
||||||
|
|
||||||
|
|
||||||
function host.write(self, s, val)
|
function host.write(self, s, val)
|
||||||
|
|
Loading…
Reference in a new issue