Merge pull request #534 from yousong/add-luci-proto-pppossh
Add luci proto pppossh
This commit is contained in:
commit
c123fa86b0
5 changed files with 150 additions and 11 deletions
|
@ -545,7 +545,7 @@ function cbi_browser_init(id, respath, url, defpath)
|
||||||
cbi_bind(btn, 'click', cbi_browser_btnclick);
|
cbi_bind(btn, 'click', cbi_browser_btnclick);
|
||||||
}
|
}
|
||||||
|
|
||||||
function cbi_dynlist_init(name, respath, datatype, optional, choices)
|
function cbi_dynlist_init(name, respath, datatype, optional, url, defpath, choices)
|
||||||
{
|
{
|
||||||
var input0 = document.getElementsByName(name)[0];
|
var input0 = document.getElementsByName(name)[0];
|
||||||
var prefix = input0.name;
|
var prefix = input0.name;
|
||||||
|
@ -606,6 +606,11 @@ function cbi_dynlist_init(name, respath, datatype, optional, choices)
|
||||||
|
|
||||||
parent.appendChild(t);
|
parent.appendChild(t);
|
||||||
parent.appendChild(b);
|
parent.appendChild(b);
|
||||||
|
if (datatype == 'file')
|
||||||
|
{
|
||||||
|
cbi_browser_init(t.id, respath, url, defpath);
|
||||||
|
}
|
||||||
|
|
||||||
parent.appendChild(document.createElement('br'));
|
parent.appendChild(document.createElement('br'));
|
||||||
|
|
||||||
if (datatype)
|
if (datatype)
|
||||||
|
@ -616,13 +621,13 @@ function cbi_dynlist_init(name, respath, datatype, optional, choices)
|
||||||
if (choices)
|
if (choices)
|
||||||
{
|
{
|
||||||
cbi_combobox_init(t.id, choices[0], '', choices[1]);
|
cbi_combobox_init(t.id, choices[0], '', choices[1]);
|
||||||
t.nextSibling.index = i;
|
b.index = i;
|
||||||
|
|
||||||
cbi_bind(t.nextSibling, 'keydown', cbi_dynlist_keydown);
|
cbi_bind(b, 'keydown', cbi_dynlist_keydown);
|
||||||
cbi_bind(t.nextSibling, 'keypress', cbi_dynlist_keypress);
|
cbi_bind(b, 'keypress', cbi_dynlist_keypress);
|
||||||
|
|
||||||
if (i == focus || -i == focus)
|
if (i == focus || -i == focus)
|
||||||
t.nextSibling.focus();
|
b.focus();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -758,20 +763,24 @@ function cbi_dynlist_init(name, respath, datatype, optional, choices)
|
||||||
ev = ev ? ev : window.event;
|
ev = ev ? ev : window.event;
|
||||||
|
|
||||||
var se = ev.target ? ev.target : ev.srcElement;
|
var se = ev.target ? ev.target : ev.srcElement;
|
||||||
|
var input = se.previousSibling;
|
||||||
|
while (input && input.name != name) {
|
||||||
|
input = input.previousSibling;
|
||||||
|
}
|
||||||
|
|
||||||
if (se.src.indexOf('remove') > -1)
|
if (se.src.indexOf('remove') > -1)
|
||||||
{
|
{
|
||||||
se.previousSibling.value = '';
|
input.value = '';
|
||||||
|
|
||||||
cbi_dynlist_keydown({
|
cbi_dynlist_keydown({
|
||||||
target: se.previousSibling,
|
target: input,
|
||||||
keyCode: 8
|
keyCode: 8
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cbi_dynlist_keydown({
|
cbi_dynlist_keydown({
|
||||||
target: se.previousSibling,
|
target: input,
|
||||||
keyCode: 13
|
keyCode: 13
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,7 +72,7 @@ function urlencode( str )
|
||||||
|
|
||||||
if type(str) == "string" then
|
if type(str) == "string" then
|
||||||
str = str:gsub(
|
str = str:gsub(
|
||||||
"([^a-zA-Z0-9$_%-%.!*'(),])",
|
"([^a-zA-Z0-9$_%-%.%~])",
|
||||||
__chrenc
|
__chrenc
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
|
@ -15,7 +15,9 @@
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
cbi_dynlist_init(
|
cbi_dynlist_init(
|
||||||
'<%=cbid%>', '<%=resource%>', '<%=self.datatype%>',
|
'<%=cbid%>', '<%=resource%>', '<%=self.datatype%>',
|
||||||
<%=tostring(self.optional or self.rmempty)%>
|
<%=tostring(self.optional or self.rmempty)%>,
|
||||||
|
'<%=url('admin/filebrowser')%>',
|
||||||
|
'<%=self.default_path and self.default_path%>'
|
||||||
<%- if #self.keylist > 0 then -%>, [{
|
<%- if #self.keylist > 0 then -%>, [{
|
||||||
<%- for i, k in ipairs(self.keylist) do -%>
|
<%- for i, k in ipairs(self.keylist) do -%>
|
||||||
<%-=string.format("%q", k) .. ":" .. string.format("%q", self.vallist[i])-%>
|
<%-=string.format("%q", k) .. ":" .. string.format("%q", self.vallist[i])-%>
|
||||||
|
|
|
@ -0,0 +1,122 @@
|
||||||
|
-- Copyright (C) 2015 Yousong Zhou <yszhou4tech@gmail.com>
|
||||||
|
-- Licensed to the public under the Apache License 2.0.
|
||||||
|
|
||||||
|
local map, section, net = ...
|
||||||
|
|
||||||
|
local sshuser, server, port, ssh_options, identity, ipaddr, peeraddr
|
||||||
|
|
||||||
|
sshuser = section:taboption("general", Value, "sshuser", translate("SSH username"))
|
||||||
|
|
||||||
|
server = section:taboption("general", Value, "server", translate("SSH server address"))
|
||||||
|
server.datatype = "host"
|
||||||
|
|
||||||
|
port = section:taboption("general", Value, "port", translate("SSH server port"))
|
||||||
|
port.datatype = "port"
|
||||||
|
port.optional = true
|
||||||
|
port.default = 22
|
||||||
|
|
||||||
|
ssh_options = section:taboption("general", Value, "ssh_options", translate("Extra SSH command options"))
|
||||||
|
ssh_options.optional = true
|
||||||
|
|
||||||
|
identity = section:taboption("general", DynamicList, "identity", translate("List of SSH key files for auth"))
|
||||||
|
identity.optional = true
|
||||||
|
identity.datatype = "file"
|
||||||
|
|
||||||
|
ipaddr = section:taboption("general", Value, "ipaddr", translate("Local IP address to assign"))
|
||||||
|
ipaddr.datatype = "ipaddr"
|
||||||
|
|
||||||
|
peeraddr = section:taboption("general", Value, "peeraddr", translate("Peer IP address to assign"))
|
||||||
|
peeraddr.datatype = "ipaddr"
|
||||||
|
|
||||||
|
|
||||||
|
local ipv6, defaultroute, metric, peerdns, dns,
|
||||||
|
keepalive_failure, keepalive_interval, demand
|
||||||
|
|
||||||
|
if luci.model.network:has_ipv6() then
|
||||||
|
ipv6 = section:taboption("advanced", Flag, "ipv6",
|
||||||
|
translate("Enable IPv6 negotiation on the PPP link"))
|
||||||
|
ipv6.default = ipv6.disabled
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
defaultroute = section:taboption("advanced", Flag, "defaultroute",
|
||||||
|
translate("Use default gateway"),
|
||||||
|
translate("If unchecked, no default route is configured"))
|
||||||
|
|
||||||
|
defaultroute.default = defaultroute.enabled
|
||||||
|
|
||||||
|
|
||||||
|
metric = section:taboption("advanced", Value, "metric",
|
||||||
|
translate("Use gateway metric"))
|
||||||
|
|
||||||
|
metric.placeholder = "0"
|
||||||
|
metric.datatype = "uinteger"
|
||||||
|
metric:depends("defaultroute", defaultroute.enabled)
|
||||||
|
|
||||||
|
|
||||||
|
peerdns = section:taboption("advanced", Flag, "peerdns",
|
||||||
|
translate("Use DNS servers advertised by peer"),
|
||||||
|
translate("If unchecked, the advertised DNS server addresses are ignored"))
|
||||||
|
|
||||||
|
peerdns.default = peerdns.enabled
|
||||||
|
|
||||||
|
|
||||||
|
dns = section:taboption("advanced", DynamicList, "dns",
|
||||||
|
translate("Use custom DNS servers"))
|
||||||
|
|
||||||
|
dns:depends("peerdns", "")
|
||||||
|
dns.datatype = "ipaddr"
|
||||||
|
dns.cast = "string"
|
||||||
|
|
||||||
|
|
||||||
|
keepalive_failure = section:taboption("advanced", Value, "_keepalive_failure",
|
||||||
|
translate("LCP echo failure threshold"),
|
||||||
|
translate("Presume peer to be dead after given amount of LCP echo failures, use 0 to ignore failures"))
|
||||||
|
|
||||||
|
function keepalive_failure.cfgvalue(self, section)
|
||||||
|
local v = m:get(section, "keepalive")
|
||||||
|
if v and #v > 0 then
|
||||||
|
return tonumber(v:match("^(%d+)[ ,]+%d+") or v)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function keepalive_failure.write() end
|
||||||
|
function keepalive_failure.remove() end
|
||||||
|
|
||||||
|
keepalive_failure.placeholder = "0"
|
||||||
|
keepalive_failure.datatype = "uinteger"
|
||||||
|
|
||||||
|
|
||||||
|
keepalive_interval = section:taboption("advanced", Value, "_keepalive_interval",
|
||||||
|
translate("LCP echo interval"),
|
||||||
|
translate("Send LCP echo requests at the given interval in seconds, only effective in conjunction with failure threshold"))
|
||||||
|
|
||||||
|
function keepalive_interval.cfgvalue(self, section)
|
||||||
|
local v = m:get(section, "keepalive")
|
||||||
|
if v and #v > 0 then
|
||||||
|
return tonumber(v:match("^%d+[ ,]+(%d+)"))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function keepalive_interval.write(self, section, value)
|
||||||
|
local f = tonumber(keepalive_failure:formvalue(section)) or 0
|
||||||
|
local i = tonumber(value) or 5
|
||||||
|
if i < 1 then i = 1 end
|
||||||
|
if f > 0 then
|
||||||
|
m:set(section, "keepalive", "%d %d" %{ f, i })
|
||||||
|
else
|
||||||
|
m:del(section, "keepalive")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
keepalive_interval.remove = keepalive_interval.write
|
||||||
|
keepalive_interval.placeholder = "5"
|
||||||
|
keepalive_interval.datatype = "min(1)"
|
||||||
|
|
||||||
|
|
||||||
|
demand = section:taboption("advanced", Value, "demand",
|
||||||
|
translate("Inactivity timeout"),
|
||||||
|
translate("Close inactive connection after the given amount of seconds, use 0 to persist connection"))
|
||||||
|
|
||||||
|
demand.placeholder = "0"
|
||||||
|
demand.datatype = "uinteger"
|
|
@ -4,7 +4,7 @@
|
||||||
local netmod = luci.model.network
|
local netmod = luci.model.network
|
||||||
|
|
||||||
local _, p
|
local _, p
|
||||||
for _, p in ipairs({"ppp", "pptp", "pppoe", "pppoa", "3g", "l2tp"}) do
|
for _, p in ipairs({"ppp", "pptp", "pppoe", "pppoa", "3g", "l2tp", "pppossh"}) do
|
||||||
|
|
||||||
local proto = netmod:register_protocol(p)
|
local proto = netmod:register_protocol(p)
|
||||||
|
|
||||||
|
@ -21,6 +21,8 @@ for _, p in ipairs({"ppp", "pptp", "pppoe", "pppoa", "3g", "l2tp"}) do
|
||||||
return luci.i18n.translate("PPPoATM")
|
return luci.i18n.translate("PPPoATM")
|
||||||
elseif p == "l2tp" then
|
elseif p == "l2tp" then
|
||||||
return luci.i18n.translate("L2TP")
|
return luci.i18n.translate("L2TP")
|
||||||
|
elseif p == "pppossh" then
|
||||||
|
return luci.i18n.translate("PPPoSSH")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -41,6 +43,8 @@ for _, p in ipairs({"ppp", "pptp", "pppoe", "pppoa", "3g", "l2tp"}) do
|
||||||
return "ppp-mod-pppoa"
|
return "ppp-mod-pppoa"
|
||||||
elseif p == "l2tp" then
|
elseif p == "l2tp" then
|
||||||
return "xl2tpd"
|
return "xl2tpd"
|
||||||
|
elseif p == "pppossh" then
|
||||||
|
return "pppossh"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -55,6 +59,8 @@ for _, p in ipairs({"ppp", "pptp", "pppoe", "pppoa", "3g", "l2tp"}) do
|
||||||
return nixio.fs.access("/lib/netifd/proto/3g.sh")
|
return nixio.fs.access("/lib/netifd/proto/3g.sh")
|
||||||
elseif p == "l2tp" then
|
elseif p == "l2tp" then
|
||||||
return nixio.fs.access("/lib/netifd/proto/l2tp.sh")
|
return nixio.fs.access("/lib/netifd/proto/l2tp.sh")
|
||||||
|
elseif p == "pppossh" then
|
||||||
|
return nixio.fs.access("/lib/netifd/proto/pppossh.sh")
|
||||||
else
|
else
|
||||||
return nixio.fs.access("/lib/netifd/proto/ppp.sh")
|
return nixio.fs.access("/lib/netifd/proto/ppp.sh")
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue