Merge pull request #3328 from ysc3839/nextdns

luci-app-nextdns: port to client side
This commit is contained in:
Jo-Philipp Wich 2019-11-19 12:04:07 +01:00 committed by GitHub
commit 15816e668d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 124 additions and 128 deletions

View file

@ -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
});

View file

@ -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();
},
});

View file

@ -3,30 +3,12 @@
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()
if not nixio.fs.access("/etc/config/nextdns") then
return
end
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", "log"}, template("nextdns/logread"), _("Logs"), 30).leaf = true
entry({"admin", "services", "nextdns", "logread"}, call("logread"), nil).leaf = true
entry({"admin", "services", "nextdns", "overview"}, view("nextdns/overview"), _("Overview"), 10).leaf = true
entry({"admin", "services", "nextdns", "log"}, view("nextdns/logread"), _("Logs"), 30).leaf = true
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

View file

@ -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

View file

@ -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%>

View file

@ -1,83 +1,87 @@
msgid ""
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 ""
"Available locations are: Switzerland, Iceland, Finland, Panama and Hong Kong."
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"
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."
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"
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."
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 ""
"For further information, go to <a href=\"https://nextdns.io\" target=\"_blank"
"\">nextdns.io</a>"
"\">nextdns.io</a>."
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"
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."
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"
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"
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."
msgstr ""
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:18
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:13
msgid "Logs"
msgstr ""
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:16
#: applications/luci-app-nextdns/luasrc/model/cbi/overview.lua:3
#: applications/luci-app-nextdns/htdocs/luci-static/resources/view/nextdns/overview.js:8
#: applications/luci-app-nextdns/luasrc/controller/nextdns.lua:11
msgid "NextDNS"
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."
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"
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"
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."
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."
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 ""
"When enabled, use DNS servers located in jurisdictions with strong privacy "
"laws."

View file

@ -0,0 +1,10 @@
{
"luci-app-nextdns": {
"description": "Grant logread access to LuCI app nextdns",
"read": {
"file": {
"/sbin/logread": [ "exec" ]
}
}
}
}