From: Jo-Philipp Wich Date: Wed, 21 Apr 2010 22:57:07 +0000 (+0000) Subject: applications: add luci-vnstat, frontend for the VnStat traffic monitor X-Git-Tag: 0.10.0~696 X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fluci.git;a=commitdiff_plain;h=f375c498f2058b9d8244a628ca78ef5110b2be79 applications: add luci-vnstat, frontend for the VnStat traffic monitor --- diff --git a/applications/luci-vnstat/Makefile b/applications/luci-vnstat/Makefile new file mode 100644 index 000000000..0d76c05e1 --- /dev/null +++ b/applications/luci-vnstat/Makefile @@ -0,0 +1,4 @@ +PO = vnstat + +include ../../build/config.mk +include ../../build/module.mk diff --git a/applications/luci-vnstat/luasrc/controller/vnstat.lua b/applications/luci-vnstat/luasrc/controller/vnstat.lua new file mode 100644 index 000000000..562fd0a24 --- /dev/null +++ b/applications/luci-vnstat/luasrc/controller/vnstat.lua @@ -0,0 +1,14 @@ +module("luci.controller.vnstat", package.seeall) + +function index() + require("luci.i18n").loadc("vnstat") + local i18n = luci.i18n.translate + + entry({"admin", "network", "vnstat"}, alias("admin", "network", "vnstat", "graphs"), i18n("VnStat Traffic Monitor"), 90).i18n = "vnstat" + entry({"admin", "network", "vnstat", "graphs"}, template("vnstat"), i18n("Graphs"), 1) + entry({"admin", "network", "vnstat", "config"}, cbi("vnstat"), i18n("VnStat Traffic Monitor"), 2) + + entry({"mini", "network", "vnstat"}, alias("mini", "network", "vnstat", "graphs"), i18n("VnStat Traffic Monitor"), 90).i18n = "vnstat" + entry({"mini", "network", "vnstat", "graphs"}, template("vnstat"), i18n("Graphs"), 1) + entry({"mini", "network", "vnstat", "config"}, cbi("vnstat"), i18n("VnStat Traffic Monitor"), 2) +end diff --git a/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua b/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua new file mode 100644 index 000000000..71e7aca72 --- /dev/null +++ b/applications/luci-vnstat/luasrc/model/cbi/vnstat.lua @@ -0,0 +1,90 @@ +--[[ +LuCI - Lua Configuration Interface + +Copyright 2010 Jo-Philipp Wich + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 +]]-- + +local utl = require "luci.util" +local sys = require "luci.sys" +local fs = require "nixio.fs" +local nw = require "luci.model.network" + +local dbdir, line + +for line in io.lines("/etc/vnstat.conf") do + dbdir = line:match("^%s*DatabaseDir%s+[\"'](%S-)[\"']") + if dbdir then break end +end + +dbdir = dbdir or "/var/lib/vnstat" + + +m = SimpleForm("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") +m.reset = false + +nw.init(luci.model.uci.cursor_state()) + +local ifaces = { } +local enabled = { } +local iface + +for iface in fs.dir(dbdir) do + if iface:sub(1,1) ~= '.' then + ifaces[iface] = iface + enabled[iface] = iface + end +end + +for _, iface in ipairs(sys.net.devices()) do + ifaces[iface] = iface +end + + +local s = m:section(SimpleSection) + +mon_ifaces = s:option(Value, "ifaces", translate("Monitor selected interfaces")) +mon_ifaces.template = "cbi/network_ifacelist" +mon_ifaces.widget = "checkbox" +mon_ifaces.default = utl.keys(enabled) + +function mon_ifaces.write(self, s, val) + local i + local s = { } + + if val then + for _, i in ipairs(type(val) == "table" and val or { val }) do + s[i] = true + end + end + + for i, _ in pairs(ifaces) do + if s[i] then + sys.call("vnstat -u -i %q" % i) + else + fs.unlink(dbdir .. "/" .. i) + fs.unlink(dbdir .. "/." .. i) + end + end + + + sys.call("/etc/init.d/vnstat restart >/dev/null 2>/dev/null") + + m.message = "

%s

