Use command "locale charmap" to detect encoding

pull/26/head
Sheng 6 years ago
parent 80bdddc280
commit 688ca78bb2

@ -51,13 +51,12 @@ class Server(paramiko.ServerInterface):
b'UWT10hcuO4Ks8=') b'UWT10hcuO4Ks8=')
good_pub_key = paramiko.RSAKey(data=decodebytes(data)) good_pub_key = paramiko.RSAKey(data=decodebytes(data))
langs = ['en_US.UTF-8', 'zh_CN.GBK'] encodings = ['UTF-8', 'GBK']
def __init__(self): def __init__(self):
self.shell_event = threading.Event() self.shell_event = threading.Event()
self.exec_event = threading.Event() self.exec_event = threading.Event()
self.lang = random.choice(self.langs) self.encoding = random.choice(self.encodings)
self.encoding = self.lang.split('.')[-1]
def check_channel_request(self, kind, chanid): def check_channel_request(self, kind, chanid):
if kind == 'session': if kind == 'session':
@ -82,12 +81,11 @@ class Server(paramiko.ServerInterface):
return 'password,publickey' return 'password,publickey'
def check_channel_exec_request(self, channel, command): def check_channel_exec_request(self, channel, command):
if command != b'locale': if command != b'locale charmap':
ret = False ret = False
else: else:
ret = True ret = True
result = 'LANG={lang}\nLANGUAGE=\nLC_CTYPE="{lang}"\n'.format(lang=self.lang) # noqa channel.send(self.encoding)
channel.send(result)
channel.shutdown(1) channel.shutdown(1)
self.exec_event.set() self.exec_event.set()
return ret return ret

@ -3,24 +3,7 @@ import paramiko
from tornado.httputil import HTTPServerRequest from tornado.httputil import HTTPServerRequest
from tests.utils import read_file, make_tests_data_path from tests.utils import read_file, make_tests_data_path
from webssh.handler import ( from webssh.handler import MixinHandler, IndexHandler, InvalidValueError
MixinHandler, IndexHandler, parse_encoding, InvalidValueError
)
class TestHandler(unittest.TestCase):
def test_parse_encoding(self):
data = ''
self.assertIsNone(parse_encoding(data))
data = 'UTF-8'
self.assertEqual(parse_encoding(data), 'UTF-8')
data = 'en_US.UTF-8'
self.assertEqual(parse_encoding(data), 'UTF-8')
data = 'LANG=en_US.UTF-8\nLANGUAGE=\nLC_CTYPE="en_US.UTF-8"\n'
self.assertEqual(parse_encoding(data), 'UTF-8')
data = 'LANGUAGE=\nLC_CTYPE="en_US.UTF-8"\n'
self.assertEqual(parse_encoding(data), 'UTF-8')
class TestMixinHandler(unittest.TestCase): class TestMixinHandler(unittest.TestCase):

@ -32,13 +32,6 @@ DELAY = 3
KEY_MAX_SIZE = 16384 KEY_MAX_SIZE = 16384
def parse_encoding(data):
for line in data.split('\n'):
s = line.split('=')[-1]
if s:
return s.strip('"').split('.')[-1]
class InvalidValueError(Exception): class InvalidValueError(Exception):
pass pass
@ -176,12 +169,11 @@ class IndexHandler(MixinHandler, tornado.web.RequestHandler):
def get_default_encoding(self, ssh): def get_default_encoding(self, ssh):
try: try:
_, stdout, _ = ssh.exec_command('locale') _, stdout, _ = ssh.exec_command('locale charmap')
except paramiko.SSHException: except paramiko.SSHException:
result = None result = None
else: else:
data = stdout.read() result = to_str(stdout.read())
result = parse_encoding(to_str(data))
return result if result else 'utf-8' return result if result else 'utf-8'

Loading…
Cancel
Save