2020-07-01 19:39:13 +00:00
|
|
|
# Copyright (C) 2020 by Thomas Lindner <tom@dl6tom.de>
|
|
|
|
# Copyright (C) 2020 by Cathy Hu <cathy.hu@fau.de>
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: 0BSD
|
|
|
|
|
|
|
|
from asyncio import run as asyncio_run
|
|
|
|
from fastapi import FastAPI
|
|
|
|
from fastapi.staticfiles import StaticFiles
|
|
|
|
from hypercorn.config import Config
|
|
|
|
from hypercorn.asyncio import serve
|
|
|
|
from kibicara.config import config
|
|
|
|
from kibicara.model import Mapping
|
|
|
|
from kibicara.platformapi import Spawner
|
|
|
|
from kibicara.webapi import router
|
2020-07-06 12:50:52 +00:00
|
|
|
from logging import basicConfig, DEBUG, getLogger, WARNING
|
2020-07-01 19:39:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
logger = getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class Main:
|
|
|
|
def __init__(self):
|
|
|
|
asyncio_run(self.run())
|
|
|
|
|
|
|
|
async def run(self):
|
2020-07-06 12:50:52 +00:00
|
|
|
basicConfig(level=DEBUG, format="%(asctime)s %(name)s %(message)s")
|
|
|
|
getLogger('aiosqlite').setLevel(WARNING)
|
2020-07-01 19:39:13 +00:00
|
|
|
Mapping.create_all()
|
|
|
|
await Spawner.init_all()
|
|
|
|
await self._start_webserver()
|
|
|
|
|
|
|
|
async def _start_webserver(self):
|
|
|
|
class SinglePageApplication(StaticFiles):
|
|
|
|
async def get_response(self, path, scope):
|
|
|
|
response = await super().get_response(path, scope)
|
|
|
|
if response.status_code == 404:
|
|
|
|
response = await super().get_response('.', scope)
|
|
|
|
return response
|
2020-07-02 12:31:53 +00:00
|
|
|
|
2020-07-01 19:39:13 +00:00
|
|
|
app = FastAPI()
|
|
|
|
server_config = Config()
|
|
|
|
server_config.accesslog = '-'
|
|
|
|
app.include_router(router, prefix='/api')
|
|
|
|
if config['frontend_path'] is not None:
|
2020-07-02 12:31:53 +00:00
|
|
|
app.mount(
|
|
|
|
'/',
|
|
|
|
app=SinglePageApplication(directory=config['frontend_path'], html=True),
|
|
|
|
)
|
2020-07-01 19:39:13 +00:00
|
|
|
await serve(app, server_config)
|