123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- 'use strict';
- 'require view';
- 'require ui';
- 'require form';
- 'require rpc';
- 'require tools.widgets as widgets';
- var callServiceList = rpc.declare({
- object: 'service',
- method: 'list',
- params: ['name'],
- expect: { '': {} }
- });
- function getServiceStatus() {
- return L.resolveDefault(callServiceList('xfrpc'), {}).then(function (res) {
- var isRunning = false;
- try {
- isRunning = res['xfrpc']['instances']['instance1']['running'];
- } catch (e) { }
- return isRunning;
- });
- }
- function renderStatus(isRunning) {
- var renderHTML = "";
- var spanTemp = '<em><span style="color:%s"><strong>%s %s</strong></span></em>';
- if (isRunning) {
- renderHTML += String.format(spanTemp, 'green', _("x-frp Client "), _("RUNNING"));
- } else {
- renderHTML += String.format(spanTemp, 'red', _("x-frp Client "), _("NOT RUNNING"));
- }
- return renderHTML;
- }
- return view.extend({
- render: function() {
- var m, s, o;
- m = new form.Map('xfrpc', _('xfrpc'));
- m.description = _("xfrpc is a c language frp client for frps.");
- s = m.section(form.NamedSection, '_status');
- s.anonymous = true;
- s.render = function (section_id) {
- L.Poll.add(function () {
- return L.resolveDefault(getServiceStatus()).then(function(res) {
- var view = document.getElementById("service_status");
- view.innerHTML = renderStatus(res);
- });
- });
- return E('div', { class: 'cbi-map' },
- E('fieldset', { class: 'cbi-section'}, [
- E('p', { id: 'service_status' },
- _('Collecting data ...'))
- ])
- );
- }
- s = m.section(form.NamedSection, 'common', 'xfrpc');
- s.dynamic = true;
- s.tab('common', _('Common Settings'));
- s.tab('init', _('Startup Settings'));
- o = s.taboption('common', form.Value, 'server_addr', _('Server address'),
- '%s <br /> %s'.format(_('Server address specifies the address of the server to connect to.'),
- _('By default, this value is "0.0.0.0".')));
- o.datatype = 'host';
- o = s.taboption('common', form.Value, 'server_port', _('Server port'),
- '%s <br /> %s'.format(_('Server port specifies the port to connect to the server on.'),
- _('By default, this value is 7000.')));
- o.datatype = 'port';
- o = s.taboption('common', form.Value, 'token', _('Token'),
- '%s <br /> %s'.format(_('Token specifies the authorization token used to create keys to be \
- sent to the server. The server must have a matching token for authorization to succeed.'),
- _('By default, this value is "".')));
- o = s.taboption('init', form.SectionValue, 'init', form.TypedSection,
- 'xfrp', _('Startup Settings'));
- s = o.subsection;
- s.anonymous = true;
- s.dynamic = true;
- o = s.option(form.Flag, 'disabled', _('Disabled xfrpc service'));
- o.datatype = 'bool';
- o.optional = true;
- o = s.option(form.ListValue, 'loglevel', _('Log level'),
- '%s <br /> %s'.format(_('LogLevel specifies the minimum log level. Valid values are "Debug", "Info", \
- "Notice", "Warning", "Error", "Critical", "Alert" and "Emergency".'),
- _('By default, this value is "Info".')));
- o.value(8, _('Debug'))
- o.value(7, _('Info'))
- o.value(6, _('Notice'))
- o.value(5, _('Warning'))
- o.value(4, _('Error'))
- o.value(3, _('Critical'))
- o.value(2, _('Alert'))
- o.value(1, _('Emergency'))
- s = m.section(form.GridSection, 'xfrpc', _('Proxy Settings'));
- s.addremove = true;
- s.filter = function(s) { return s !== 'common'; };
- 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) {
- if (v === 'common') return _('Name can not be "common"');
- return true;
- }, 'blur', 'keyup');
- return el;
- }
- s.tab('general', _('General Settings'));
- s.tab('http', _('HTTP Settings'));
- s.option(form.Value, 'type', _('Proxy type'));
- s.option(form.Value, 'local_ip', _('Local IP'));
- s.option(form.Value, 'local_port', _('Local port'));
- o = s.taboption('general', form.ListValue, 'type', _('Proxy type'),
- '%s <br /> %s'.format(_('ProxyType specifies the type of this proxy. Valid values include "tcp", "http", "https".'),
- _('By default, this value is "tcp".')));
- o.value('tcp');
- o.value('http');
- o.value('https');
- o.modalonly = true;
- o = s.taboption('general', form.Value, 'local_ip', _('Local IP'),
- _('LocalIp specifies the IP address or host name to proxy to.'));
- o.modalonly = true;
- o.datatype = 'ip4addr';
-
- o = s.taboption('general', form.Value, 'local_port', _('Local port'),
- _('LocalPort specifies the port to proxy to.'));
- o.modalonly = true;
- o.datatype = 'port';
- // TCP
- o = s.taboption('general', form.Value, 'remote_port', _('Remote port'),
- _('If remote_port is 0, frps will assign a random port for you'));
- o.depends.apply(o, [{type: 'tcp'}]);
- o.optional = true;
- o.modalonly = true;
- o.datatype = 'port';
- // HTTP and HTTPS
- o = s.taboption('http', form.Value, 'custom_domains', _('Custom domains'));
- o.depends.apply(o, [{type: 'http'}]);
- o.depends.apply(o, [{type: 'https'}]);
- o.optional = true;
- o.modalonly = true;
- o = s.taboption('http', form.Value, 'subdomain', _('Subdomain'));
- o.depends.apply(o, [{type: 'http'}]);
- o.depends.apply(o, [{type: 'https'}]);
- o.optional = true;
- o.modalonly = true;
- return m.render();
- }
- });
|