summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-wol/luasrc/model
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-04-21 21:25:58 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-04-21 21:25:58 +0000
commit34b3ae2a428f75165001dc0ef19cd33bc7f2323a (patch)
tree0bb8b11825f920c41bdf2f71ffcee9397c587fc0 /applications/luci-wol/luasrc/model
parent3cb299dc1077b7edee16e48255073603a3c694d8 (diff)
applications/luci-wol: handle command execution in write hook and use message facility to output info
Diffstat (limited to 'applications/luci-wol/luasrc/model')
-rw-r--r--applications/luci-wol/luasrc/model/cbi/wol.lua87
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 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(
- "<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