summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-app-adblock/luasrc
diff options
context:
space:
mode:
authorDirk Brenken <dev@brenken.org>2020-03-28 14:35:10 +0100
committerDirk Brenken <dev@brenken.org>2020-03-28 14:35:10 +0100
commit0f18b873d893a30564a2684e0dcc7f4fb68ed296 (patch)
treead80bf79f72e4a9935bcd74266afd4074d038ef9 /applications/luci-app-adblock/luasrc
parent0adf93de3b78fae8a19843906852abad6c7855ae (diff)
luci-app-adblock: release 4.0.0
* complete rewrite, migrated to client side JS * tested with mainline 19.07 and current master * tested with latest Firefox & Chrome and all standard themes (not OpenWrt2020!) Pre-tested by many forum users, see here: https://forum.openwrt.org/t/adblock-4-pre-releases/57101 * sync translations Signed-off-by: Dirk Brenken <dev@brenken.org>
Diffstat (limited to 'applications/luci-app-adblock/luasrc')
-rw-r--r--applications/luci-app-adblock/luasrc/controller/adblock.lua177
-rw-r--r--applications/luci-app-adblock/luasrc/model/cbi/adblock/blacklist_tab.lua55
-rw-r--r--applications/luci-app-adblock/luasrc/model/cbi/adblock/configuration_tab.lua52
-rw-r--r--applications/luci-app-adblock/luasrc/model/cbi/adblock/overview_tab.lua267
-rw-r--r--applications/luci-app-adblock/luasrc/model/cbi/adblock/whitelist_tab.lua55
-rw-r--r--applications/luci-app-adblock/luasrc/view/adblock/adblock_css.htm86
-rw-r--r--applications/luci-app-adblock/luasrc/view/adblock/blocklist.htm47
-rw-r--r--applications/luci-app-adblock/luasrc/view/adblock/logread.htm36
-rw-r--r--applications/luci-app-adblock/luasrc/view/adblock/query.htm64
-rw-r--r--applications/luci-app-adblock/luasrc/view/adblock/report.htm310
-rw-r--r--applications/luci-app-adblock/luasrc/view/adblock/runtime.htm213
11 files changed, 7 insertions, 1355 deletions
diff --git a/applications/luci-app-adblock/luasrc/controller/adblock.lua b/applications/luci-app-adblock/luasrc/controller/adblock.lua
index bee1d1439..11a4abb9f 100644
--- a/applications/luci-app-adblock/luasrc/controller/adblock.lua
+++ b/applications/luci-app-adblock/luasrc/controller/adblock.lua
@@ -1,175 +1,12 @@
--- Copyright 2017-2019 Dirk Brenken (dev@brenken.org)
--- This is free software, licensed under the Apache License, Version 2.0
+-- stub lua controller for 19.07 backward compatibility
module("luci.controller.adblock", package.seeall)
-local sys = require("luci.sys")
-local util = require("luci.util")
-local http = require("luci.http")
-local i18n = require("luci.i18n")
-local json = require("luci.jsonc")
-local uci = require("luci.model.uci").cursor()
-
function index()
- if not nixio.fs.access("/etc/config/adblock") then
- return
- end
- entry({"admin", "services", "adblock"}, firstchild(), _("Adblock"), 30).dependent = false
- entry({"admin", "services", "adblock", "tab_from_cbi"}, cbi("adblock/overview_tab", {hideresetbtn=true, hidesavebtn=true}), _("Overview"), 10).leaf = true
- if nixio.fs.access("/usr/sbin/tcpdump") then
- entry({"admin", "services", "adblock", "report"}, template("adblock/report"), _("DNS Query Report"), 20).leaf = true
- end
- entry({"admin", "services", "adblock", "log"}, template("adblock/logread"), _("Logfile"), 30).leaf = true
- entry({"admin", "services", "adblock", "advanced"}, firstchild(), _("Advanced"), 100)
- entry({"admin", "services", "adblock", "advanced", "blacklist"}, form("adblock/blacklist_tab"), _("Edit Blacklist"), 110).leaf = true
- entry({"admin", "services", "adblock", "advanced", "whitelist"}, form("adblock/whitelist_tab"), _("Edit Whitelist"), 120).leaf = true
- entry({"admin", "services", "adblock", "advanced", "configuration"}, form("adblock/configuration_tab"), _("Edit Configuration"), 130).leaf = true
- entry({"admin", "services", "adblock", "advanced", "query"}, template("adblock/query"), _("Query domains"), 140).leaf = true
- entry({"admin", "services", "adblock", "advanced", "result"}, call("queryData"), nil, 150).leaf = true
- entry({"admin", "services", "adblock", "logread"}, call("logread"), nil).leaf = true
- entry({"admin", "services", "adblock", "status_update"}, call("status_update"), nil).leaf = true
- entry({"admin", "services", "adblock", "report_json"}, call("report_json"), nil).leaf = true
- entry({"admin", "services", "adblock", "report_text"}, call("report_text"), nil).leaf = true
- entry({"admin", "services", "adblock", "action"}, call("adb_action"), nil).leaf = true
-end
-
-function adb_action(name, ...)
- local domain = select(1, ...) or ""
- local search = select(2, ...) or "+"
- local count = select(3, ...) or "50"
- local filter = select(4, ...) or "false"
- local print = select(5, ...) or "false"
-
- local report_params = {
- search,
- count,
- filter,
- print
- }
-
- if name == "do_suspend" then
- luci.sys.call("/etc/init.d/adblock suspend >/dev/null 2>&1")
- elseif name == "do_resume" then
- luci.sys.call("/etc/init.d/adblock resume >/dev/null 2>&1")
- elseif name == "do_refresh" then
- luci.sys.call("/etc/init.d/adblock reload >/dev/null 2>&1")
- elseif name == "do_report" then
- luci.sys.call("/etc/init.d/adblock report " ..table.concat(report_params, " ").. " >/dev/null 2>&1")
- local rep_dir = uci:get("adblock", "extra", "adb_repdir") or "/tmp"
- repeat
- nixio.nanosleep(1)
- until not nixio.fs.access(rep_dir.. "/adb_report.raw")
- elseif name == "do_filter" then
- luci.sys.call("/etc/init.d/adblock report " ..table.concat(report_params, " ").. " >/dev/null 2>&1")
- local rep_dir = uci:get("adblock", "extra", "adb_repdir") or "/tmp"
- repeat
- nixio.nanosleep(1)
- until nixio.fs.access(rep_dir.. "/adb_report.final")
- elseif name == "add_blacklist" then
- local file = uci:get("adblock", "blacklist", "adb_src") or "/etc/adblock/adblock.blacklist"
- if nixio.fs.access(file) then
- local blacklist = nixio.fs.readfile(file)
- if not string.find(blacklist, domain, 1, true)
- then
- nixio.fs.writefile(file, blacklist.. domain.. "\n")
- end
- end
- elseif name == "add_whitelist" then
- local file = uci:get("adblock", "global", "adb_whitelist") or "/etc/adblock/adblock.whitelist"
- if nixio.fs.access(file) then
- local whitelist = nixio.fs.readfile(file)
- if not string.find(whitelist, domain, 1, true)
- then
- nixio.fs.writefile(file, whitelist.. domain.. "\n")
- end
- end
- end
- if name == "do_suspend" or name == "do_resume" or name == "do_refresh" then
- local pid_file = "/var/run/adblock.pid"
- if nixio.fs.access(pid_file) then
- repeat
- nixio.nanosleep(1)
- until nixio.fs.readfile(pid_file) == ""
- end
- end
- luci.http.prepare_content("text/plain")
- luci.http.write("0")
-end
-
-function status_update()
- local rt_file
- local content
-
- rt_file = uci:get("adblock", "global", "adb_rtfile") or "/tmp/adb_runtime.json"
-
- if nixio.fs.access(rt_file) then
- content = json.parse(nixio.fs.readfile(rt_file) or "")
- http.prepare_content("application/json")
- http.write_json(content)
- end
-end
-
-function report_json()
- local rep_dir
- local rep_file
- local content
-
- rep_dir = uci:get("adblock", "extra", "adb_repdir") or "/tmp"
- rep_file = rep_dir.. "/adb_report.json"
- http.prepare_content("application/json")
-
- if nixio.fs.access(rep_file) then
- content = json.parse(nixio.fs.readfile(rep_file) or "")
- http.write_json(content)
- else
- http.write_json("{}")
- end
-end
-
-function report_text()
- local file
- local rep_dir
- local rep_file
- local content
-
- rep_dir = uci:get("adblock", "extra", "adb_repdir") or "/tmp"
- rep_file = rep_dir.. "/adb_report.final"
- http.prepare_content("text/plain")
-
- if nixio.fs.access(rep_file) then
- file = io.open(rep_file, "r")
- content = file:read("*all")
- file:close()
- http.write(content)
- else
- http.write("")
- end
-end
-
-function logread()
- local content = util.trim(util.exec("logread -e 'adblock-'")) or ""
-
- if content == "" then
- content = "No adblock related logs yet!"
- end
- http.write(content)
-end
-
-function queryData(domain)
- if domain then
- luci.http.prepare_content("text/plain")
- local cmd = "/etc/init.d/adblock query %s 2>&1"
- local util = io.popen(cmd % util.shellquote(domain))
- if util then
- while true do
- local line = util:read("*l")
- if not line then
- break
- end
- luci.http.write(line)
- luci.http.write("\n")
- end
- util:close()
- end
- end
+ entry({"admin", "services", "adblock"}, firstchild(), _("Adblock"), 60)
+ entry({"admin", "services", "adblock", "overview"}, view("adblock/overview"), _("Overview"), 10)
+ entry({"admin", "services", "adblock", "dnsreport"}, view("adblock/dnsreport"), _("DNS Report"), 20)
+ entry({"admin", "services", "adblock", "blacklist"}, view("adblock/blacklist"), _("Edit Blacklist"), 30)
+ entry({"admin", "services", "adblock", "whitelist"}, view("adblock/whitelist"), _("Edit Whitelist"), 40)
+ entry({"admin", "services", "adblock", "logread"}, view("adblock/logread"), _("Log View"), 50)
end
diff --git a/applications/luci-app-adblock/luasrc/model/cbi/adblock/blacklist_tab.lua b/applications/luci-app-adblock/luasrc/model/cbi/adblock/blacklist_tab.lua
deleted file mode 100644
index 4d1a9f7e6..000000000
--- a/applications/luci-app-adblock/luasrc/model/cbi/adblock/blacklist_tab.lua
+++ /dev/null
@@ -1,55 +0,0 @@
--- Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
--- This is free software, licensed under the Apache License, Version 2.0
-
-local fs = require("nixio.fs")
-local util = require("luci.util")
-local uci = require("luci.model.uci").cursor()
-local input = uci:get("adblock", "blacklist", "adb_src") or "/etc/adblock/adblock.blacklist"
-
-if not fs.access(input) then
- m = SimpleForm("error", nil, translate("Input file not found, please check your configuration."))
- m.reset = false
- m.submit = false
- return m
-end
-
-if fs.stat(input).size >= 102400 then
- m = SimpleForm("error", nil,
- translate("The file size is too large for online editing in LuCI (&ge; 100 KB). ")
- .. translate("Please edit this file directly in a terminal session."))
- m.reset = false
- m.submit = false
- return m
-end
-
-m = SimpleForm("input", nil)
-m:append(Template("adblock/adblock_css"))
-m.submit = translate("Save")
-m.reset = false
-
-s = m:section(SimpleSection, nil,
- translatef("This form allows you to modify the content of the adblock blacklist (%s). ", input)
- .. translate("Please add only one domain per line. Comments introduced with '#' are allowed - ip addresses, wildcards and regex are not."))
-
-f = s:option(TextValue, "data")
-f.datatype = "string"
-f.rows = 20
-f.rmempty = true
-
-function f.cfgvalue()
- return fs.readfile(input) or ""
-end
-
-function f.write(self, section, data)
- return fs.writefile(input, "\n" .. util.trim(data:gsub("\r\n", "\n")) .. "\n")
-end
-
-function f.remove(self, section, value)
- return fs.writefile(input, "")
-end
-
-function s.handle(self, state, data)
- return true
-end
-
-return m
diff --git a/applications/luci-app-adblock/luasrc/model/cbi/adblock/configuration_tab.lua b/applications/luci-app-adblock/luasrc/model/cbi/adblock/configuration_tab.lua
deleted file mode 100644
index 1e7eda903..000000000
--- a/applications/luci-app-adblock/luasrc/model/cbi/adblock/configuration_tab.lua
+++ /dev/null
@@ -1,52 +0,0 @@
--- Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
--- This is free software, licensed under the Apache License, Version 2.0
-
-local fs = require("nixio.fs")
-local util = require("luci.util")
-local input = "/etc/config/adblock"
-
-if not fs.access(input) then
- m = SimpleForm("error", nil, translate("Input file not found, please check your configuration."))
- m.reset = false
- m.submit = false
- return m
-end
-
-if fs.stat(input).size >= 102400 then
- m = SimpleForm("error", nil,
- translate("The file size is too large for online editing in LuCI (&ge; 100 KB). ")
- .. translate("Please edit this file directly in a terminal session."))
- m.reset = false
- m.submit = false
- return m
-end
-
-m = SimpleForm("input", nil)
-m:append(Template("adblock/adblock_css"))
-m.submit = translate("Save")
-m.reset = false
-
-s = m:section(SimpleSection, nil,
- translate("This form allows you to modify the content of the main adblock configuration file (/etc/config/adblock)."))
-
-f = s:option(TextValue, "data")
-f.rows = 20
-f.rmempty = true
-
-function f.cfgvalue()
- return fs.readfile(input) or ""
-end
-
-function f.write(self, section, data)
- return fs.writefile(input, "\n" .. util.trim(data:gsub("\r\n", "\n")) .. "\n")
-end
-
-function f.remove(self, section, value)
- return fs.writefile(input, "")
-end
-
-function s.handle(self, state, data)
- return true
-end
-
-return m
diff --git a/applications/luci-app-adblock/luasrc/model/cbi/adblock/overview_tab.lua b/applications/luci-app-adblock/luasrc/model/cbi/adblock/overview_tab.lua
deleted file mode 100644
index edef8a049..000000000
--- a/applications/luci-app-adblock/luasrc/model/cbi/adblock/overview_tab.lua
+++ /dev/null
@@ -1,267 +0,0 @@
--- Copyright 2017-2019 Dirk Brenken (dev@brenken.org)
--- This is free software, licensed under the Apache License, Version 2.0
-
-local fs = require("nixio.fs")
-local uci = require("luci.model.uci").cursor()
-local util = require("luci.util")
-local net = require "luci.model.network".init()
-local dump = util.ubus("network.interface", "dump", {})
-
-m = Map("adblock", translate("Adblock"),
- translate("Configuration of the adblock package to block ad/abuse domains by using DNS. ")
- ..translatef("For further information "
- .. "<a href=\"%s\" target=\"_blank\">"
- .. "check the online documentation</a>", "https://github.com/openwrt/packages/blob/master/net/adblock/files/README.md"))
-
--- Main adblock options
-
-s = m:section(NamedSection, "global", "adblock")
-
-o1 = s:option(Flag, "adb_enabled", translate("Enable Adblock"))
-o1.default = o1.disabled
-o1.rmempty = false
-
-o2 = s:option(ListValue, "adb_dns", translate("DNS Backend (DNS Directory)"),
- translate("List of supported DNS backends with their default list export directory. ")
- ..translate("To overwrite the default path use the 'DNS Directory' option in the extra section below."))
-o2:value("dnsmasq", "dnsmasq (/tmp)")
-o2:value("unbound", "unbound (/var/lib/unbound)")
-o2:value("named", "named (/var/lib/bind)")
-o2:value("kresd", "kresd (/etc/kresd)")
-o2.default = "dnsmasq (/tmp)"
-o2.rmempty = false
-
-o3 = s:option(ListValue, "adb_dnsvariant", translate("DNS Blocking Variant"),
- translate("List of supported DNS blocking variants. By default 'nxdomain' will be used for all DNS backends. ")
- ..translate("Dnsmasq also supports 'null' block variants, which may provide better response times."))
-o3:value("nxdomain", "nxdomain, all DNS backends")
-o3:value("null (IPv4)", "null (IPv4), dnsmasq only")
-o3:value("null (IPv4/IPv6)", "null (IPv4/IPv6), dnsmasq only")
-o3.default = "nxdomain, all DNS backends"
-o3.rmempty = false
-
-o4 = s:option(ListValue, "adb_fetchutil", translate("Download Utility"),
- translate("List of supported and fully pre-configured download utilities."))
-o4:value("uclient-fetch")
-o4:value("wget")
-o4:value("curl")
-o4:value("aria2c")
-o4:value("wget-nossl", "wget-nossl (noSSL)")
-o4:value("busybox", "wget-busybox (noSSL)")
-o4.default = "uclient-fetch"
-o4.rmempty = false
-
-o5 = s:option(ListValue, "adb_trigger", translate("Startup Trigger"),
- translate("List of available network interfaces. Usually the startup will be triggered by the 'wan' interface. ")
- ..translate("Choose 'none' to disable automatic startups, 'timed' to use a classic timeout (default 30 sec.) or select another trigger interface."))
-o5:value("none")
-o5:value("timed")
-if dump then
- local i, v
- for i, v in ipairs(dump.interface) do
- if v.interface ~= "loopback" then
- local device = v.l3_device or v.device or "-"
- o5:value(v.interface, v.interface.. " (" ..device.. ")")
- end
- end
-end
-o5.rmempty = false
-
--- Runtime information
-
-ds = s:option(DummyValue, "_dummy")
-ds.template = "adblock/runtime"
-
--- Blocklist table
-
-bl = m:section(TypedSection, "source", translate("Blocklist Sources"),
- translate("<b>Caution:</b> To prevent OOM exceptions on low memory devices with less than 64 MB free RAM, please only select a few of them!"))
-bl.template = "adblock/blocklist"
-
-name = bl:option(Flag, "enabled", translate("Enabled"))
-name.rmempty = false
-
-ssl = bl:option(DummyValue, "adb_src", translate("SSL req."))
-function ssl.cfgvalue(self, section)
- local source = self.map:get(section, "adb_src")
- if source and source:match("https://") then
- return translate("Yes")
- else
- return translate("No")
- end
-end
-
-des = bl:option(DummyValue, "adb_src_desc", translate("Description"))
-
-cat = bl:option(DynamicList, "adb_src_cat", translate("Archive Categories"))
-cat.datatype = "uciname"
-cat.optional = true
-
--- 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."))
-
-e1 = e:option(Flag, "adb_debug", translate("Verbose Debug Logging"),
- translate("Enable verbose debug logging in case of any processing error."))
-e1.rmempty = false
-
-e2 = e:option(Flag, "adb_nice", translate("Low Priority Service"),
- translate("Set the nice level to 'low priority' and the adblock background processing will take fewer resources from the system. ")
- ..translate("This change requires a manual service stop/re-start to take effect."))
-e2.disabled = "0"
-e2.enabled = "10"
-e2.rmempty = false
-
-e3 = e:option(Flag, "adb_forcedns", translate("Force Local DNS"),
- translate("Redirect all DNS queries from 'lan' zone to the local resolver, applies to UDP and TCP protocol on port 53, 853 and 5353."))
-e3.rmempty = false
-
-e4 = e:option(Value, "adb_maxqueue", translate("Max. Download Queue"),
- translate("Size of the download queue to handle downloads &amp; list processing in parallel (default '4'). ")
- ..translate("For further performance improvements you can raise this value, e.g. '8' or '16' should be safe."))
-e4.default = 4
-e4.datatype = "range(1,32)"
-e4.rmempty = false
-
-e5 = e:option(Flag, "adb_dnsfilereset", translate("DNS File Reset"),
- translate("Resets the final DNS blockfile 'adb_list.overall' after loading through the DNS backend. ")
- ..translate("This option saves an enormous amount of storage space, but starts a small ubus/adblock monitor in the background."))
-e5.disabled = "false"
-e5.enabled = "true"
-e5.rmempty = false
-
-e6 = e:option(Flag, "adb_report", translate("DNS Query Report"),
- translate("Gather DNS related network traffic via tcpdump to provide a DNS Query Report on demand. ")
- ..translate("Please note: this needs manual 'tcpdump-mini' package installation."))
-e6.rmempty = false
-
-e7 = e:option(Value, "adb_repdir", translate("Report Directory"),
- translate("Target directory for dns related report files. Default is '/tmp', please use preferably a non-volatile disk if available."))
-e7:depends("adb_report", 1)
-e7.datatype = "directory"
-e7.default = "/tmp"
-e7.rmempty = true
-
-e8 = e:option(Value, "adb_backupdir", translate("Backup Directory"),
- translate("Target directory for adblock source backups. Default is '/tmp', please use preferably a non-volatile disk if available."))
-e8.datatype = "directory"
-e8.default = "/tmp"
-e8.rmempty = true
-
-e9 = e:option(Flag, "adb_mail", translate("E-Mail Notification"),
- translate("Send notification e-mails in case of a processing error or if domain count is &le; 0. ")
- .. translate("Please note: this needs manual 'msmtp' package installation and setup."))
-e9.rmempty = true
-
-e10 = e:option(Value, "adb_mreceiver", translate("E-Mail Receiver Address"),
- translate("Receiver address for adblock notification e-mails."))
-e10:depends("adb_mail", 1)
-e10.rmempty = true
-
--- Optional Extra Options
-
-e20 = e:option(Value, "adb_dnsdir", translate("DNS Directory"),
- translate("Target directory for the generated blocklist 'adb_list.overall'."))
-e20.datatype = "directory"
-e20.optional = true
-
-e21 = e:option(Value, "adb_blacklist", translate("Blacklist File"),
- translate("Full path to the blacklist file."))
-e21.datatype = "file"
-e21.default = "/etc/adblock/adblock.blacklist"
-e21.optional = true
-
-e22 = e:option(Value, "adb_whitelist", translate("Whitelist File"),
- translate("Full path to the whitelist file."))
-e22.datatype = "file"
-e22.default = "/etc/adblock/adblock.whitelist"
-e22.optional = true
-
-e23 = e:option(Value, "adb_triggerdelay", translate("Trigger Delay"),
- translate("Additional trigger delay in seconds before adblock processing begins."))
-e23.datatype = "range(1,60)"
-e23.optional = true
-
-e24 = e:option(Value, "adb_maxtld", translate("TLD Compression Threshold"),
- translate("Disable the toplevel domain compression, if the number of blocked domains is greater than this threshold."))
-e24.datatype = "min(0)"
-e24.default = 100000
-e24.optional = true
-
-e25 = e:option(Value, "adb_portlist", translate("Local FW/DNS Ports"),
- translate("Space separated list of firewall ports which should be redirected locally."))
-e25.default = "53 853 5353"
-e25.optional = true
-
-e26 = e:option(Flag, "adb_dnsinotify", translate("DNS Inotify"),
- translate("Disable adblock triggered restarts and the 'DNS File Reset' for DNS backends with autoload features."))
-e26.default = nil
-e26.enabled = "true"
-e26.optional = true
-
-e27 = e:option(Flag, "adb_dnsflush", translate("Flush DNS Cache"),
- translate("Flush DNS cache after adblock processing."))
-e27.default = nil
-e27.optional = true
-
-e28 = e:option(ListValue, "adb_repiface", translate("Report Interface"),
- translate("Reporting interface used by tcpdump, set to 'any' for multiple interfaces (default 'br-lan'). ")
- ..translate("This change requires a manual service stop/re-start to take effect."))
-if dump then
- local i, v
- for i, v in ipairs(dump.interface) do
- if v.interface ~= "loopback" then
- local device = v.device
- if device then
- e28:value(device)
- end
- end
- end
-end
-e28:value("any")
-e28.optional = true
-
-e29 = e:option(Value, "adb_replisten", translate("Report Listen Port(s)"),
- translate("Space separated list of reporting port(s) used by tcpdump (default: '53'). ")
- ..translate("This change requires a manual service stop/re-start to take effect."))
-e29.default = 53
-e29.optional = true
-
-e30 = e:option(Value, "adb_repchunkcnt", translate("Report Chunk Count"),
- translate("Report chunk count used by tcpdump (default '5'). ")
- ..translate("This change requires a manual service stop/re-start to take effect."))
-e30.datatype = "range(1,10)"
-e30.default = 5
-e30.optional = true
-
-e31 = e:option(Value, "adb_repchunksize", translate("Report Chunk Size"),
- translate("Report chunk size used by tcpdump in MB (default '1'). ")
- ..translate("This change requires a manual service stop/re-start to take effect."))
-e31.datatype = "range(1,10)"
-e31.default = 1
-e31.optional = true
-
-e32 = e:option(Value, "adb_msender", translate("E-mail Sender Address"),
- translate("Sender address for adblock notification e-mails."))
-e32.default = "no-reply@adblock"
-e32.optional = true
-
-e33 = e:option(Value, "adb_mtopic", translate("E-mail Topic"),
- translate("Topic for adblock notification e-mails."))
-e33.default = "adblock notification"
-e33.optional = true
-
-e34 = e:option(Value, "adb_mprofile", translate("E-mail Profile"),
- translate("Mail profile used in 'msmtp' for adblock notification e-mails."))
-e34.default = "adb_notify"
-e34.optional = true
-
-e35 = e:option(Value, "adb_mcnt", translate("E-mail Notification Count"),
- translate("Raise the minimum notification count, to get e-mails if the overall count is less or equal to the given limit (default 0), ")
- .. translate("e.g. to receive an e-mail notification with every adblock run set this value to 200000."))
-e35.default = 0
-e35.datatype = "min(0)"
-e35.optional = true
-
-return m
diff --git a/applications/luci-app-adblock/luasrc/model/cbi/adblock/whitelist_tab.lua b/applications/luci-app-adblock/luasrc/model/cbi/adblock/whitelist_tab.lua
deleted file mode 100644
index 03dcecf1a..000000000
--- a/applications/luci-app-adblock/luasrc/model/cbi/adblock/whitelist_tab.lua
+++ /dev/null
@@ -1,55 +0,0 @@
--- Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
--- This is free software, licensed under the Apache License, Version 2.0
-
-local fs = require("nixio.fs")
-local util = require("luci.util")
-local uci = require("luci.model.uci").cursor()
-local input = uci:get("adblock", "global", "adb_whitelist") or "/etc/adblock/adblock.whitelist"
-
-if not fs.access(input) then
- m = SimpleForm("error", nil, translate("Input file not found, please check your configuration."))
- m.reset = false
- m.submit = false
- return m
-end
-
-if fs.stat(input).size >= 102400 then
- m = SimpleForm("error", nil,
- translate("The file size is too large for online editing in LuCI (&ge; 100 KB). ")
- .. translate("Please edit this file directly in a terminal session."))
- m.reset = false
- m.submit = false
- return m
-end
-
-m = SimpleForm("input", nil)
-m:append(Template("adblock/adblock_css"))
-m.submit = translate("Save")
-m.reset = false
-
-s = m:section(SimpleSection, nil,
- translatef("This form allows you to modify the content of the adblock whitelist (%s). ", input)
- .. translate("Please add only one domain per line. Comments introduced with '#' are allowed - ip addresses, wildcards and regex are not."))
-
-f = s:option(TextValue, "data")
-f.datatype = "string"
-f.rows = 20
-f.rmempty = true
-
-function f.cfgvalue()
- return fs.readfile(input) or ""
-end
-
-function f.write(self, section, data)
- return fs.writefile(input, "\n" .. util.trim(data:gsub("\r\n", "\n")) .. "\n")
-end
-
-function f.remove(self, section, value)
- return fs.writefile(input, "")
-end
-
-function s.handle(self, state, data)
- return true
-end
-
-return m
diff --git a/applications/luci-app-adblock/luasrc/view/adblock/adblock_css.htm b/applications/luci-app-adblock/luasrc/view/adblock/adblock_css.htm
deleted file mode 100644
index 5467c8763..000000000
--- a/applications/luci-app-adblock/luasrc/view/adblock/adblock_css.htm
+++ /dev/null
@@ -1,86 +0,0 @@
-<style type="text/css">
- textarea
- {
- width: 100% !important;
- height: 450px !important;
- border: 1px solid #cccccc;
- padding: 5px;
- font-size: 12px;
- font-family: monospace;
- resize: none;
- white-space: pre;
- overflow-wrap: normal;
- overflow-x: scroll;
- }
-
- select[readonly],
- textarea[readonly]
- {
- width: 100% !important;
- height: 450px !important;
- border: 1px solid #cccccc;
- padding: 5px;
- font-size: 12px;
- font-family: monospace;
- resize: none;
- pointer-events: auto;
- cursor: auto;
- }
-
- .table.cbi-section-table .th,
- .table.cbi-section-table .td,
- .cbi-section-table-cell,
- .cbi-section-table-row,
- .tr[data-title]::before
- {
- text-align: left !important;
- vertical-align: top;
- margin-left: 0px;
- padding-left: 2px;
- }
-
- .table.cbi-section-table .th
- {
- white-space: nowrap;
- }
-
- .cbi-section-table-row > .cbi-value-field .cbi-input-select,
- .table.cbi-section-table select
- {
- width: 70px;
- }
-
- .item,
- .add-item
- {
- white-space: nowrap;
- width: 8.2em;
- }
-
- .cbi-input-checkbox
- {
- height: 1em;
- }
-
- .cbi-button
- {
- -webkit-appearance: menulist;
- }
-
- .runtime
- {
- color: #37c;
- font-weight: bold;
- display: inline-block;
- width: 100%;
- padding-top: 0.5rem;
- }
-
- .button_running
- {
- display: inline-block;
- width: 16px;
- height: 16px;
- margin: 0 5px;
- }
-</style>
diff --git a/applications/luci-app-adblock/luasrc/view/adblock/blocklist.htm b/applications/luci-app-adblock/luasrc/view/adblock/blocklist.htm
deleted file mode 100644
index c90afe768..000000000
--- a/applications/luci-app-adblock/luasrc/view/adblock/blocklist.htm
+++ /dev/null
@@ -1,47 +0,0 @@
-<%#
-Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
-This is free software, licensed under the Apache License, Version 2.0
--%>
-
-<%-
-local anonclass = (not self.anonymous or self.sectiontitle) and "named" or "anonymous"
--%>
-
-<%+adblock/adblock_css%>
-
-<div class="cbi-section" id="cbi-<%=self.config%>-<%=self.sectiontype%>">
- <% if self.title then -%>
- <h3><%=self.title%></h3>
- <%- end %>
- <div class="cbi-section-descr"><%=self.description%></div>
- <div class="cbi-section-node">
- <div class="table cbi-section-table">
- <div class="tr cbi-section-table-titles <%=anonclass%>">
- <%- for i, k in pairs(self.children) do -%>
- <div class="th cbi-section-table-cell">
- <%-=k.title-%>
- </div>
- <%- end -%>
- </div>
- <%- local section, scope, isempty = true
- for i, k in ipairs(self:cfgsections()) do
- section = k
- local sectionname = striptags((type(self.sectiontitle) == "function") and self:sectiontitle(section) or k)
- local sectiontitle = ifattr(sectionname and (not self.anonymous or self.sectiontitle), "data-title", sectionname, true)
- isempty = false
- scope = { valueheader = "cbi/cell_valueheader", valuefooter = "cbi/cell_valuefooter" }
- -%>
- <div class="tr cbi-section-table-row" id="cbi-<%=self.config%>-<%=section%>"<%=sectiontitle%>>
- <%-
- for k, node in ipairs(self.children) do
- node:render(section, scope or {})
- end
- if not scope.cbid:match("adb_src_cat") then
- -%>
- <div class="td cbi-value-field">&#160;</div>
- <%- end -%>
- </div>
- <%- end -%>
- </div>
- </div>
-</div>
diff --git a/applications/luci-app-adblock/luasrc/view/adblock/logread.htm b/applications/luci-app-adblock/luasrc/view/adblock/logread.htm
deleted file mode 100644
index 48e367ec2..000000000
--- a/applications/luci-app-adblock/luasrc/view/adblock/logread.htm
+++ /dev/null
@@ -1,36 +0,0 @@
-<%#
-Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
-This is free software, licensed under the Apache License, Version 2.0
--%>
-
-<%+header%>
-<%+adblock/adblock_css%>
-
-<script type="text/javascript">
-//<![CDATA[
- function log_update()
- {
- XHR.poll(-1, '<%=luci.dispatcher.build_url("admin", "services", "adblock", "logread")%>', null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- var view = document.getElementById("view_id");
- view.value = x.responseText;
- view.scrollTop = view.scrollHeight;
- });
- }
- window.onload = log_update();
-//]]>
-</script>
-
-<div class="cbi-map">
- <div class="cbi-section">
- <div class="cbi-section-descr"><%:The syslog output, pre-filtered for adblock related messages only.%></div>
- <textarea id="view_id" readonly="readonly" wrap="off" value=""></textarea>
- </div>
-</div>
-
-<%+footer%>
diff --git a/applications/luci-app-adblock/luasrc/view/adblock/query.htm b/applications/luci-app-adblock/luasrc/view/adblock/query.htm
deleted file mode 100644
index fb659958d..000000000
--- a/applications/luci-app-adblock/luasrc/view/adblock/query.htm
+++ /dev/null
@@ -1,64 +0,0 @@
-<%#
-Copyright 2017-2018 Dirk Brenken (dev@brenken.org)
-This is free software, licensed under the Apache License, Version 2.0
--%>
-
-<%+header%>
-
-<script type="text/javascript">
-//<![CDATA[
- var stxhr = new XHR();
-
- function update_status(data)
- {
- var domain = data.value || data.placeholder;
- var input = document.getElementById('query_input');
- var output = document.getElementById('query_output');
-
- if (input && output)
- {
- output.innerHTML =
- '<img src="<%=resource%>/icons/loading.gif" alt="<%:Loading%>" style="vertical-align:middle" /> ' +
- '<%:Waiting for command to complete...%>'
- ;
- input.parentNode.style.display = 'block';
- input.style.display = 'inline';
- stxhr.post('<%=luci.dispatcher.build_url('admin/services/adblock/advanced/result/')%>' + domain, { token: '<%=token%>' },
- function(x)
- {
- if (x.responseText)
- {
- input.style.display = 'none';
- output.innerHTML = String.format('<pre>%h</pre>', x.responseText);
- }
- else
- {
- input.style.display = 'none';
- output.innerHTML = '<span class="error"><%:Blocklist not found!%></span>';
- }
- }
- );
- }
- }
-//]]>
-</script>
-
-<form method="post" action="<%=REQUEST_URI%>" onsubmit="update_status(this.input); return false;">
- <div class="cbi-map">
- <div class="cbi-section">
- <div class="cbi-section-descr"><%:This form allows you to query active block lists for certain domains, e.g. for whitelisting.%></div>
- <div style="width:33%; float:left;">
- <input type="text" placeholder="google.com" name="input" />
- <input type="button" value="<%:Query%>" class="cbi-button cbi-button-apply" onclick="update_status(this.form.input)" />
- </div>
- <br style="clear:both" />
- <br />
- </div>
- </div>
- <div class="cbi-section" style="display:none">
- <h3 id="query_input"><%:Collecting data...%></h3>
- <span id="query_output"></span>
- </div>
-</form>
-
-<%+footer%>
diff --git a/applications/luci-app-adblock/luasrc/view/adblock/report.htm b/applications/luci-app-adblock/luasrc/view/adblock/report.htm
deleted file mode 100644
index 814cc2fb2..000000000
--- a/applications/luci-app-adblock/luasrc/view/adblock/report.htm
+++ /dev/null
@@ -1,310 +0,0 @@
-<%#
-Copyright 2017-2019 Dirk Brenken (dev@brenken.org)
-This is free software, licensed under the Apache License, Version 2.0
--%>
-
-<%+header%>
-<%+adblock/adblock_css%>
-
-<script type="text/javascript">
-//<![CDATA[
- function report_json(json)
- {
- document.getElementById("value_1").innerHTML = json.data.start_date + ", " + json.data.start_time || "-";
- document.getElementById("value_2").innerHTML = json.data.end_date + ", " + json.data.end_time || "-";
- document.getElementById("value_3").innerHTML = json.data.total || "-";
- document.getElementById("value_4").innerHTML = json.data.blocked + " (" + json.data.percent + ")" || "-";
-
- var a_cnt;
- var b_cnt;
- var c_cnt;
- var a_val;
- var b_val;
- var c_val;
- var s = '<div class="tr table-titles">';
- s += '<div class="th left"><%:Count%></div>';
- s += '<div class="th left"><%:Name / IP-Address%></div>';
- s += '<div class="th left"><%:Count%></div>';
- s += '<div class="th left"><%:Domain%></div>';
- s += '<div class="th left"><%:Count%></div>';
- s += '<div class="th left"><%:Blocked Domain%></div></div>';
-
- for(var i=0;i<10;i++)
- {
- if (i < json.top_clients.length)
- {
- a_cnt = json.top_clients[i].count;
- a_val = json.top_clients[i].address;
- }
- else
- {
- a_cnt = "-";
- a_val = "";
- }
-
- if (i < json.top_domains.length)
- {
- b_cnt = json.top_domains[i].count;
- b_val = json.top_domains[i].address;
- }
- else
- {
- b_cnt = "-";
- b_val = "";
- }
-
- if (i < json.top_blocked.length)
- {
- c_cnt = json.top_blocked[i].count;
- c_val = json.top_blocked[i].address;
- }
- else
- {
- c_cnt = "-";
- c_val = "";
- }
-
- s += '<div class="tr left">';
- s += '<div class="td left" data-title="<%:Count%>">' + a_cnt + '</div>';
- s += '<div class="td left" data-title="<%:Name / IP-Address%>">' + a_val + '</div>';
- s += '<div class="td left" data-title="<%:Count%>">' + b_cnt + '</div>';
- s += '<div class="td left" data-title="<%:Domain%>">' + b_val + '</div>';
- s += '<div class="td left" data-title="<%:Count%>">' + c_cnt + '</div>';
- s += '<div class="td left" data-title="<%:Blocked Domain%>">' + c_val + '</div></div>';
- }
- document.getElementById("value_5").innerHTML = s;
- }
-
- function report_text(text)
- {
- var s = '<div class="tr table-titles">';
- s += '<div class="th left"><%:Date%></div>';
- s += '<div class="th left"><%:Time%></div>';
- s += '<div class="th left"><%:Client%></div>';
- s += '<div class="th left"><%:Domain%></div>';
- s += '<div class="th left"><%:Answer%></div>';
- s += '<div class="th left"><%:Action%></div></div>';
- var btn1;
- var record;
- var title_arr = ["<%:Date%>", "<%:Time%>", "<%:Client%>", "<%:Domain%>", "<%:Answer%>", "<%:Action%>"];
- var array = text.split("\n");
- for (var i=0;i<array.length;i++)
- {
- record = array[i].split("\t");
- if (record[0] && record[0] != "undefined")
- {
- s += '<div class="tr left">';
- for (var j=0;j<5;j++)
- {
- s += '<div class="td left" data-title="' + title_arr[j] + '">' + record[j] + '</div>';
- if (record[4] === "NX")
- {
- btn1 = '<div class="td left" data-title="' + title_arr[5] + '"><input type="button" class="cbi-button cbi-button-edit" name="add_whitelist,' + record[3] + '" value="<%:Whitelist%>" onclick="btn_action(this)" /></div>';
- }
- else if (record[4] === "OK")
- {
- btn1 = '<div class="td left" data-title="' + title_arr[5] + '"><input type="button" class="cbi-button cbi-button-remove" name="add_blacklist,' + record[3] + '" value="<%:Blacklist%>" onclick="btn_action(this)" /></div>';
- }
- else
- {
- btn1 = '-'
- }
- }
- s += btn1 + '</div>'
- }
- }
- document.getElementById("value_6").innerHTML = s;
- }
-
- function btn_action(value)
- {
- var action = value.name.split(",");
-
- if (action[0] === "do_report")
- {
- var btn1 = document.getElementById("btn1");
- var btn1_running = document.getElementById("btn1_running");
-
- btn1.disabled = true;
- running(btn1_running, 1);
-
- document.getElementById("filter_search").value = '';
- document.getElementById("filter_count").selectedIndex = 1;
-
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action[0], null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_json")%>', null,
- function(x, json_info)
- {
- if (!x || !json_info || !json_info.data)
- {
- running(btn1_running, 0);
- btn1.disabled = false;
- return;
- }
- report_json(json_info);
- });
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_text")%>', null,
- function(x)
- {
- if (!x || !x.responseText)
- {
- return;
- }
- report_text(x.responseText);
- running(btn1_running, 0);
- btn1.disabled = false;
- });
- });
- }
- else if (action[0] === "do_filter")
- {
- var btn2 = document.getElementById("btn2");
- var btn2_running = document.getElementById("btn2_running");
- var search = document.getElementById("filter_search").value.replace(/[^\x00-\x7F]|[\s!@#$%^&*()+=\[\]{};'"\\|,<>\/?]/g,'') || "\"+\"";
- var count = document.getElementById("filter_count").value;
-
- btn2.disabled = true;
- running(btn2_running, 1);
- if (search != "\"+\"")
- {
- document.getElementById("filter_search").value = search;
- }
-
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action[0] + "/" + "-" + "/" + search + "/" + count + "/" + "true" + "/" + "false", null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_text")%>', null,
- function(x)
- {
- if (!x || !x.responseText)
- {
- return;
- }
- report_text(x.responseText);
- running(btn2_running, 0);
- btn2.disabled = false;
- });
- });
- }
- else if (action[0] === "add_blacklist" || action[0] === "add_whitelist")
- {
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action[0] + "/" + action[1], null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- btn3 = document.getElementsByName(value.name);
- for (var i=0; i<btn3.length; i++)
- {
- btn3[i].disabled = true;
- }
- });
- }
- }
-
- function running(element, state)
- {
- if (state === 1)
- {
- var running_html = '<img src="<%=resource%>/icons/loading.gif" alt="<%:Loading%>" width="16" height="16" style="vertical-align:middle" />';
- element.innerHTML = running_html;
- }
- else
- {
- element.innerHTML = '';
- }
- }
-
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_json")%>', null,
- function(x, json_info)
- {
- if (!x || !json_info || !json_info.data)
- {
- running(btn1_running, 0);
- btn1.disabled = false;
- return;
- }
- report_json(json_info);
- });
-
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "report_text")%>', null,
- function(x)
- {
- if (!x || !x.responseText)
- {
- return;
- }
- report_text(x.responseText);
- });
-//]]>
-</script>
-
-<div class="cbi-section">
- <div class="cbi-value" id="status_1">
- <label class="cbi-value-title" for="status_1"><%:Start Date%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_1">-</span>
- </div>
- </div>
- <div class="cbi-value" id="status_2">
- <label class="cbi-value-title" for="status_2"><%:End Date%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_2">-</span>
- </div>
- </div>
- <div class="cbi-value" id="status_3">
- <label class="cbi-value-title" for="status_3"><%:Total DNS Queries%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_3">-</span>
- </div>
- </div>
- <div class="cbi-value" id="status_4">
- <label class="cbi-value-title" for="status_4"><%:Blocked DNS Queries%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_4">-</span>
- </div>
- </div>
- <br />
- <div id="button">
- <input type="button" class="cbi-button cbi-button-action important" id="btn1" name="do_report" value="<%:Refresh Report%>" onclick="btn_action(this)" />
- <span id="btn1_running" class="btn1_running"></span>
- </div>
-</div>
-<br />
-<div class="cbi-section">
- <h3><%:Top 10 Reporting%></h3>
- <div class="table" id="value_5"></div>
-</div>
-<hr />
-<div class="cbi-section">
- <div class="cbi-section-descr"><%:Filter the DNS Query result set for a particular domain, client or time frame.%></div>
- <div style="float:left;">
- <input type="text" placeholder="<%:Domain/Client/Date/Time%>" id="filter_search" name="filter_search" />
- <select name="filter_count" id="filter_count">
- <option value="25">25</option>
- <option value="50" selected="selected">50</option>
- <option value="100">100</option>
- <option value="250">250</option>
- <option value="500">500</option>
- </select>
- <input type="button" class="cbi-button cbi-button-action" id="btn2" name="do_filter" value="<%:Filter%>" onclick="btn_action(this)" />
- <span id="btn2_running" class="btn2_running"></span>
- </div>
- <br />
- <br />
- <h3><%:Latest DNS Queries%></h3>
- <div class="table" id="value_6"></div>
-</div>
-<%+footer%>
diff --git a/applications/luci-app-adblock/luasrc/view/adblock/runtime.htm b/applications/luci-app-adblock/luasrc/view/adblock/runtime.htm
deleted file mode 100644
index 2cec57334..000000000
--- a/applications/luci-app-adblock/luasrc/view/adblock/runtime.htm
+++ /dev/null
@@ -1,213 +0,0 @@
-<%#
-Copyright 2017-2019 Dirk Brenken (dev@brenken.org)
-This is free software, licensed under the Apache License, Version 2.0
--%>
-
-<%+adblock/adblock_css%>
-<script type="text/javascript">
-//<![CDATA[
- function format(number)
- {
- var string = number.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1.');
- return string;
- }
-
- function status_update(json)
- {
- var btn1 = document.getElementById("btn1");
- var btn1_running = document.getElementById("btn1_running");
- var btn2 = document.getElementById("btn2");
- var btn2_running = document.getElementById("btn2_running");
- var input = json.data.adblock_status || "-";
-
- document.getElementById("value_1").innerHTML = input;
- if (input === "enabled")
- {
- btn1.value = "<%:Suspend%>";
- btn1.name = "do_suspend";
- btn2.value = "<%:Refresh%>";
- btn2.name = "do_refresh";
- btn1.disabled = false;
- running(btn1_running, 0);
- btn2.disabled = false;
- running(btn2_running, 0);
- }
- else if (input === "paused")
- {
- btn1.value = "<%:Resume%>";
- btn1.name = "do_resume";
- btn2.value = "<%:Refresh%>";
- btn2.name = "do_refresh";
- btn1.disabled = false;
- running(btn1_running, 0);
- btn2.disabled = false;
- running(btn2_running, 0);
- }
- else
- {
- btn1.value = "<%:Suspend%>";
- btn1.name = "do_suspend";
- btn2.value = "<%:Refresh%>";
- btn2.name = "do_refresh";
- btn1.disabled = true;
- btn2.disabled = true;
- }
-
- document.getElementById("value_2").innerHTML = json.data.adblock_version || "-";
- document.getElementById("value_3").innerHTML = json.data.fetch_utility || "-";
- document.getElementById("value_4").innerHTML = json.data.dns_backend || "-";
- document.getElementById("value_5").innerHTML = json.data.dns_variant || "-";
- document.getElementById("value_6").innerHTML = json.data.backup_dir || "-";
- document.getElementById("value_7").innerHTML = format(json.data.overall_domains) || "-";
- document.getElementById("value_8").innerHTML = json.data.last_rundate || "-";
- }
-
- function btn_action(action)
- {
- var btn1 = document.getElementById("btn1");
- var btn1_running = document.getElementById("btn1_running");
- var btn2 = document.getElementById("btn2");
- var btn2_running = document.getElementById("btn2_running");
-
- btn1.disabled = true;
- btn2.disabled = true;
-
- if (action.name === "do_refresh")
- {
- running(btn2_running, 1);
- }
- else
- {
- running(btn1_running, 1);
- }
-
- new XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock")%>/action/' + action.name, null,
- function(x)
- {
- if (!x)
- {
- return;
- }
- });
- }
-
- function running(element, state)
- {
- if (state === 1)
- {
- var running_html = '<img src="<%=resource%>/icons/loading.gif" alt="<%:Loading%>" width="16" height="16" style="vertical-align:middle" />';
- element.innerHTML = running_html;
- }
- else
- {
- element.innerHTML = '';
- }
- }
-
- function reset_view()
- {
- document.getElementById("btn1").value = "<%:Suspend%>";
- document.getElementById("btn1").name = "do_suspend";
- document.getElementById("btn2").value = "<%:Refresh%>";
- document.getElementById("btn2").name = "do_refresh";
- document.getElementById("btn1").disabled = true;
- document.getElementById("btn2").disabled = true;
- document.getElementById("value_1").innerHTML = "-";
- document.getElementById("value_2").innerHTML = "-";
- document.getElementById("value_3").innerHTML = "-";
- document.getElementById("value_4").innerHTML = "-";
- document.getElementById("value_5").innerHTML = "-";
- document.getElementById("value_6").innerHTML = "-";
- document.getElementById("value_7").innerHTML = "-";
- document.getElementById("value_8").innerHTML = "-";
- }
-
- XHR.get('<%=luci.dispatcher.build_url("admin", "services", "adblock", "status_update")%>', null,
- function(x, json_info)
- {
- if (!x || !json_info || !json_info.data)
- {
- reset_view();
- return;
- }
- status_update(json_info);
- });
-
- XHR.poll(-1, '<%=luci.dispatcher.build_url("admin", "services", "adblock", "status_update")%>', null,
- function(x, json_info)
- {
- if (!x || !json_info || !json_info.data)
- {
- reset_view();
- return;
- }
- status_update(json_info);
- });
-//]]>
-</script>
-
-<h3><%:Runtime Information%></h3>
-<div class="cbi-value" id="status_1">
- <label class="cbi-value-title" for="status_1"><%:Adblock Status%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_1">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_2">
- <label class="cbi-value-title" for="status_2"><%:Adblock Version%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_2">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_3">
- <label class="cbi-value-title" for="status_3"><%:Download Utility (SSL Library)%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_3">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_4">
- <label class="cbi-value-title" for="status_4"><%:DNS Backend, DNS Directory%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_4">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_5">
- <label class="cbi-value-title" for="status_5"><%:DNS Variant, DNS File Reset%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_5">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_6">
- <label class="cbi-value-title" for="status_6"><%:Backup Directory%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_6">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_7">
- <label class="cbi-value-title" for="status_7"><%:Overall Domains%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_7">-</span>
- </div>
-</div>
-<div class="cbi-value" id="status_8">
- <label class="cbi-value-title" for="status_8"><%:Last Run%></label>
- <div class="cbi-value-field">
- <span class="runtime" id="value_8">-</span>
- </div>
-</div>
-<hr />
-<div class="cbi-value" id="button_1">
- <label class="cbi-value-title" for="button_1"><%:Suspend / Resume Adblock%></label>
- <div class="cbi-value-field">
- <input class="cbi-button cbi-button-reset" id="btn1" type="button" value="" onclick="btn_action(this)" />
- <span id="btn1_running" class="btn_running"></span>
- </div>
-</div>
-<p />
-<div class="cbi-value" id="button_2">
- <label class="cbi-value-title" for="button_2"><%:Refresh Blocklist Sources%></label>
- <div class="cbi-value-field">
- <input class="cbi-button cbi-button-apply" id="btn2" type="button" value="" onclick="btn_action(this)" />
- <span id="btn2_running" class="btn_running"></span>
- </div>
-</div>