summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2011-04-25 19:54:32 +0000
committerJo-Philipp Wich <jow@openwrt.org>2011-04-25 19:54:32 +0000
commit542cc1da5bcdb1e77508c7847d18479e3c2b64b4 (patch)
tree0d6fa424ea041bc75c12b0f4d97843443bccd25b
parent4adfa3d84170582e32a5c30490089faee8fd2e6f (diff)
modules/admin-full: implement "dev" option for USB device led triggers (#224)
-rw-r--r--modules/admin-full/luasrc/model/cbi/admin_system/leds.lua50
1 files changed, 47 insertions, 3 deletions
diff --git a/modules/admin-full/luasrc/model/cbi/admin_system/leds.lua b/modules/admin-full/luasrc/model/cbi/admin_system/leds.lua
index b48ade5d3..ca964a815 100644
--- a/modules/admin-full/luasrc/model/cbi/admin_system/leds.lua
+++ b/modules/admin-full/luasrc/model/cbi/admin_system/leds.lua
@@ -46,7 +46,7 @@ for k, v in ipairs(leds) do
sysfs:value(v)
end
-s:option(Flag, "default", translate("Default state")).rmempty = false
+s:option(Flag, "default", translate("Default state")).rmempty = true
trigger = s:option(ListValue, "trigger", translate("Trigger"))
@@ -54,7 +54,7 @@ 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(t:gsub("-", "")))
-end
+end
delayon = s:option(Value, "delayon", translate ("On-State Delay"))
@@ -64,10 +64,26 @@ delayoff = s:option(Value, "delayoff", translate ("Off-State Delay"))
delayoff:depends("trigger", "timer")
-dev = s:option(ListValue, "dev", translate("Device"))
+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)
@@ -82,4 +98,32 @@ 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