|
@ -26,7 +26,6 @@ import logging |
|
|
from shadowsocks.common import to_bytes, to_str, IPNetwork, PortRange |
|
|
from shadowsocks.common import to_bytes, to_str, IPNetwork, PortRange |
|
|
from shadowsocks import encrypt |
|
|
from shadowsocks import encrypt |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
VERBOSE_LEVEL = 5 |
|
|
VERBOSE_LEVEL = 5 |
|
|
|
|
|
|
|
|
verbose = 0 |
|
|
verbose = 0 |
|
@ -52,6 +51,7 @@ def print_exception(e): |
|
|
import traceback |
|
|
import traceback |
|
|
traceback.print_exc() |
|
|
traceback.print_exc() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def __version(): |
|
|
def __version(): |
|
|
version_str = '' |
|
|
version_str = '' |
|
|
try: |
|
|
try: |
|
@ -65,9 +65,11 @@ def __version(): |
|
|
pass |
|
|
pass |
|
|
return version_str |
|
|
return version_str |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def print_shadowsocks(): |
|
|
def print_shadowsocks(): |
|
|
print('ShadowsocksR %s' % __version()) |
|
|
print('ShadowsocksR %s' % __version()) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def log_shadowsocks_version(): |
|
|
def log_shadowsocks_version(): |
|
|
logging.info('ShadowsocksR %s' % __version()) |
|
|
logging.info('ShadowsocksR %s' % __version()) |
|
|
|
|
|
|
|
@ -84,6 +86,7 @@ def find_config(): |
|
|
|
|
|
|
|
|
return sub_find(user_config_path) or sub_find(config_path) |
|
|
return sub_find(user_config_path) or sub_find(config_path) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def check_config(config, is_local): |
|
|
def check_config(config, is_local): |
|
|
if config.get('daemon', None) == 'stop': |
|
|
if config.get('daemon', None) == 'stop': |
|
|
# no need to specify configuration for daemon stop |
|
|
# no need to specify configuration for daemon stop |
|
@ -110,13 +113,13 @@ def check_config(config, is_local): |
|
|
logging.warning('warning: local set to listen on 0.0.0.0, it\'s not safe') |
|
|
logging.warning('warning: local set to listen on 0.0.0.0, it\'s not safe') |
|
|
if config.get('server', '') in ['127.0.0.1', 'localhost']: |
|
|
if config.get('server', '') in ['127.0.0.1', 'localhost']: |
|
|
logging.warning('warning: server set to listen on %s:%s, are you sure?' % |
|
|
logging.warning('warning: server set to listen on %s:%s, are you sure?' % |
|
|
(to_str(config['server']), config['server_port'])) |
|
|
(to_str(config['server']), config['server_port'])) |
|
|
if config.get('timeout', 300) < 100: |
|
|
if config.get('timeout', 300) < 100: |
|
|
logging.warning('warning: your timeout %d seems too short' % |
|
|
logging.warning('warning: your timeout %d seems too short' % |
|
|
int(config.get('timeout'))) |
|
|
int(config.get('timeout'))) |
|
|
if config.get('timeout', 300) > 600: |
|
|
if config.get('timeout', 300) > 600: |
|
|
logging.warning('warning: your timeout %d seems too long' % |
|
|
logging.warning('warning: your timeout %d seems too long' % |
|
|
int(config.get('timeout'))) |
|
|
int(config.get('timeout'))) |
|
|
if config.get('password') in [b'mypassword']: |
|
|
if config.get('password') in [b'mypassword']: |
|
|
logging.error('DON\'T USE DEFAULT PASSWORD! Please change it in your ' |
|
|
logging.error('DON\'T USE DEFAULT PASSWORD! Please change it in your ' |
|
|
'config.json!') |
|
|
'config.json!') |
|
@ -160,7 +163,6 @@ def get_config(is_local): |
|
|
if config_path is None: |
|
|
if config_path is None: |
|
|
config_path = find_config() |
|
|
config_path = find_config() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if config_path: |
|
|
if config_path: |
|
|
logging.debug('loading config from %s' % config_path) |
|
|
logging.debug('loading config from %s' % config_path) |
|
|
with open(config_path, 'rb') as f: |
|
|
with open(config_path, 'rb') as f: |
|
@ -170,7 +172,6 @@ def get_config(is_local): |
|
|
logging.error('found an error in config.json: %s', str(e)) |
|
|
logging.error('found an error in config.json: %s', str(e)) |
|
|
sys.exit(1) |
|
|
sys.exit(1) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
v_count = 0 |
|
|
v_count = 0 |
|
|
for key, value in optlist: |
|
|
for key, value in optlist: |
|
|
if key == '-p': |
|
|
if key == '-p': |
|
@ -260,6 +261,7 @@ def get_config(is_local): |
|
|
config['server'] = to_str(config['server']) |
|
|
config['server'] = to_str(config['server']) |
|
|
else: |
|
|
else: |
|
|
config['server'] = to_str(config.get('server', '0.0.0.0')) |
|
|
config['server'] = to_str(config.get('server', '0.0.0.0')) |
|
|
|
|
|
config['black_hostname_list'] = config.get('black_hostname_list', []) |
|
|
try: |
|
|
try: |
|
|
config['forbidden_ip'] = \ |
|
|
config['forbidden_ip'] = \ |
|
|
IPNetwork(config.get('forbidden_ip', '127.0.0.0/8,::1/128')) |
|
|
IPNetwork(config.get('forbidden_ip', '127.0.0.0/8,::1/128')) |
|
@ -398,6 +400,7 @@ def _decode_dict(data): |
|
|
rv[key] = value |
|
|
rv[key] = value |
|
|
return rv |
|
|
return rv |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class JSFormat: |
|
|
class JSFormat: |
|
|
def __init__(self): |
|
|
def __init__(self): |
|
|
self.state = 0 |
|
|
self.state = 0 |
|
@ -435,6 +438,7 @@ class JSFormat: |
|
|
return "\n" |
|
|
return "\n" |
|
|
return "" |
|
|
return "" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def remove_comment(json): |
|
|
def remove_comment(json): |
|
|
fmt = JSFormat() |
|
|
fmt = JSFormat() |
|
|
return "".join([fmt.push(c) for c in json]) |
|
|
return "".join([fmt.push(c) for c in json]) |
|
|