5 network.registerPatternVirtual(/^vpn-.+$/);
7 return network.registerProtocol('vpnc', {
9 return _('VPNC (CISCO 3000 (and others) VPN)');
12 getIfname: function() {
13 return this._ubus('l3_device') || 'vpn-%s'.format(this.sid);
16 getOpkgPackage: function() {
20 isFloating: function() {
24 isVirtual: function() {
28 getDevices: function() {
32 containsDevice: function(ifname) {
33 return (network.getIfnameOf(ifname) == this.getIfname());
36 renderFormOptions: function(s) {
39 o = s.taboption('general', form.Value, 'server', _('VPN Server'));
40 o.datatype = 'host(0)';
42 o = s.taboption('general', form.Value, 'local_addr', _('VPN Local address'));
43 o.placeholder = '0.0.0.0';
44 o.datatype = 'ipaddr';
46 o = s.taboption('general', form.Value, 'local_port', _('VPN Local port'));
47 o.placeholder = '500';
50 o = s.taboption('general', form.Value, 'interface', _('Output Interface'));
51 o.template = 'cbi/network_netlist';
53 o = s.taboption('general', form.Value, 'mtu', _('MTU'));
54 o.datatype = 'uinteger';
56 s.taboption('general', form.Value, 'username', _('Username'));
58 o = s.taboption('general', form.Value, 'password', _('Password'));
61 o = s.taboption('general', form.Value, 'hexpassword', _('Obfuscated Password'));
64 s.taboption('general', form.Value, 'authgroup', _('Auth Group'));
66 o = s.taboption('general', form.Value, 'passgroup', _('Group Password'));
69 o = s.taboption('general', form.Value, 'hexpassgroup', _('Obfuscated Group Password'));
72 s.taboption('general', form.Value, 'domain', _('NT Domain'));
73 s.taboption('general', form.Value, 'vendor', _('Vendor'));
75 o = s.taboption('general', form.ListValue, 'dh_group', _('IKE DH Group'));
80 o = s.taboption('general', form.ListValue, 'pfs', _('Perfect Forward Secrecy'));
87 o = s.taboption('general', form.ListValue, 'natt_mode', _('NAT-T Mode'));
88 o.value('natt', _('RFC3947 NAT-T mode'));
89 o.value('none', _('No NAT-T'));
90 o.value('force-natt', _('Force use of NAT-T'));
91 o.value('cisco-udp', _('Cisco UDP encapsulation'));
93 o = s.taboption('general', form.Flag, 'enable_no_enc', _('Disable Encryption'), _('If checked, encryption is disabled'));
94 o.default = o.disabled;
96 o = s.taboption('general', form.Flag, 'enable_single_des', _('Enable Single DES'), _('If checked, 1DES is enabled'));
97 o.default = o.disabled;
99 o = s.taboption('general', form.Value, 'dpd_idle', _('DPD Idle Timeout'));
100 o.datatype = 'uinteger';
101 o.placeholder = '600';
103 o = s.taboption('general', form.Value, 'target_network', _('Target network'));
104 o.placeholder = '0.0.0.0/0';
105 o.datatype = 'network';
107 o = s.taboption('general', form.ListValue, 'defaultroute', _('Default Route'), _('Set VPN as Default Route'));
108 o.value('0', _('No'));
109 o.value('1', _('Yes'));