applications/luci-vnstat: move to status menu
[project/luci.git] / modules / admin-full / luasrc / model / cbi / admin_system / leds.lua
index 71bd7d0..053a5de 100644 (file)
@@ -11,7 +11,7 @@ You may obtain a copy of the License at
 
 $Id$
 ]]--
-m = Map("system", translate("leds"), translate("leds_desc"))
+m = Map("system", translate("<abbr title=\"Light Emitting Diode\">LED</abbr> Configuration"), translate("Customizes the behaviour of the device <abbr title=\"Light Emitting Diode\">LED</abbr>s if possible."))
 
 local sysfs_path = "/sys/class/leds/"
 local leds = {}
@@ -38,36 +38,52 @@ function s.parse(self, ...)
 end
 
 
-s:option(Value, "name")
+s:option(Value, "name", translate("Name"))
 
 
-sysfs = s:option(ListValue, "sysfs")
+sysfs = s:option(ListValue, "sysfs", translate("<abbr title=\"Light Emitting Diode\">LED</abbr> Name"))
 for k, v in ipairs(leds) do
        sysfs:value(v)
 end
 
-s:option(Flag, "default").rmempty = true
+s:option(Flag, "default", translate("Default state")).rmempty = false
 
 
-trigger = s:option(ListValue, "trigger")
+trigger = s:option(ListValue, "trigger", translate("Trigger"))
 
 local triggers = fs.readfile(sysfs_path .. leds[1] .. "/trigger")
 for t in triggers:gmatch("[%w-]+") do
-       trigger:value(t, translate("system_led_trigger_" .. t:gsub("-", "")))
-end 
+       trigger:value(t, translate(t:gsub("-", "")))
+end
 
 
-delayon = s:option(Value, "delayon")
+delayon = s:option(Value, "delayon", translate ("On-State Delay"))
 delayon:depends("trigger", "timer")
 
-delayoff = s:option(Value, "delayoff")
+delayoff = s:option(Value, "delayoff", translate ("Off-State Delay"))
 delayoff:depends("trigger", "timer")
 
 
-dev = s:option(ListValue, "dev")
+dev = s:option(ListValue, "_net_dev", translate("Device"))
 dev.rmempty = true
 dev:value("")
 dev:depends("trigger", "netdev")
+
+function dev.cfgvalue(self, section)
+       return m.uci:get("system", section, "dev")
+end
+
+function dev.write(self, section, value)
+       m.uci:set("system", section, "dev", value)
+end
+
+function dev.remove(self, section)
+       local t = trigger:formvalue(section)
+       if t ~= "netdev" and t ~= "usbdev" then
+               m.uci:delete("system", section, "dev")
+       end
+end
+
 for k, v in pairs(luci.sys.net.devices()) do
        if v ~= "lo" then
                dev:value(v)
@@ -75,11 +91,39 @@ for k, v in pairs(luci.sys.net.devices()) do
 end
 
 
-mode = s:option(MultiValue, "mode")
+mode = s:option(MultiValue, "mode", translate("Trigger Mode"))
 mode.rmempty = true
 mode:depends("trigger", "netdev")
-mode:value("link", translate("system_led_mode_link"))
-mode:value("tx", translate("system_led_mode_tx"))
-mode:value("rx", translate("system_led_mode_rx"))
+mode:value("link", translate("Link On"))
+mode:value("tx", translate("Transmit"))
+mode:value("rx", translate("Receive"))
+
+
+usbdev = s:option(ListValue, "_usb_dev", translate("USB Device"))
+usbdev:depends("trigger", "usbdev")
+usbdev.rmempty = true
+usbdev:value("")
+
+function usbdev.cfgvalue(self, section)
+       return m.uci:get("system", section, "dev")
+end
+
+function usbdev.write(self, section, value)
+       m.uci:set("system", section, "dev", value)
+end
+
+function usbdev.remove(self, section)
+       local t = trigger:formvalue(section)
+       if t ~= "netdev" and t ~= "usbdev" then
+               m.uci:delete("system", section, "dev")
+       end
+end
+
+for p in nixio.fs.glob("/sys/bus/usb/devices/[0-9]*/manufacturer") do
+       local id = p:match("%d+-%d+")
+       local mf = nixio.fs.readfile("/sys/bus/usb/devices/" .. id .. "/manufacturer")
+       local pr = nixio.fs.readfile("/sys/bus/usb/devices/" .. id .. "/product")
+       usbdev:value(id, "%s (%s - %s)" %{ id, mf, pr })
+end
 
 return m