protocols: add client side protocol handler implementations
[project/luci.git] / protocols / luci-proto-ppp / htdocs / luci-static / resources / protocol / pppoe.js
diff --git a/protocols/luci-proto-ppp/htdocs/luci-static/resources/protocol/pppoe.js b/protocols/luci-proto-ppp/htdocs/luci-static/resources/protocol/pppoe.js
new file mode 100644 (file)
index 0000000..5d71c43
--- /dev/null
@@ -0,0 +1,114 @@
+'use strict';
+'require uci';
+'require form';
+'require network';
+
+network.registerPatternVirtual(/^pppoe-.+$/);
+
+function write_keepalive(section_id, value) {
+       var f_opt = this.map.lookupOption('_keepalive_failure', section_id),
+           i_opt = this.map.lookupOption('_keepalive_interval', section_id),
+           f = (f_opt != null) ? +f_opt[0].formvalue(section_id) : null,
+           i = (i_opt != null) ? +i_opt[0].formvalue(section_id) : null;
+
+       if (f == null || f == '' || isNaN(f))
+               f = 0;
+
+       if (i == null || i == '' || isNaN(i) || i < 1)
+               i = 1;
+
+       if (f > 0)
+               uci.set('network', section_id, 'keepalive', '%d %d'.format(f, i));
+       else
+               uci.unset('network', section_id, 'keepalive');
+}
+
+return network.registerProtocol('pppoe', {
+       getI18n: function() {
+               return _('PPPoE');
+       },
+
+       getIfname: function() {
+               return this._ubus('l3_device') || 'pppoe-%s'.format(this.sid);
+       },
+
+       getOpkgPackage: function() {
+               return 'ppp-mod-pppoe';
+       },
+
+       renderFormOptions: function(s) {
+               var dev = this.getL3Device() || this.getDevice(), o;
+
+               s.taboption('general', form.Value, 'username', _('PAP/CHAP username'));
+
+               o = s.taboption('general', form.Value, 'password', _('PAP/CHAP password'));
+               o.password = true;
+
+               o = s.taboption('general', form.Value, 'ac', _('Access Concentrator'), _('Leave empty to autodetect'));
+               o.placeholder = _('auto');
+
+               o = s.taboption('general', form.Value, 'service', _('Service Name'), _('Leave empty to autodetect'));
+               o.placeholder = _('auto');
+
+               if (L.hasSystemFeature('ipv6')) {
+                       o = s.taboption('advanced', form.ListValue, 'ipv6', _('Obtain IPv6-Address'), _('Enable IPv6 negotiation on the PPP link'));
+                       o.value('auto', _('Automatic'));
+                       o.value('0', _('Disabled'));
+                       o.value('1', _('Manual'));
+                       o.default = 'auto';
+               }
+
+               o = s.taboption('advanced', form.Flag, 'defaultroute', _('Use default gateway'), _('If unchecked, no default route is configured'));
+               o.default = o.enabled;
+
+               o = s.taboption('advanced', form.Flag, 'peerdns', _('Use DNS servers advertised by peer'), _('If unchecked, the advertised DNS server addresses are ignored'));
+               o.default = o.enabled;
+
+               o = s.taboption('advanced', form.DynamicList, 'dns', _('Use custom DNS servers'));
+               o.depends('peerdns', '0');
+               o.datatype = 'ipaddr';
+               o.cast     = 'string';
+
+               o = s.taboption('advanced', form.Value, 'metric', _('Use gateway metric'));
+               o.placeholder = '0';
+               o.datatype    = 'uinteger';
+
+               o = s.taboption('advanced', form.Value, '_keepalive_failure', _('LCP echo failure threshold'), _('Presume peer to be dead after given amount of LCP echo failures, use 0 to ignore failures'));
+               o.placeholder = '0';
+               o.datatype    = 'uinteger';
+               o.write       = write_keepalive;
+               o.remove      = write_keepalive;
+               o.cfgvalue = function(section_id) {
+                       var v = uci.get('network', section_id, 'keepalive');
+                       if (typeof(v) == 'string' && v != '') {
+                               var m = v.match(/^(\d+)[ ,]\d+$/);
+                               return m ? m[1] : v;
+                       }
+               };
+
+               o = s.taboption('advanced', form.Value, '_keepalive_interval', _('LCP echo interval'), _('Send LCP echo requests at the given interval in seconds, only effective in conjunction with failure threshold'));
+               o.placeholder = '5';
+               o.datatype    = 'min(1)';
+               o.write       = write_keepalive;
+               o.remove      = write_keepalive;
+               o.cfgvalue = function(section_id) {
+                       var v = uci.get('network', section_id, 'keepalive');
+                       if (typeof(v) == 'string' && v != '') {
+                               var m = v.match(/^\d+[ ,](\d+)$/);
+                               return m ? m[1] : v;
+                       }
+               };
+
+               o = s.taboption('advanced', form.Value, 'host_uniq', _('Host-Uniq tag content'), _('Raw hex-encoded bytes. Leave empty unless your ISP require this'));
+               o.placeholder = _('auto');
+               o.datatype    = 'hexstring';
+
+               o = s.taboption('advanced', form.Value, 'demand', _('Inactivity timeout'), _('Close inactive connection after the given amount of seconds, use 0 to persist connection'));
+               o.placeholder = '0';
+               o.datatype    = 'uinteger';
+
+               o = s.taboption('advanced', form.Value, 'mtu', _('Override MTU'));
+               o.placeholder = dev ? (dev.getMTU() || '1500') : '1500';
+               o.datatype    = 'max(9200)';
+       }
+});