#!/usr/bin/env python # Contributors Listed Below - COPYRIGHT 2016 # [+] International Business Machines Corp. # # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or # implied. See the License for the specific language governing # permissions and limitations under the License. import sys import os import gevent from gevent.pywsgi import WSGIServer have_wsock = True try: from geventwebsocket.handler import WebSocketHandler except ImportError: have_wsock = False # Parameters # REQUIRED Application to import and run (e.g. rest_dbus) # <--no-ssl> OPTIONAL Don't use SSL # # NOTE: If not activated via a systemd socket then this server will bind # by default to all address's at port 443 or 80(--no-ssl) if __name__ == '__main__': if len(sys.argv) < 2: sys.stderr.write('WSGI application required!') sys.exit(1) if (len(sys.argv) > 2) and (sys.argv[2] == "--no-ssl"): use_ssl = False else: use_ssl = True exec('from obmc.wsgi.apps.%s import App' % sys.argv[1]) default_cert = os.path.join( sys.prefix, 'share', os.path.basename(__file__), 'cert.pem') kw = {} if have_wsock: kw['have_wsock'] = True app = App(**kw) # repurpose for WSGIServer usage below kw = {} if use_ssl: # ECDH - Allow Elliptic Curve Diffie Hellman # kDH - Allow Key Exchange algorithm as Diffie Hellman # kEDH - Allow Key Exchange algorithm as Ephemeral Diffie Hellman # kRSA - Allow Key Exchange algorithm as RSA # !SSLv3 - Disallows any ciphers specific to SSLv3 # !SSLv2 - Disallows any ciphers specific to SSLv2 protocol # !aNULL - Disallows anonymous authentication or no authentication # !eNULL - Disallows connection with NULL encryption # !LOW - Disallows any low strength ciphers # !MEDIUM- Disallows medium strength ciphers kw['ciphers'] = ( 'ECDH:kDH:kEDH:kRSA:!SSLv3:!SSLv2:!aNULL:!eNULL:!LOW:!MEDIUM:@STRENGTH' ) kw['keyfile'] = default_cert kw['certfile'] = default_cert if os.environ.get('LISTEN_PID', None) == str(os.getpid()): FIRST_SYSTEMD_SOCKET_FD = 3 bind = gevent.socket.fromfd(FIRST_SYSTEMD_SOCKET_FD, gevent.socket.AF_INET, gevent.socket.SOCK_STREAM) else: if use_ssl: bind = ('', 443) else: bind = ('', 80) if have_wsock: kw['handler_class'] = WebSocketHandler server = WSGIServer( bind, app, **kw ) server.serve_forever()