2016-04-03 12:08:55 -07:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
2016-04-03 12:14:26 -07:00
|
|
|
import argparse
|
2016-04-03 12:08:55 -07:00
|
|
|
from http import server
|
|
|
|
|
import socket
|
|
|
|
|
import ssl
|
|
|
|
|
|
|
|
|
|
|
2016-04-03 12:14:26 -07:00
|
|
|
parser = argparse.ArgumentParser(description='certserver')
|
2016-04-03 12:50:30 -07:00
|
|
|
parser.add_argument(
|
|
|
|
|
'--ca-cert',
|
|
|
|
|
dest='ca_cert',
|
|
|
|
|
action='store',
|
|
|
|
|
required=True)
|
2016-04-03 12:14:26 -07:00
|
|
|
parser.add_argument(
|
|
|
|
|
'--listen-host',
|
|
|
|
|
dest='listen_host',
|
|
|
|
|
action='store',
|
|
|
|
|
default='::')
|
|
|
|
|
parser.add_argument(
|
|
|
|
|
'--listen-port',
|
|
|
|
|
dest='listen_port',
|
|
|
|
|
type=int,
|
|
|
|
|
action='store',
|
|
|
|
|
default=443)
|
|
|
|
|
parser.add_argument(
|
|
|
|
|
'--server-key',
|
|
|
|
|
dest='server_key',
|
|
|
|
|
action='store',
|
|
|
|
|
required=True)
|
|
|
|
|
parser.add_argument(
|
|
|
|
|
'--server-cert',
|
|
|
|
|
dest='server_cert',
|
|
|
|
|
action='store',
|
|
|
|
|
required=True)
|
|
|
|
|
FLAGS = parser.parse_args()
|
|
|
|
|
|
|
|
|
|
|
2016-04-03 12:08:55 -07:00
|
|
|
class HTTPServer6(server.HTTPServer):
|
|
|
|
|
address_family = socket.AF_INET6
|
|
|
|
|
|
2016-04-03 12:14:26 -07:00
|
|
|
|
|
|
|
|
class CertServer(object):
|
|
|
|
|
|
2016-04-03 12:50:30 -07:00
|
|
|
def __init__(self, listen_host, listen_port, server_key, server_cert, ca_cert):
|
2016-04-04 22:44:13 -07:00
|
|
|
|
|
|
|
|
class RequestHandler(server.BaseHTTPRequestHandler):
|
|
|
|
|
def do_POST(self):
|
|
|
|
|
assert self.headers['Content-Type'] == 'application/x-pem-file'
|
|
|
|
|
size = int(self.headers['Content-Length'])
|
|
|
|
|
print(self.rfile.read(size))
|
|
|
|
|
self.send_response(200)
|
|
|
|
|
self.end_headers()
|
|
|
|
|
|
|
|
|
|
self._httpd = HTTPServer6((listen_host, listen_port), RequestHandler)
|
2016-04-03 12:14:26 -07:00
|
|
|
self._httpd.socket = ssl.wrap_socket(
|
|
|
|
|
self._httpd.socket,
|
|
|
|
|
keyfile=server_key,
|
|
|
|
|
certfile=server_cert,
|
2016-04-03 12:50:30 -07:00
|
|
|
ca_certs=ca_cert,
|
2016-04-03 12:14:26 -07:00
|
|
|
server_side=True,
|
|
|
|
|
cert_reqs=ssl.CERT_REQUIRED,
|
|
|
|
|
ssl_version=ssl.PROTOCOL_TLSv1_2,
|
|
|
|
|
ciphers='ECDHE-ECDSA-AES256-GCM-SHA384')
|
|
|
|
|
|
|
|
|
|
def Serve(self):
|
|
|
|
|
self._httpd.serve_forever()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
|
server = CertServer(
|
|
|
|
|
FLAGS.listen_host,
|
|
|
|
|
FLAGS.listen_port,
|
|
|
|
|
FLAGS.server_key,
|
2016-04-03 12:50:30 -07:00
|
|
|
FLAGS.server_cert,
|
|
|
|
|
FLAGS.ca_cert)
|
2016-04-03 12:14:26 -07:00
|
|
|
server.Serve()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
|
main()
|