Copyright 2008 Steven Barth <steven@midlink.org>
Copyright 2008 Jo-Philipp Wich <xm@leipzig.freifunk.net>
+Copyright 2013 Manuel Munz <freifunk at somakoma dot de>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
http://www.apache.org/licenses/LICENSE-2.0
-$Id$
]]--
-local is_mini = (luci.dispatcher.context.path[1] == "mini")
+require("luci.tools.webadmin")
-
-m = Map("ddns", translate("Dynamic DNS"), translate("Dynamic DNS allows that your router can be reached with a fixed hostname while having a dynamically changing IP-Address."))
+m = Map("ddns", translate("Dynamic DNS"),
+ translate("Dynamic DNS allows that your router can be reached with " ..
+ "a fixed hostname while having a dynamically changing " ..
+ "IP address."))
s = m:section(TypedSection, "service", "")
s.addremove = true
s.anonymous = false
-s:option(Flag, "enabled", translate("enable"))
+s:option(Flag, "enabled", translate("Enable"))
svc = s:option(ListValue, "service_name", translate("Service"))
-svc.rmempty = true
+svc.rmempty = false
+svc.default = "dyndns.org"
local services = { }
local fd = io.open("/usr/lib/ddns/services", "r")
svc:value(v)
end
-svc:value("", translate("-- custom --"))
-
+function svc.cfgvalue(...)
+ local v = Value.cfgvalue(...)
+ if not v or #v == 0 then
+ return "-"
+ else
+ return v
+ end
+end
-s:option(Value, "domain", translate("Hostname")).rmempty = true
-s:option(Value, "username", translate("Username")).rmempty = true
-pw = s:option(Value, "password", translate("Password"))
-pw.rmempty = true
-pw.password = true
+function svc.write(self, section, value)
+ if value == "-" then
+ m.uci:delete("ddns", section, self.option)
+ else
+ Value.write(self, section, value)
+ end
+end
+svc:value("-", "-- "..translate("custom").." --")
-if is_mini then
- s.defaults.ip_source = "network"
- s.defaults.ip_network = "wan"
-else
- require("luci.tools.webadmin")
+local url = s:option(Value, "update_url", translate("Custom update-URL"))
+url:depends("service_name", "-")
+url.rmempty = true
- src = s:option(ListValue, "ip_source", translate("Source of IP-Address"))
- src:value("network", translate("Network"))
- src:value("interface", translate("Interface"))
- src:value("web", "URL")
+local hostname = s:option(Value, "domain", translate("Hostname"))
+hostname.rmempty = true
+hostname.default = "mypersonaldomain.dyndns.org"
+hostname.datatype = "host"
- iface = s:option(ListValue, "ip_network", translate("Network"))
- iface:depends("ip_source", "network")
- iface.rmempty = true
- luci.tools.webadmin.cbi_add_networks(iface)
+local username = s:option(Value, "username", translate("Username"))
+username.rmempty = true
- iface = s:option(ListValue, "ip_interface", translate("Interface"))
- iface:depends("ip_source", "interface")
- iface.rmempty = true
- for k, v in pairs(luci.sys.net.devices()) do
- iface:value(v)
- end
+local pw = s:option(Value, "password", translate("Password"))
+pw.rmempty = true
+pw.password = true
- web = s:option(Value, "ip_url", "URL")
- web:depends("ip_source", "web")
- web.rmempty = true
+require("luci.tools.webadmin")
+
+local src = s:option(ListValue, "ip_source",
+ translate("Source of IP address"))
+src.default = "network"
+src:value("network", translate("network"))
+src:value("interface", translate("interface"))
+src:value("web", translate("URL"))
+
+local iface = s:option(ListValue, "ip_network", translate("Network"))
+iface:depends("ip_source", "network")
+iface.rmempty = true
+iface.default = "wan"
+luci.tools.webadmin.cbi_add_networks(iface)
+iface = s:option(ListValue, "ip_interface", translate("Interface"))
+iface:depends("ip_source", "interface")
+iface.rmempty = true
+for k, v in pairs(luci.sys.net.devices()) do
+ iface:value(v)
end
-url = s:option(Value, "update_url", translate("Custom Update-URL"))
-url:depends("service_name", "")
-url.rmempty = true
+local web = s:option(Value, "ip_url", translate("URL"))
+web:depends("ip_source", "web")
+web.default = "http://checkip.dyndns.com/"
+web.rmempty = true
+
-s:option(Value, "check_interval", translate("Check for changed IP every")).default = 10
-unit = s:option(ListValue, "check_unit", translate("Check-Time unit"))
+local ci = s:option(Value, "check_interval", translate("Check for changed IP every"))
+ci.datatype = "and(uinteger,min(1))"
+ci.default = 10
+
+local unit = s:option(ListValue, "check_unit", translate("Check-time unit"))
unit.default = "minutes"
-unit:value("minutes", "min")
-unit:value("hours", "h")
+unit:value("minutes", translate("min"))
+unit:value("hours", translate("h"))
+
+fi = s:option(Value, "force_interval", translate("Force update every"))
+fi.datatype = "and(uinteger,min(1))"
+fi.default = 72
-s:option(Value, "force_interval", translate("Force update every")).default = 72
-unit = s:option(ListValue, "force_unit", translate("Force-Time unit"))
+local unit = s:option(ListValue, "force_unit", translate("Force-time unit"))
unit.default = "hours"
-unit:value("minutes", "min")
-unit:value("hours", "h")
+unit:value("minutes", translate("min"))
+unit:value("hours", translate("h"))
return m