From 34b3ae2a428f75165001dc0ef19cd33bc7f2323a Mon Sep 17 00:00:00 2001 From: Jo-Philipp Wich Date: Wed, 21 Apr 2010 21:25:58 +0000 Subject: applications/luci-wol: handle command execution in write hook and use message facility to output info --- applications/luci-wol/luasrc/model/cbi/wol.lua | 87 +++++++++++++------------- 1 file changed, 42 insertions(+), 45 deletions(-) (limited to 'applications/luci-wol/luasrc/model/cbi') diff --git a/applications/luci-wol/luasrc/model/cbi/wol.lua b/applications/luci-wol/luasrc/model/cbi/wol.lua index 03598fa133..bf192ee88a 100644 --- a/applications/luci-wol/luasrc/model/cbi/wol.lua +++ b/applications/luci-wol/luasrc/model/cbi/wol.lua @@ -23,51 +23,6 @@ m.reset = false local has_ewk = fs.access("/usr/bin/etherwake") local has_wol = fs.access("/usr/bin/wol") -if luci.http.formvalue("cbi.submit") then - local host = luci.http.formvalue("cbid.wol.1.mac") - if host and #host > 0 then - local cmd - local util = luci.http.formvalue("cbid.wol.1.binary") or ( - has_ewk and "/usr/bin/etherwake" or "/usr/bin/wol" - ) - - if util == "/usr/bin/etherwake" then - local iface = luci.http.formvalue("cbid.wol.1.iface") - cmd = "%s -D%s %q" %{ - util, (iface ~= "" and " -i %q" % iface or ""), host - } - else - cmd = "%s -v %q" %{ util, host } - end - - is = m:section(SimpleSection) - - function is.render() - luci.http.write( - "


%s

%s

" %{ - translate("Starting WoL utility:"), cmd - } - ) - - local p = io.popen(cmd .. " 2>&1") - if p then - while true do - local l = p:read("*l") - if l then - if #l > 100 then l = l:sub(1, 100) .. "..." end - luci.http.write(l .. "
") - else - break - end - end - p:close() - end - - luci.http.write("

") - end - end -end - s = m:section(SimpleSection) @@ -120,5 +75,47 @@ for mac, ip in pairs(arp) do end +function host.write(self, s, val) + local host = luci.http.formvalue("cbid.wol.1.mac") + if host and #host > 0 then + local cmd + local util = luci.http.formvalue("cbid.wol.1.binary") or ( + has_ewk and "/usr/bin/etherwake" or "/usr/bin/wol" + ) + + if util == "/usr/bin/etherwake" then + local iface = luci.http.formvalue("cbid.wol.1.iface") + cmd = "%s -D%s %q" %{ + util, (iface ~= "" and " -i %q" % iface or ""), host + } + else + cmd = "%s -v %q" %{ util, host } + end + + local msg = "

%s

%s

" %{ + translate("Starting WoL utility:"), cmd + } + + local p = io.popen(cmd .. " 2>&1") + if p then + while true do + local l = p:read("*l") + if l then + if #l > 100 then l = l:sub(1, 100) .. "..." end + msg = msg .. l .. "
" + else + break + end + end + p:close() + end + + msg = msg .. "

" + + m.message = msg + end +end + + return m -- cgit v1.2.3