hyp/hyp.py
2015-03-28 18:55:12 +01:00

62 lines
2.1 KiB
Python

#!/usr/bin/env python3
import argparse
import sys
import os.path
import http.server
import ssl
def check_cert(dir):
try:
for i in 'cert', 'key':
open(os.path.join(dir, 'https-%s.pem' % i)).close()
except (FileNotFoundError, PermissionError) as e:
print('Could not use %s: %s. Using http only.' % (dir, e.args[1]))
return False
except Exception as e:
print('Error %d: %s' % e.args)
sys.exit(e.errno)
return True
def main(address, port, tls_dir):
use_tls = check_cert(tls_dir)
port = 80 if port == 443 and not use_tls else port
try:
server = http.server.HTTPServer((address, port),
http.server.SimpleHTTPRequestHandler)
if use_tls:
tls_socket = ssl.wrap_socket(server.socket, server_side=True,
certfile=os.path.join(tls_dir, 'https-cert.pem'),
keyfile=os.path.join(tls_dir,'https-key.pem'),
ssl_version=ssl.PROTOCOL_TLSv1_2)
server.socket = tls_socket
except Exception as e:
print('Error %d: %s' % e.args)
sys.exit(e.errno)
print('Serving on %s:%d...' % (address, port))
try:
server.serve_forever()
except KeyboardInterrupt:
print(' Bye.')
server.socket.close()
if __name__ == '__main__':
parser = argparse.ArgumentParser(description='Hyperminimal https server')
parser.add_argument('address', nargs='?',
type=str, default='0.0.0.0',
help='bind ip address (default: 0.0.0.0)')
parser.add_argument('port', nargs='?',
type=int, default=443,
help='bind port number (default: 80 or 443)')
parser.add_argument('-t', '--tls', type=str,
default='/usr/local/etc/openssl',
help='cert/key couple directory. Must be PEM'
'formatted and named https-key.pem, https-cert.pem'
'(default: /usr/local/etc/openssl)')
args = parser.parse_args()
main(args.address, args.port, args.tls)