applications/luci-vnstat: rework model, use uci config
authorJo-Philipp Wich <jow@openwrt.org>
Fri, 14 Jan 2011 19:58:53 +0000 (19:58 +0000)
committerJo-Philipp Wich <jow@openwrt.org>
Fri, 14 Jan 2011 19:58:53 +0000 (19:58 +0000)
applications/luci-vnstat/luasrc/model/cbi/vnstat.lua

index 71e7aca72b7c5c6c6ab05917853da44893bc7ebf..9161ec6a67364ea6e04ccdab6d8f505b4392584d 100644 (file)
@@ -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
-