diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2010-04-21 21:25:58 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2010-04-21 21:25:58 +0000 |
commit | 34b3ae2a428f75165001dc0ef19cd33bc7f2323a (patch) | |
tree | 0bb8b11825f920c41bdf2f71ffcee9397c587fc0 | |
parent | 3cb299dc1077b7edee16e48255073603a3c694d8 (diff) |
applications/luci-wol: handle command execution in write hook and use message facility to output info
-rw-r--r-- | applications/luci-wol/luasrc/model/cbi/wol.lua | 87 |
1 files changed, 42 insertions, 45 deletions
diff --git a/applications/luci-wol/luasrc/model/cbi/wol.lua b/applications/luci-wol/luasrc/model/cbi/wol.lua index 03598fa13..bf192ee88 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( - "<p><br /><strong>%s</strong><br /><br /><code>%s<br /><br />" %{ - 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 .. "<br />") - else - break - end - end - p:close() - end - - luci.http.write("</code><br /></p>") - 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 = "<p><strong>%s</strong><br /><br /><code>%s<br /><br />" %{ + 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 .. "<br />" + else + break + end + end + p:close() + end + + msg = msg .. "</code></p>" + + m.message = msg + end +end + + return m |