summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-vnstat
diff options
context:
space:
mode:
Diffstat (limited to 'applications/luci-vnstat')
-rw-r--r--applications/luci-vnstat/luasrc/model/cbi/vnstat.lua31
1 files changed, 14 insertions, 17 deletions
diff --git a/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua b/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua
index 71e7aca72..9161ec6a6 100644
--- a/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua
+++ b/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua
@@ -1,7 +1,7 @@
--[[
LuCI - Lua Configuration Interface
-Copyright 2010 Jo-Philipp Wich <xm@subsignal.org>
+Copyright 2010-2011 Jo-Philipp Wich <xm@subsignal.org>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
@@ -25,7 +25,7 @@ end
dbdir = dbdir or "/var/lib/vnstat"
-m = SimpleForm("vnstat", translate("VnStat"),
+m = Map("vnstat", translate("VnStat"),
translate("VnStat is a network traffic monitor for Linux that keeps a log of network traffic for the selected interface(s)."))
m.submit = translate("Restart VnStat")
@@ -49,14 +49,16 @@ for _, iface in ipairs(sys.net.devices()) do
end
-local s = m:section(SimpleSection)
+local s = m:section(TypedSection, "vnstat")
+s.anonymous = true
+s.addremove = false
-mon_ifaces = s:option(Value, "ifaces", translate("Monitor selected interfaces"))
+mon_ifaces = s:option(Value, "interface", translate("Monitor selected interfaces"))
mon_ifaces.template = "cbi/network_ifacelist"
mon_ifaces.widget = "checkbox"
-mon_ifaces.default = utl.keys(enabled)
+mon_ifaces.cast = "table"
-function mon_ifaces.write(self, s, val)
+function mon_ifaces.write(self, section, val)
local i
local s = { }
@@ -67,24 +69,19 @@ function mon_ifaces.write(self, s, val)
end
for i, _ in pairs(ifaces) do
- if s[i] then
- sys.call("vnstat -u -i %q" % i)
- else
+ if not s[i] then
fs.unlink(dbdir .. "/" .. i)
fs.unlink(dbdir .. "/." .. i)
end
end
-
- sys.call("/etc/init.d/vnstat restart >/dev/null 2>/dev/null")
-
- m.message = "<p><strong>%s</strong></p>"
- % translate("The VnStat service has been restarted."), cmd
-
- self.default = utl.keys(s)
+ if next(s) then
+ m.uci:set_list("vnstat", section, "interface", utl.keys(s))
+ else
+ m.uci:delete("vnstat", section, "interface")
+ end
end
mon_ifaces.remove = mon_ifaces.write
return m
-