Merge pull request #3328 from ysc3839/nextdns
luci-app-nextdns: port to client side
This commit is contained in:
commit
15816e668d
7 changed files with 124 additions and 128 deletions
applications/luci-app-nextdns
htdocs/luci-static/resources/view/nextdns
luasrc
po/templates
root/usr/share/rpcd/acl.d
|
@ -0,0 +1,43 @@
|
||||||
|
'use strict';
|
||||||
|
'require fs';
|
||||||
|
|
||||||
|
return L.view.extend({
|
||||||
|
render: function() {
|
||||||
|
L.Poll.add(function() {
|
||||||
|
return L.resolveDefault(fs.exec('/sbin/logread', ['-e', 'nextdns']), { code: 1 })
|
||||||
|
.then(function(res) {
|
||||||
|
var content;
|
||||||
|
if (res.code === 0)
|
||||||
|
content = res.stdout.trim();
|
||||||
|
if (!content)
|
||||||
|
content = _('No nextdns related logs yet!');
|
||||||
|
var view = document.getElementById("view_id");
|
||||||
|
view.value = content;
|
||||||
|
view.scrollTop = view.scrollHeight;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return E('div', { class: 'cbi-map' },
|
||||||
|
E('div', { class: 'cbi-section' }, [
|
||||||
|
E('div', { class: 'cbi-section-descr' },
|
||||||
|
_('The syslog output, pre-filtered for nextdns related messages only.')),
|
||||||
|
E('textarea', {
|
||||||
|
id: 'view_id',
|
||||||
|
readonly: 'readonly',
|
||||||
|
wrap: 'off',
|
||||||
|
style: '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;'
|
||||||
|
})
|
||||||
|
])
|
||||||
|
);
|
||||||
|
},
|
||||||
|
handleSaveApply: null,
|
||||||
|
handleSave: null,
|
||||||
|
handleReset: null
|
||||||
|
});
|
|
@ -0,0 +1,44 @@
|
||||||
|
'use strict';
|
||||||
|
'require form';
|
||||||
|
|
||||||
|
return L.view.extend({
|
||||||
|
render: function() {
|
||||||
|
var m, s, o;
|
||||||
|
|
||||||
|
m = new form.Map('nextdns', _('NextDNS'),
|
||||||
|
_('NextDNS Configuration.')
|
||||||
|
+ '<br>'
|
||||||
|
+ _('For further information, go to \
|
||||||
|
<a href="https://nextdns.io" target="_blank">nextdns.io</a>.'));
|
||||||
|
|
||||||
|
s = m.section(form.TypedSection, 'nextdns', _('General'));
|
||||||
|
s.anonymous = true;
|
||||||
|
|
||||||
|
o = s.option(form.Flag, 'enabled', _('Enabled'),
|
||||||
|
_('Enable NextDNS.'));
|
||||||
|
o.default = '1';
|
||||||
|
o.rmempty = false;
|
||||||
|
|
||||||
|
s.option(form.Value, 'config', _('Configuration ID'),
|
||||||
|
_('The ID of your NextDNS configuration.')
|
||||||
|
+ '<br>'
|
||||||
|
+ _('Go to nextdns.io to create a configuration.'));
|
||||||
|
|
||||||
|
o = s.option(form.Flag, 'report_client_info', _('Report Client Info'),
|
||||||
|
_('Expose LAN clients information in NextDNS analytics.'));
|
||||||
|
o.default = '1';
|
||||||
|
o.rmempty = false;
|
||||||
|
|
||||||
|
o = s.option(form.Flag, 'hardened_privacy', _('Hardened Privacy'),
|
||||||
|
_('When enabled, use DNS servers located in jurisdictions with strong privacy laws.')
|
||||||
|
+ '<br>'
|
||||||
|
+ _('Available locations are: Switzerland, Iceland, Finland, Panama and Hong Kong.'));
|
||||||
|
o.rmempty = false;
|
||||||
|
|
||||||
|
o = s.option(form.Flag, 'log_queries', _('Log Queries'),
|
||||||
|
_('Log individual queries to system log.'));
|
||||||
|
o.rmempty = false;
|
||||||
|
|
||||||
|
return m.render();
|
||||||
|
},
|
||||||
|
});
|
|
@ -3,30 +3,12 @@
|
||||||
|
|
||||||
module("luci.controller.nextdns", package.seeall)
|
module("luci.controller.nextdns", package.seeall)
|
||||||
|
|
||||||
local util = require("luci.util")
|
|
||||||
local i18n = require("luci.i18n")
|
|
||||||
local templ = require("luci.template")
|
|
||||||
local http = require("luci.http")
|
|
||||||
|
|
||||||
function index()
|
function index()
|
||||||
if not nixio.fs.access("/etc/config/nextdns") then
|
if not nixio.fs.access("/etc/config/nextdns") then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
entry({"admin", "services", "nextdns"}, firstchild(), _("NextDNS"), 60).dependent = false
|
entry({"admin", "services", "nextdns"}, firstchild(), _("NextDNS"), 60).dependent = false
|
||||||
entry({"admin", "services", "nextdns", "overview"}, cbi("overview", {hideresetbtn=true, hidesavebtn=true}), _("Overview"), 10).leaf = true
|
entry({"admin", "services", "nextdns", "overview"}, view("nextdns/overview"), _("Overview"), 10).leaf = true
|
||||||
entry({"admin", "services", "nextdns", "log"}, template("nextdns/logread"), _("Logs"), 30).leaf = true
|
entry({"admin", "services", "nextdns", "log"}, view("nextdns/logread"), _("Logs"), 30).leaf = true
|
||||||
|
|
||||||
entry({"admin", "services", "nextdns", "logread"}, call("logread"), nil).leaf = true
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function logread()
|
|
||||||
local content = util.trim(util.exec("logread -e 'nextdns'")) or ""
|
|
||||||
|
|
||||||
if content == "" then
|
|
||||||
content = "No nextdns related logs yet!"
|
|
||||||
end
|
|
||||||
http.write(content)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
|
@ -1,41 +0,0 @@
|
||||||
local uci = require("luci.model.uci").cursor()
|
|
||||||
|
|
||||||
nextdns = Map("nextdns", translate("NextDNS"),
|
|
||||||
translate("NextDNS Configuration.")
|
|
||||||
.. "<br>"
|
|
||||||
.. translatef("For further information, go to "
|
|
||||||
.. "<a href=\"https://nextdns.io\" target=\"_blank\">nextdns.io</a>"))
|
|
||||||
|
|
||||||
|
|
||||||
function nextdns.on_after_commit(self)
|
|
||||||
luci.sys.call("env -i /etc/init.d/nextdns restart >/dev/null 2>&1")
|
|
||||||
end
|
|
||||||
|
|
||||||
s = nextdns:section(TypedSection, "nextdns", translate("General"))
|
|
||||||
s.anonymous = true
|
|
||||||
|
|
||||||
enabled = s:option(Flag, "enabled", translate("Enabled"),
|
|
||||||
translate("Enable NextDNS."))
|
|
||||||
enabled.rmempty = false
|
|
||||||
|
|
||||||
conf = s:option(Value, "config", translate("Configuration ID"),
|
|
||||||
translate("The ID of your NextDNS configuration.")
|
|
||||||
.. "<br>"
|
|
||||||
.. translate("Go to nextdns.io to create a configuration."))
|
|
||||||
conf.rmempty = false
|
|
||||||
|
|
||||||
report_client_info = s:option(Flag, "report_client_info", translate("Report Client Info"),
|
|
||||||
translate("Expose LAN clients information in NextDNS analytics."))
|
|
||||||
report_client_info.rmempty = false
|
|
||||||
|
|
||||||
hardened_privacy = s:option(Flag, "hardened_privacy", translate("Hardened Privacy"),
|
|
||||||
translate("When enabled, use DNS servers located in jurisdictions with strong privacy laws.")
|
|
||||||
.. "<br>"
|
|
||||||
.. translate("Available locations are: Switzerland, Iceland, Finland, Panama and Hong Kong."))
|
|
||||||
hardened_privacy.rmempty = false
|
|
||||||
|
|
||||||
log_query = s:option(Flag, "log_query", translate("Log Queries"),
|
|
||||||
translate("Log individual queries to system log."))
|
|
||||||
log_query.rmempty = false
|
|
||||||
|
|
||||||
return nextdns
|
|
|
@ -1,46 +0,0 @@
|
||||||
<%+header%>
|
|
||||||
|
|
||||||
<style type="text/css">
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
|
||||||
//<![CDATA[
|
|
||||||
function log_update()
|
|
||||||
{
|
|
||||||
XHR.poll(-1, '<%=luci.dispatcher.build_url("admin", "services", "nextdns", "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 nextdns related messages only.%></div>
|
|
||||||
<textarea id="view_id" readonly="readonly" wrap="off" value=""></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<%+footer%>
|
|
|
@ -1,83 +1,87 @@
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr "Content-Type: text/plain; charset=UTF-8"
|
msgstr "Content-Type: text/plain; charset=UTF-8"
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:34
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:35
|
||||||
msgid ""
|
msgid ""
|
||||||
"Available locations are: Switzerland, Iceland, Finland, Panama and Hong Kong."
|
"Available locations are: Switzerland, Iceland, Finland, Panama and Hong Kong."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:21
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:22
|
||||||
msgid "Configuration ID"
|
msgid "Configuration ID"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:18
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:18
|
||||||
msgid "Enable NextDNS."
|
msgid "Enable NextDNS."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:17
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:17
|
||||||
msgid "Enabled"
|
msgid "Enabled"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:28
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:28
|
||||||
msgid "Expose LAN clients information in NextDNS analytics."
|
msgid "Expose LAN clients information in NextDNS analytics."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:6
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:11
|
||||||
msgid ""
|
msgid ""
|
||||||
"For further information, go to <a href=\"https://nextdns.io\" target=\"_blank"
|
"For further information, go to <a href=\"https://nextdns.io\" target=\"_blank"
|
||||||
"\">nextdns.io</a>"
|
"\">nextdns.io</a>."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:14
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:14
|
||||||
msgid "General"
|
msgid "General"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:24
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:25
|
||||||
msgid "Go to nextdns.io to create a configuration."
|
msgid "Go to nextdns.io to create a configuration."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:31
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:32
|
||||||
msgid "Hardened Privacy"
|
msgid "Hardened Privacy"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:37
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:38
|
||||||
msgid "Log Queries"
|
msgid "Log Queries"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:38
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:39
|
||||||
msgid "Log individual queries to system log."
|
msgid "Log individual queries to system log."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:18
|
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:13
|
||||||
msgid "Logs"
|
msgid "Logs"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:16
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:8
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:3
|
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:11
|
||||||
msgid "NextDNS"
|
msgid "NextDNS"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:4
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:9
|
||||||
msgid "NextDNS Configuration."
|
msgid "NextDNS Configuration."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:17
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/logread.js:13
|
||||||
|
msgid "No nextdns related logs yet!"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:12
|
||||||
msgid "Overview"
|
msgid "Overview"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:27
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:27
|
||||||
msgid "Report Client Info"
|
msgid "Report Client Info"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:22
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:23
|
||||||
msgid "The ID of your NextDNS configuration."
|
msgid "The ID of your NextDNS configuration."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/view/nextdns/logread.htm:41
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/logread.js:22
|
||||||
msgid "The syslog output, pre-filtered for nextdns related messages only."
|
msgid "The syslog output, pre-filtered for nextdns related messages only."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:32
|
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:33
|
||||||
msgid ""
|
msgid ""
|
||||||
"When enabled, use DNS servers located in jurisdictions with strong privacy "
|
"When enabled, use DNS servers located in jurisdictions with strong privacy "
|
||||||
"laws."
|
"laws."
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
"luci-app-nextdns": {
|
||||||
|
"description": "Grant logread access to LuCI app nextdns",
|
||||||
|
"read": {
|
||||||
|
"file": {
|
||||||
|
"/sbin/logread": [ "exec" ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue