#!/usr/bin/env python """ simple_https_server.py Vladimir Diaz. June 17, 2014 See LICENSE for licensing information. Provide a simple https server that can be used by the unit tests. For example, 'download.py' can connect to the https server started by this module to verify that https downloads are permitted. ssl.wrap_socket: https://docs.python.org/2/library/ssl.html#functions-constants-and-exceptions SimpleHTTPServer: http://docs.python.org/library/simplehttpserver.html#module-SimpleHTTPServer """ # Help with Python 3 compatibility, where the print statement is a function, an # implicit relative import is invalid, and the '/' operator performs true # division. Example: print 'hello world' raises a 'SyntaxError' exception. from __future__ import print_function from __future__ import absolute_import from __future__ import division from __future__ import unicode_literals import sys import random import ssl import tuf._vendor.six as six PORT = 0 def _generate_random_port(): return random.randint(30000, 45000) if len(sys.argv) > 1: try: PORT = int(sys.argv[1]) if PORT < 30000 or PORT > 45000: raise ValueError except ValueError: PORT = _generate_random_port() else: PORT = _generate_random_port() httpd = six.moves.BaseHTTPServer.HTTPServer(('localhost', PORT), six.moves.SimpleHTTPServer.SimpleHTTPRequestHandler) httpd.socket = ssl.wrap_socket(httpd.socket, certfile='https_server.pem', server_side=True) #print('Starting https server on port: ' + str(PORT)) httpd.serve_forever()