123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- -- Copyright 2008 Steven Barth <steven@midlink.org>
- -- Copyright 2008-2011 Jo-Philipp Wich <jow@openwrt.org>
- -- Licensed to the public under the Apache License 2.0.
- m = Map("upnpd", luci.util.pcdata(translate("Universal Plug & Play")),
- translate("UPnP allows clients in the local network to automatically configure the router."))
- m:section(SimpleSection).template = "upnp_status"
- s = m:section(NamedSection, "config", "upnpd", translate("MiniUPnP settings"))
- s.addremove = false
- s:tab("general", translate("General Settings"))
- s:tab("advanced", translate("Advanced Settings"))
- e = s:taboption("general", Flag, "enabled", translate("Start UPnP and NAT-PMP service"))
- e.rmempty = false
- --function e.cfgvalue(self, section)
- -- return luci.sys.init.enabled("miniupnpd") and self.enabled or self.disabled
- --end
- function e.write(self, section, value)
- if value == "1" then
- luci.sys.call("/etc/init.d/miniupnpd start >/dev/null")
- else
- luci.sys.call("/etc/init.d/miniupnpd stop >/dev/null")
- end
- return Flag.write(self, section, value)
- end
- s:taboption("general", Flag, "enable_upnp", translate("Enable UPnP functionality")).default = "1"
- s:taboption("general", Flag, "enable_natpmp", translate("Enable NAT-PMP functionality")).default = "1"
- s:taboption("general", Flag, "secure_mode", translate("Enable secure mode"),
- translate("Allow adding forwards only to requesting ip addresses")).default = "1"
- s:taboption("general", Flag, "log_output", translate("Enable additional logging"),
- translate("Puts extra debugging information into the system log"))
- s:taboption("general", Value, "download", translate("Downlink"),
- translate("Value in KByte/s, informational only")).rmempty = true
- s:taboption("general", Value, "upload", translate("Uplink"),
- translate("Value in KByte/s, informational only")).rmempty = true
- port = s:taboption("general", Value, "port", translate("Port"))
- port.datatype = "port"
- port.default = 5000
- s:taboption("advanced", Flag, "system_uptime", translate("Report system instead of daemon uptime")).default = "1"
- s:taboption("advanced", Value, "uuid", translate("Device UUID"))
- s:taboption("advanced", Value, "serial_number", translate("Announced serial number"))
- s:taboption("advanced", Value, "model_number", translate("Announced model number"))
- ni = s:taboption("advanced", Value, "notify_interval", translate("Notify interval"))
- ni.datatype = "uinteger"
- ni.placeholder = 30
- ct = s:taboption("advanced", Value, "clean_ruleset_threshold", translate("Clean rules threshold"))
- ct.datatype = "uinteger"
- ct.placeholder = 20
- ci = s:taboption("advanced", Value, "clean_ruleset_interval", translate("Clean rules interval"))
- ci.datatype = "uinteger"
- ci.placeholder = 600
- pu = s:taboption("advanced", Value, "presentation_url", translate("Presentation URL"))
- pu.placeholder = "http://192.168.1.1/"
- lf = s:taboption("advanced", Value, "upnp_lease_file", translate("UPnP lease file"))
- lf.placeholder = "/var/log/upnp.leases"
- s2 = m:section(TypedSection, "perm_rule", translate("MiniUPnP ACLs"),
- translate("ACLs specify which external ports may be redirected to which internal addresses and ports"))
- s2.template = "cbi/tblsection"
- s2.sortable = true
- s2.anonymous = true
- s2.addremove = true
- s2:option(Value, "comment", translate("Comment"))
- ep = s2:option(Value, "ext_ports", translate("External ports"))
- ep.datatype = "portrange"
- ep.placeholder = "0-65535"
- ia = s2:option(Value, "int_addr", translate("Internal addresses"))
- ia.datatype = "ip4addr"
- ia.placeholder = "0.0.0.0/0"
- ip = s2:option(Value, "int_ports", translate("Internal ports"))
- ip.datatype = "portrange"
- ip.placeholder = "0-65535"
- ac = s2:option(ListValue, "action", translate("Action"))
- ac:value("allow")
- ac:value("deny")
- return m
|