" + % translate("The VnStat service has been restarted."), cmd + + self.default = utl.keys(s) +end + +mon_ifaces.remove = mon_ifaces.write + +return m + diff --git a/applications/luci-vnstat/luasrc/view/vnstat.htm b/applications/luci-vnstat/luasrc/view/vnstat.htm new file mode 100644 index 000000000..440252caa --- /dev/null +++ b/applications/luci-vnstat/luasrc/view/vnstat.htm @@ -0,0 +1,88 @@ +<%# +LuCI - Lua Configuration Interface +Copyright 2010 Jo-Philipp Wich + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +-%> + +<%- + +local fs = require "nixio.fs" +local sys = require "luci.sys" +local utl = require "luci.util" + +local param = luci.http.formvalue + +local iface = param("iface") +local style = param("style") + +style = (style and #style > 0) and style or "s" + + +-- +-- render image +-- +if iface then + luci.http.prepare_content("image/png") + + local png = io.popen("vnstati -i %q -%q -o -" % { iface, style }) + luci.http.write(png:read("*a")) + png:close() + + return + +-- +-- update database +-- +else + sys.call("vnstat -u >/dev/null 2>/dev/null") +end + + +-- +-- find databases +-- +local dbdir, line + +for line in io.lines("/etc/vnstat.conf") do + dbdir = line:match("^%s*DatabaseDir%s+[\"'](%S-)[\"']") + if dbdir then break end +end + +dbdir = dbdir or "/var/lib/vnstat" + +-%> + +<%+header%> + +

<%:VnStat Graphs%>

+ +
+ + + + + +
+ +


+ +
+<% for iface in fs.dir(dbdir) do if iface:sub(1,1) ~= "." then %> + +

+<% end end %> +
+ +<%+footer%> diff --git a/contrib/package/luci/Makefile b/contrib/package/luci/Makefile index 9d4d84e9e..55c21a5a8 100644 --- a/contrib/package/luci/Makefile +++ b/contrib/package/luci/Makefile @@ -788,6 +788,17 @@ define Package/luci-app-wol/install $(call Package/luci/install/template,$(1),applications/luci-wol) endef +define Package/luci-app-vnstat + $(call Package/luci/webtemplate) + TITLE:=LuCI Support for VnStat + DEPENDS+=+luci-admin-core +PACKAGE_luci-app-vnstat:vnstat \ + +PACKAGE_luci-app-vnstat:vnstati +endef + +define Package/luci-app-vnstat/install + $(call Package/luci/install/template,$(1),applications/luci-vnstat) +endef + ### Server Gateway Interfaces ### @@ -1215,6 +1226,9 @@ endif ifneq ($(CONFIG_PACKAGE_luci-app-wol),) PKG_SELECTED_MODULES+=applications/luci-wol endif +ifneq ($(CONFIG_PACKAGE_luci-app-vnstat),) + PKG_SELECTED_MODULES+=applications/luci-vnstat +endif ifneq ($(CONFIG_PACKAGE_luci-sgi-cgi),) @@ -1351,6 +1365,7 @@ $(eval $(call BuildPackage,luci-app-openvpn)) $(eval $(call BuildPackage,luci-app-p2pblock)) $(eval $(call BuildPackage,luci-app-multiwan)) $(eval $(call BuildPackage,luci-app-wol)) +$(eval $(call BuildPackage,luci-app-vnstat)) $(eval $(call BuildPackage,luci-sgi-cgi)) $(eval $(call BuildPackage,luci-sgi-uhttpd)) diff --git a/po/templates/vnstat.pot b/po/templates/vnstat.pot new file mode 100644 index 000000000..455bd89f6 --- /dev/null +++ b/po/templates/vnstat.pot @@ -0,0 +1,46 @@ +msgid "" +msgstr "Content-Type: text/plain; charset=UTF-8" + +msgid "Daily traffic" +msgstr "" + +msgid "Graphs" +msgstr "" + +msgid "Hourly traffic" +msgstr "" + +msgid "Monitor selected interfaces" +msgstr "" + +msgid "Monthly traffic" +msgstr "" + +msgid "Restart VnStat" +msgstr "" + +msgid "Summary display" +msgstr "" + +msgid "The VnStat service has been restarted." +msgstr "" + +msgid "Top 10 display" +msgstr "" + +msgid "Update »" +msgstr "" + +msgid "VnStat" +msgstr "" + +msgid "VnStat Graphs" +msgstr "" + +msgid "VnStat Traffic Monitor" +msgstr "" + +msgid "" +"VnStat is a network traffic monitor for Linux that keeps a log of network " +"traffic for the selected interface(s)." +msgstr ""