luci-app-adblock: sync with adblock 3.1.0

* add support for new 'whitelist mode'
* fix a small css issue in advanced edit tabs

Signed-off-by: Dirk Brenken <dev@brenken.org>
This commit is contained in:
Dirk Brenken 2017-11-04 14:13:22 +01:00
parent 6d4370d681
commit b02a13ea77
2 changed files with 46 additions and 38 deletions

View file

@ -9,9 +9,9 @@ local dump = util.ubus("network.interface", "dump", {})
local json = require("luci.jsonc") local json = require("luci.jsonc")
local adbinput = uci.get("adblock", "global", "adb_rtfile") or "/tmp/adb_runtime.json" local adbinput = uci.get("adblock", "global", "adb_rtfile") or "/tmp/adb_runtime.json"
if not uci:get_first("adblock", "adblock", "adb_trigger") then if not uci:get("adblock", "extra") then
m = SimpleForm("error", nil, translate("Please update your adblock config file to use this package. ") m = SimpleForm("", nil, translate("Please update your adblock config file to use this package.<br />")
.. translatef("In OPKG use the '--force-maintainer' option to overwrite the pre-existing config file or download a fresh default config from " .. translatef("During opkg package installation use the '--force-maintainer' option to overwrite the pre-existing config file or download a fresh default config from "
.. "<a href=\"%s\" target=\"_blank\">" .. "<a href=\"%s\" target=\"_blank\">"
.. "here</a>", "https://raw.githubusercontent.com/openwrt/packages/master/net/adblock/files/adblock.conf")) .. "here</a>", "https://raw.githubusercontent.com/openwrt/packages/master/net/adblock/files/adblock.conf"))
m.submit = false m.submit = false
@ -23,16 +23,10 @@ m = Map("adblock", translate("Adblock"),
translate("Configuration of the adblock package to block ad/abuse domains by using DNS. ") translate("Configuration of the adblock package to block ad/abuse domains by using DNS. ")
.. translatef("For further information " .. translatef("For further information "
.. "<a href=\"%s\" target=\"_blank\">" .. "<a href=\"%s\" target=\"_blank\">"
.. "see online documentation</a>", "https://github.com/openwrt/packages/blob/master/net/adblock/files/README.md")) .. "check the online documentation</a>", "https://github.com/openwrt/packages/blob/master/net/adblock/files/README.md"))
function m.on_after_commit(self) function m.on_after_commit(self)
function e4.validate(self, value)
if value == "0" then
luci.sys.call("/etc/init.d/adblock reload >/dev/null 2>&1") luci.sys.call("/etc/init.d/adblock reload >/dev/null 2>&1")
else
luci.sys.call("/etc/init.d/adblock start >/dev/null 2>&1")
end
end
luci.http.redirect(luci.dispatcher.build_url("admin", "services", "adblock")) luci.http.redirect(luci.dispatcher.build_url("admin", "services", "adblock"))
end end
@ -44,7 +38,7 @@ local parse = json.parse(fs.readfile(adbinput) or "")
if parse then if parse then
status = parse.data.adblock_status status = parse.data.adblock_status
version = parse.data.adblock_version version = parse.data.adblock_version
domains = parse.data.blocked_domains domains = parse.data.overall_domains
fetch = parse.data.fetch_utility fetch = parse.data.fetch_utility
backend = parse.data.dns_backend backend = parse.data.dns_backend
rundate = parse.data.last_rundate rundate = parse.data.last_rundate
@ -82,14 +76,13 @@ o2 = s:option(ListValue, "adb_dns", translate("DNS Backend (DNS Directory)"),
.. translate("To overwrite the default path use the 'DNS Directory' option in the extra section below.")) .. translate("To overwrite the default path use the 'DNS Directory' option in the extra section below."))
o2:value("dnsmasq", "dnsmasq (/tmp/dnsmasq.d)") o2:value("dnsmasq", "dnsmasq (/tmp/dnsmasq.d)")
o2:value("unbound", "unbound (/var/lib/unbound)") o2:value("unbound", "unbound (/var/lib/unbound)")
o2:value("named", "bind (/var/lib/bind)") o2:value("named", "named (/var/lib/bind)")
o2:value("kresd", "kresd (/etc/kresd)") o2:value("kresd", "kresd (/etc/kresd)")
o2:value("dnscrypt-proxy","dnscrypt-proxy (/tmp)") o2:value("dnscrypt-proxy","dnscrypt-proxy (/tmp)")
o2.default = "dnsmasq"
o2.rmempty = false o2.rmempty = false
o3 = s:option(ListValue, "adb_trigger", translate("Startup Trigger"), o3 = s:option(ListValue, "adb_trigger", translate("Startup Trigger"),
translate("List of available network interfaces. By default the startup will be triggered by the 'wan' interface.<br />") translate("List of available network interfaces. Usually the startup will be triggered by the 'wan' interface.<br />")
.. translate("Choose 'none' to disable automatic startups, 'timed' to use a classic timeout (default 30 sec.) or select another trigger interface.")) .. translate("Choose 'none' to disable automatic startups, 'timed' to use a classic timeout (default 30 sec.) or select another trigger interface."))
o3:value("none") o3:value("none")
o3:value("timed") o3:value("timed")
@ -149,7 +142,7 @@ else
dv4.value = backend dv4.value = backend
end end
dv5 = s:option(DummyValue, "", translate("Overall Blocked Domains")) dv5 = s:option(DummyValue, "", translate("Overall Domains"))
dv5.template = "adblock/runtime" dv5.template = "adblock/runtime"
if parse == nil then if parse == nil then
dv5.value = translate("n/a") dv5.value = translate("n/a")
@ -170,7 +163,7 @@ end
bl = m:section(TypedSection, "source", translate("Blocklist Sources"), bl = m:section(TypedSection, "source", translate("Blocklist Sources"),
translate("Available blocklist sources. ") translate("Available blocklist sources. ")
.. translate("List URLs and Shallalist category selections are configurable in the 'Advanced' section.<br />") .. translate("List URLs and Shallalist category selections are configurable in the 'Advanced' section.<br />")
.. translate("Caution: Please don't select big lists or many lists at once on low memory devices to prevent OOM exceptions!")) .. translate("Caution: To prevent OOM exceptions on low memory devices with less than 64 MB free RAM, please do not select too many lists - 5-6 should be sufficient!"))
bl.template = "cbi/tblsection" bl.template = "cbi/tblsection"
name = bl:option(Flag, "enabled", translate("Enabled")) name = bl:option(Flag, "enabled", translate("Enabled"))
@ -185,12 +178,11 @@ function ssl.cfgvalue(self, section)
return translate("No") return translate("No")
end end
end end
des = bl:option(DummyValue, "adb_src_desc", translate("Description")) des = bl:option(DummyValue, "adb_src_desc", translate("Description"))
-- Extra options -- Extra options
e = m:section(NamedSection, "global", "adblock", translate("Extra Options"), e = m:section(NamedSection, "extra", "adblock", translate("Extra Options"),
translate("Options for further tweaking in case the defaults are not suitable for you.")) translate("Options for further tweaking in case the defaults are not suitable for you."))
e1 = e:option(Flag, "adb_debug", translate("Verbose Debug Logging"), e1 = e:option(Flag, "adb_debug", translate("Verbose Debug Logging"),
@ -204,34 +196,47 @@ e2.default = e2.disabled
e2.rmempty = false e2.rmempty = false
e3 = e:option(Flag, "adb_forcesrt", translate("Force Overall Sort"), e3 = e:option(Flag, "adb_forcesrt", translate("Force Overall Sort"),
translate("Enable memory intense overall sort / duplicate removal on low memory devices (&lt; 64 MB RAM)")) translate("Enable memory intense overall sort / duplicate removal on low memory devices (&lt; 64 MB free RAM)"))
e3.default = e3.disabled e3.default = e3.disabled
e3.rmempty = false e3.rmempty = false
e4 = e:option(Flag, "adb_manmode", translate("Manual / Backup mode"), e4 = e:option(Flag, "adb_backup", translate("Enable Blocklist Backup"),
translate("Do not automatically update blocklists during startup, use blocklist backups instead.")) translate("Create compressed blocklist backups, they will be used in case of download errors or during startup in backup mode."))
e4.default = e4.disabled e4.default = e4.disabled
e4.rmempty = false e4.rmempty = false
e5 = e:option(Flag, "adb_backup", translate("Enable Blocklist Backup"), e5 = e:option(Value, "adb_backupdir", translate("Backup Directory"),
translate("Create compressed blocklist backups, they will be used in case of download errors or during startup in manual mode.")) translate("Target directory for adblock backups. Please use only non-volatile disks, e.g. an external usb stick."))
e5.default = e5.disabled e5:depends("adb_backup", 1)
e5.rmempty = false e5.datatype = "directory"
e5.default = "/mnt"
e5.rmempty = true
e6 = e:option(Value, "adb_backupdir", translate("Backup Directory"), e6 = e:option(Flag, "adb_backup_mode", translate("Backup Mode"),
translate("Target directory for adblock backups. Please use only non-volatile disks, no ram/tmpfs drives.")) translate("Do not automatically update blocklists during startup, use blocklist backups instead."))
e6.datatype = "directory" e6:depends("adb_backup", 1)
e6.default = "/mnt" e6.default = e6.disabled
e6.rmempty = false e6.rmempty = true
e7 = e:option(Value, "adb_dnsdir", translate("DNS Directory"), e7 = e:option(Flag, "adb_whitelist_mode", translate("Whitelist Mode"),
translate("Block access to all domains except those explicitly listed in the whitelist file."))
e7.default = e7.disabled
e7.rmempty = true
e8 = e:option(Value, "adb_dnsdir", translate("DNS Directory"),
translate("Target directory for the generated blocklist 'adb_list.overall'.")) translate("Target directory for the generated blocklist 'adb_list.overall'."))
e7.datatype = "directory" e8.datatype = "directory"
e7.optional = true
e8 = e:option(Value, "adb_triggerdelay", translate("Trigger Delay"),
translate("Additional trigger delay in seconds before adblock processing begins."))
e8.datatype = "range(1,60)"
e8.optional = true e8.optional = true
e9 = e:option(Value, "adb_whitelist", translate("Whitelist File"),
translate("Full path to the whitelist file."))
e9.datatype = "file"
e9.default = "/etc/adblock/adblock.whitelist"
e9.optional = true
e10 = e:option(Value, "adb_triggerdelay", translate("Trigger Delay"),
translate("Additional trigger delay in seconds before adblock processing begins."))
e10.datatype = "range(1,60)"
e10.optional = true
return m return m

View file

@ -6,5 +6,8 @@
font-size: 12px; font-size: 12px;
font-family: monospace; font-family: monospace;
resize: none; resize: none;
white-space: pre;
overflow-wrap: normal;
overflow-x: scroll;
} }
</style> </style>