summaryrefslogtreecommitdiffhomepage
path: root/applications/luci-app-libreswan
diff options
context:
space:
mode:
Diffstat (limited to 'applications/luci-app-libreswan')
-rw-r--r--applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/overview.js19
-rw-r--r--applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/proposals.js20
-rw-r--r--applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/tunnels.js113
3 files changed, 93 insertions, 59 deletions
diff --git a/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/overview.js b/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/overview.js
index 61a2e4cbcc..399e55af97 100644
--- a/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/overview.js
+++ b/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/overview.js
@@ -11,14 +11,19 @@ var callLibreswanStatus = rpc.declare({
});
function secondsToString(seconds) {
- var str = '';
- var numdays = Math.floor(seconds / 86400);
- var numhours = Math.floor((seconds % 86400) / 3600);
- var numminutes = Math.floor(((seconds % 86400) % 3600) / 60);
- var numseconds = ((seconds % 86400) % 3600) % 60;
+ const numdays = Math.floor(seconds / 86400);
+ seconds %= 86400;
+ const numhours = Math.floor(seconds / 3600);
+ seconds %= 3600;
+ const numminutes = Math.floor(seconds / 60);
+ const numseconds = seconds % 60;
- str = (numdays ? numdays + 'd ' : '') + (numhours ? numhours + 'h ' : '') + (numminutes ? numminutes + 'm ' : '') + numseconds + 's';
- return str;
+ return [
+ numdays ? `${numdays}d` : '',
+ numhours ? `${numhours}h` : '',
+ numminutes ? `${numminutes}m` : '',
+ `${numseconds}s`
+ ].filter(Boolean).join(' ');
}
return view.extend({
diff --git a/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/proposals.js b/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/proposals.js
index 8569e05caa..e1b14a8e32 100644
--- a/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/proposals.js
+++ b/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/proposals.js
@@ -2,6 +2,7 @@
'require view';
'require ui';
'require form';
+'require uci';
return view.extend({
render: function() {
@@ -15,6 +16,25 @@ return view.extend({
s.nodescriptions = true;
s.addbtntitle = _('Add Proposal');
+ s.renderSectionAdd = function(extra_class) {
+ var el = form.GridSection.prototype.renderSectionAdd.apply(this, arguments),
+ nameEl = el.querySelector('.cbi-section-create-name');
+ ui.addValidator(nameEl, 'uciname', true, function(v) {
+ let sections = [
+ ...uci.sections('libreswan', 'crypto_proposal'),
+ ...uci.sections('libreswan', 'tunnel'),
+ ];
+ if (sections.find(function(s) {
+ return s['.name'] == v;
+ })) {
+ return _('This may not share the same name as other proposals or configured tunnels.');
+ }
+ if (v.length > 15) return _('Name length shall not exceed 15 characters');
+ return true;
+ }, 'blur', 'keyup');
+ return el;
+ };
+
o = s.tab('general', _('General'));
o = s.taboption('general', form.MultiValue, 'hash_algorithm', _('Hash Algorithm'), ('* = %s').format(_('Unsafe')));
diff --git a/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/tunnels.js b/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/tunnels.js
index f7cb439458..a2d5fd8493 100644
--- a/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/tunnels.js
+++ b/applications/luci-app-libreswan/htdocs/luci-static/resources/view/libreswan/tunnels.js
@@ -8,23 +8,17 @@
'require tools.widgets as widgets';
function calculateNetwork(addr, mask) {
- addr = validation.parseIPv4(String(addr));
-
- if (!isNaN(mask))
- mask = validation.parseIPv4(network.prefixToMask(+mask));
- else
- mask = validation.parseIPv4(String(mask));
-
- if (addr == null || mask == null)
- return null;
-
- return [
- addr[0] & (mask[0] >>> 0 & 255),
- addr[1] & (mask[1] >>> 0 & 255),
- addr[2] & (mask[2] >>> 0 & 255),
- addr[3] & (mask[3] >>> 0 & 255)
- ].join('.') + '/' +
- network.maskToPrefix(mask.join('.'));
+ const parsedAddr = validation.parseIPv4(String(addr));
+ if (parsedAddr == null) return null;
+
+ const parsedMask = !isNaN(mask)
+ ? validation.parseIPv4(network.prefixToMask(+mask))
+ : validation.parseIPv4(String(mask));
+ if (parsedMask == null) return null;
+
+ const networkAddr = parsedAddr.map((byte, i) => byte & (parsedMask[i] >>> 0 & 255));
+
+ return `${networkAddr.join('.')}/${network.maskToPrefix(parsedMask.join('.'))}`;
}
return view.extend({
@@ -54,6 +48,26 @@ return view.extend({
s.nodedescription = false;
s.addbtntitle = _('Add Tunnel');
+ s.renderSectionAdd = function(extra_class) {
+ var el = form.GridSection.prototype.renderSectionAdd.apply(this, arguments),
+ nameEl = el.querySelector('.cbi-section-create-name');
+ ui.addValidator(nameEl, 'uciname', true, function(v) {
+ let sections = [
+ ...uci.sections('libreswan', 'crypto_proposal'),
+ ...uci.sections('libreswan', 'tunnel'),
+ ];
+
+ if (sections.find(function(s) {
+ return s['.name'] == v;
+ })) {
+ return _('This may not share the same name as other proposals or configured tunnels.');
+ }
+ if (v.length > 15) return _('Name length shall not exceed 15 characters');
+ return true;
+ }, 'blur', 'keyup');
+ return el;
+ };
+
o = s.tab('general', _('General'));
o = s.tab('authentication', _('Authentication'));
o = s.tab('interface', _('Interface'));
@@ -71,15 +85,14 @@ return view.extend({
o = s.taboption('general', form.Value, 'left', _('Left IP/Device'));
o.datatype = 'or(string, ipaddr)';
- for (var i = 0; i < netDevs.length; i++) {
- var addrs = netDevs[i].getIPAddrs();
- for (var j = 0; j < addrs.length; j++) {
- o.value(addrs[j].split('/')[0]);
- }
- }
- for (var i = 0; i < netDevs.length; i++) {
- o.value('%' + netDevs[i].device);
- }
+ netDevs.forEach(netDev => {
+ netDev.getIPAddrs().forEach(addr => {
+ o.value(addr.split('/')[0]);
+ });
+ });
+ netDevs.forEach(netDev => {
+ o.value(`%${netDev.device}`);
+ });
o.value('%defaultroute');
o.optional = false;
o.depends({ 'left_interface' : '' });
@@ -102,12 +115,11 @@ return view.extend({
o = s.taboption('general', form.Value, 'leftsourceip', _('Local Source IP'));
o.datatype = 'ipaddr';
- for (var i = 0; i < netDevs.length; i++) {
- var addrs = netDevs[i].getIPAddrs();
- for (var j = 0; j < addrs.length; j++) {
- o.value(addrs[j].split('/')[0]);
- }
- }
+ netDevs.forEach(netDev => {
+ netDev.getIPAddrs().forEach(addr => {
+ o.value(addr.split('/')[0]);
+ });
+ });
o.optional = false;
o.modalonly = true;
@@ -160,6 +172,13 @@ return view.extend({
}
o.modalonly = true;
+ function timevalidate(section_id, value) {
+ if (!/^[0-9]{1,3}[smhd]$/.test(value)) {
+ return _('Acceptable values are an integer followed by m, h, d');
+ }
+ return true;
+ }
+
o = s.taboption('advanced', form.Value, 'ikelifetime', _('IKE Life Time'), _('Acceptable values are an integer followed by m, h, d'));
o.default = '8h';
o.value('1h', '1h');
@@ -171,12 +190,7 @@ return view.extend({
o.value('24h', '24h');
o.modalonly = false;
o.modalonly = true;
- o.validate = function(section_id, value) {
- if (!/^[0-9]{1,3}[smhd]$/.test(value)) {
- return _('Acceptable values are an integer followed by m, h, d');
- }
- return true;
- }
+ o.validate = timevalidate;
o = s.taboption('advanced', form.Flag, 'rekey', _('Rekey'));
o.default = false;
@@ -193,12 +207,7 @@ return view.extend({
o.value('60m', '60m');
o.modalonly = false;
o.modalonly = true;
- o.validate = function(section_id, value) {
- if (!/^[0-9]{1,3}[smhd]$/.test(value)) {
- return _('Acceptable values are an integer followed by m, h, d');
- }
- return true;
- }
+ o.validate = timevalidate;
o = s.taboption('advanced', form.ListValue, 'dpdaction', _('DPD Action'));
o.default = 'restart';
@@ -245,17 +254,17 @@ return view.extend({
o.rmempty = true;
o.modalonly = true;
o.value('');
- for (var i = 0; i < interfaces.length; i++) {
- if ((interfaces[i]['proto'] == "vti") && interfaces[i]['ikey'] && interfaces[i]['okey']) {
- o.value(interfaces[i]['.name'], 'VTI - ' + interfaces[i]['.name']);
+ interfaces.forEach(iface => {
+ const { proto, ikey, okey, ifid, ['.name']: name } = iface;
+
+ if (proto === "vti" && ikey && okey) {
+ o.value(name, `VTI - ${name}`);
}
- if ((interfaces[i]['proto'] == "xfrm")
- && interfaces[i]['ifid']
- && interfaces[i]['.name'].match('ipsec' + interfaces[i]['ifid'])) {
- o.value(interfaces[i]['.name'], 'XFRM - ' + interfaces[i]['.name']);
+ if (proto === "xfrm" && ifid && name.match(`ipsec${ifid}`)) {
+ o.value(name, `XFRM - ${name}`);
}
- }
+ });
o = s.taboption('advanced', form.Flag, 'update_peeraddr', _('Update Peer Address'),
_('Auto Update Peer Address of VTI interface'));