From 3a7c6df26296922e2ce2d6aeb8e23cdae2ddb9b6 Mon Sep 17 00:00:00 2001 From: Yousong Zhou Date: Wed, 29 Jul 2020 14:53:32 +0800 Subject: luci-app-shadowsocks-libev: local_{ipv4,ipv6}_address for ss_server Following changes are related and included in the same commit - Deprecate bind_address by not displaying and handling it in the UI - Allow ipv6 address for the old local_address option Signed-off-by: Yousong Zhou --- .../htdocs/luci-static/resources/shadowsocks-libev.js | 17 +++++++++++++++-- .../resources/view/shadowsocks-libev/instances.js | 17 +++++++++++++---- 2 files changed, 28 insertions(+), 6 deletions(-) (limited to 'applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources') diff --git a/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/shadowsocks-libev.js b/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/shadowsocks-libev.js index ef93a1c754..c0f1ced553 100644 --- a/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/shadowsocks-libev.js +++ b/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/shadowsocks-libev.js @@ -21,6 +21,7 @@ var names_options_client = [ ]; var names_options_common = [ + 'local_address', 'verbose', 'ipv6_first', 'fast_open', @@ -100,7 +101,7 @@ return baseclass.extend({ } }); }, - values_ipaddr: function(o, netDevs) { + values_ip4addr: function(o, netDevs) { netDevs.forEach(function(v) { v.getIPAddrs().forEach(function(a) { var host = a.split('/')[0]; @@ -108,6 +109,18 @@ return baseclass.extend({ }); }); }, + values_ip6addr: function(o, netDevs) { + netDevs.forEach(function(v) { + v.getIP6Addrs().forEach(function(a) { + var host = a.split('/')[0]; + o.value(host, '%s (%s)'.format(host, v.getShortName())); + }); + }); + }, + values_ipaddr: function(o, netDevs) { + this.values_ip4addr(o, netDevs) + this.values_ip6addr(o, netDevs) + }, options_client: function(s, tab, netDevs) { var o = s.taboption(tab, form.ListValue, 'server', _('Remote server')); this.values_serverlist(o); @@ -191,7 +204,7 @@ return baseclass.extend({ if (stype === 'ss_server') { this.cfgvalue_overview_(sdata, lines, names_options_server); this.cfgvalue_overview_(sdata, lines, names_options_common); - this.cfgvalue_overview_(sdata, lines, ['bind_address']); + this.cfgvalue_overview_(sdata, lines, ['local_ipv4_address', 'local_ipv6_address']); } else if (stype === 'ss_local' || stype === 'ss_redir' || stype === 'ss_tunnel') { this.cfgvalue_overview_(sdata, lines, names_options_client); if (stype === 'ss_tunnel') { diff --git a/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/view/shadowsocks-libev/instances.js b/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/view/shadowsocks-libev/instances.js index 9a591d5962..671f17a9e4 100644 --- a/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/view/shadowsocks-libev/instances.js +++ b/applications/luci-app-shadowsocks-libev/htdocs/luci-static/resources/view/shadowsocks-libev/instances.js @@ -84,12 +84,21 @@ return view.extend({ if (stype === 'ss_server') { ss.options_server(s, { tab: 'general' }); - o = s.taboption('general', form.Value, 'bind_address', - _('Bind address'), - _('The address ss-server will initiate connection from')); + o = s.taboption('advanced', form.Value, 'local_address', + _('Local address'), + _('The address ss-server will initiate connections from')); o.datatype = 'ipaddr'; - o.placeholder = '0.0.0.0'; ss.values_ipaddr(o, res[1]); + o = s.taboption('advanced', form.Value, 'local_ipv4_address', + _('Local IPv4 address'), + _('The IPv4 address ss-server will initiate IPv4 connections from')); + o.datatype = 'ip4addr'; + ss.values_ip4addr(o, res[1]); + o = s.taboption('advanced', form.Value, 'local_ipv6_address', + _('Local IPv6 address'), + _('The IPv6 address ss-server will initiate IPv6 connections from')); + o.datatype = 'ip6addr'; + ss.values_ip6addr(o, res[1]); } else { ss.options_client(s, 'general', res[1]); if (stype === 'ss_tunnel') { -- cgit v1.2.3