Browse Source

read black_hostname_list from config

akkariiin/master
Akkariiin 8 years ago
parent
commit
a1b2513a82
  1. 16
      shadowsocks/shell.py

16
shadowsocks/shell.py

@ -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])

Loading…
Cancel
Save