Example #1
0
 def run_app_sync(*args, loop=None, shutdown_event=None):
     kwargs = {}
     config = Config()
     cert_file_name, key_file_name = ssl_creds or (None, None)
     if cert_file_name:
         kwargs['certfile'] = cert_file_name
         config.certfile = cert_file_name
     if key_file_name:
         kwargs['keyfile'] = key_file_name
         config.keyfile = key_file_name
     setup_quart_logging()
     config.bind = ['0.0.0.0:%s' % port]
     loop = loop or ensure_event_loop()
     run_kwargs = {}
     if shutdown_event:
         run_kwargs['shutdown_trigger'] = shutdown_event.wait
     try:
         try:
             return loop.run_until_complete(serve(app, config, **run_kwargs))
         except Exception as e:
             if 'SSLError' in str(e):
                 c_exists = os.path.exists(cert_file_name)
                 k_exists = os.path.exists(key_file_name)
                 c_size = len(load_file(cert_file_name)) if c_exists else 0
                 k_size = len(load_file(key_file_name)) if k_exists else 0
                 LOG.warning('Unable to create SSL context. Cert files exist: %s %s (%sB), %s %s (%sB)' %
                     (cert_file_name, c_exists, c_size, key_file_name, k_exists, k_size))
             raise
     finally:
         try:
             _cancel_all_tasks(loop)
             loop.run_until_complete(loop.shutdown_asyncgens())
         finally:
             asyncio.set_event_loop(None)
             loop.close()
Example #2
0
 def run_app_sync(*args, loop=None, shutdown_event=None):
     kwargs = {}
     config = Config()
     cert_file_name, key_file_name = ssl_creds or (None, None)
     if cert_file_name:
         kwargs['certfile'] = cert_file_name
         config.certfile = cert_file_name
     if key_file_name:
         kwargs['keyfile'] = key_file_name
         config.keyfile = key_file_name
     setup_quart_logging()
     config.bind = ['0.0.0.0:%s' % port]
     loop = loop or ensure_event_loop()
     run_kwargs = {}
     if shutdown_event:
         run_kwargs['shutdown_trigger'] = shutdown_event.wait
     try:
         return loop.run_until_complete(serve(app, config, **run_kwargs))
     finally:
         try:
             _cancel_all_tasks(loop)
             loop.run_until_complete(loop.shutdown_asyncgens())
         finally:
             asyncio.set_event_loop(None)
             loop.close()
Example #3
0
 def run_app_sync(*args, loop=None, shutdown_event=None):
     kwargs = {}
     config = Config()
     cert_file_name, key_file_name = ssl_creds or (None, None)
     if cert_file_name:
         kwargs["certfile"] = cert_file_name
         config.certfile = cert_file_name
     if key_file_name:
         kwargs["keyfile"] = key_file_name
         config.keyfile = key_file_name
     setup_quart_logging()
     config.bind = [f"{bind_address}:{port}" for bind_address in bind_addresses]
     config.workers = len(bind_addresses)
     loop = loop or ensure_event_loop()
     run_kwargs = {}
     if shutdown_event:
         run_kwargs["shutdown_trigger"] = shutdown_event.wait
     try:
         try:
             return loop.run_until_complete(serve(app, config, **run_kwargs))
         except Exception as e:
             LOG.info(
                 "Error running server event loop on port %s: %s %s",
                 port,
                 e,
                 traceback.format_exc(),
             )
             if "SSL" in str(e):
                 c_exists = os.path.exists(cert_file_name)
                 k_exists = os.path.exists(key_file_name)
                 c_size = len(load_file(cert_file_name)) if c_exists else 0
                 k_size = len(load_file(key_file_name)) if k_exists else 0
                 LOG.warning(
                     "Unable to create SSL context. Cert files exist: %s %s (%sB), %s %s (%sB)",
                     cert_file_name,
                     c_exists,
                     c_size,
                     key_file_name,
                     k_exists,
                     k_size,
                 )
             raise
     finally:
         try:
             _cancel_all_tasks(loop)
             loop.run_until_complete(loop.shutdown_asyncgens())
         finally:
             asyncio.set_event_loop(None)
             loop.close()