Fix python2 server compatibility

Fixes  #469. We replace python3 exclusive code with a check for python3 and a compatibility fix. Note that the switch from os.set_nonblocking to fcntl.fcntl in 98d052d (fixing #503) also fixes python2 compatibility.
This commit is contained in:
Joseph Barker 2020-08-28 10:04:12 +09:00
parent e8f3b53c7d
commit c12d2ba5c6
No known key found for this signature in database
GPG Key ID: A42D72998CB33917
2 changed files with 23 additions and 3 deletions

View File

@ -7,8 +7,11 @@ z = zlib.decompressobj()
while 1: while 1:
name = sys.stdin.readline().strip() name = sys.stdin.readline().strip()
if name: if name:
# python2 compat: in python2 sys.stdin.readline().strip() -> str
# in python3 sys.stdin.readline().strip() -> bytes
# (see #481)
if sys.version_info >= (3, 0):
name = name.decode("ASCII") name = name.decode("ASCII")
nbytes = int(sys.stdin.readline()) nbytes = int(sys.stdin.readline())
if verbosity >= 2: if verbosity >= 2:
sys.stderr.write('server: assembling %r (%d bytes)\n' sys.stderr.write('server: assembling %r (%d bytes)\n'

View File

@ -6,7 +6,24 @@ import time
import sys import sys
import os import os
import platform import platform
if sys.version_info >= (3, 0):
from shutil import which from shutil import which
else:
# python2 compat: shutil.which is not available so we provide our own which command
def which(file, mode=os.F_OK | os.X_OK, path=None):
if path is not None:
search_paths = [path]
elif "PATH" in os.environ:
search_paths = os.environ["PATH"].split(os.pathsep)
else:
search_paths = os.defpath.split(os.pathsep)
for path in search_paths:
filepath = os.path.join(path, file)
if os.path.exists(filepath) and os.access(filepath, mode):
return filepath
return None
import sshuttle.ssnet as ssnet import sshuttle.ssnet as ssnet
import sshuttle.helpers as helpers import sshuttle.helpers as helpers