From 6e27ecfe8ce1a417af65a7f328f8ea2cd85c9c8d Mon Sep 17 00:00:00 2001 From: Sebastian Lohff Date: Sun, 24 Feb 2019 13:54:11 +0100 Subject: [PATCH] Python3 SSL socket handling --- servefile | 16 ++++++++++++++-- tests/test_servefile.py | 10 ++++++++++ 2 files changed, 24 insertions(+), 2 deletions(-) diff --git a/servefile b/servefile index bb8bb35..b594cf3 100755 --- a/servefile +++ b/servefile @@ -13,6 +13,7 @@ import argparse import base64 import cgi import datetime +import io import mimetypes import os import re @@ -771,8 +772,19 @@ class SecureThreadedHTTPServer(ThreadedHTTPServer): class SecureHandler(): def setup(self): self.connection = self.request - self.rfile = socket._fileobject(self.request, "rb", self.rbufsize) - self.wfile = socket._fileobject(self.request, "wb", self.wbufsize) + + if sys.version_info[0] > 2: + # python3 SocketIO (replacement for socket._fileobject) + raw_read_sock = socket.SocketIO(self.request, 'rb') + raw_write_sock = socket.SocketIO(self.request, 'wb') + rbufsize = self.rbufsize > 0 and self.rbufsize or io.DEFAULT_BUFFER_SIZE + wbufsize = self.wbufsize > 0 and self.wbufsize or io.DEFAULT_BUFFER_SIZE + self.rfile = io.BufferedReader(raw_read_sock, rbufsize) + self.wfile = io.BufferedWriter(raw_write_sock, wbufsize) + else: + # python2 does not have SocketIO + self.rfile = socket._fileobject(self.request, "rb", self.rbufsize) + self.wfile = socket._fileobject(self.request, "wb", self.wbufsize) class ServeFileException(Exception): pass diff --git a/tests/test_servefile.py b/tests/test_servefile.py index 866ac6f..afc587b 100644 --- a/tests/test_servefile.py +++ b/tests/test_servefile.py @@ -274,3 +274,13 @@ def test_https(run_servefile, datadir): # assert fingerprint urllib3.disable_warnings() check_download(data, protocol='https', verify=False) + +def test_https_big_download(run_servefile, datadir): + # test with about 10 mb of data + data = "x" * (10 * 1024 ** 2) + p = datadir({'testfile': data}) / 'testfile' + run_servefile(['--ssl', str(p)]) + time.sleep(0.2) # time for generating ssl certificates + + urllib3.disable_warnings() + check_download(data, protocol='https', verify=False)