comment-server/src/app.py

91 lines
2.8 KiB
Python
Raw Normal View History

2019-05-26 06:42:39 +02:00
# cython: language_level=3
2019-05-21 13:54:52 +02:00
import logging
import pathlib
import re
2019-05-21 13:54:52 +02:00
2019-07-19 06:32:14 +02:00
import aiojobs
2019-05-21 13:54:52 +02:00
import aiojobs.aiohttp
2019-05-16 01:17:06 +02:00
import asyncio
from aiohttp import web
2019-05-21 15:02:50 +02:00
import schema.db_helpers
from src.database import obtain_connection, DatabaseWriter
2019-07-22 14:10:21 +02:00
from src.handles import api_endpoint, get_api_endpoint
2019-05-21 12:56:27 +02:00
logger = logging.getLogger(__name__)
2019-05-20 07:18:47 +02:00
async def setup_db_schema(app):
if not pathlib.Path(app['db_path']).exists():
logger.info('Setting up schema in %s', app['db_path'])
schema.db_helpers.setup_database(app['db_path'])
else:
logger.info('Database already exists in %s, skipping setup', app['db_path'])
2019-05-16 01:17:06 +02:00
2019-05-20 07:18:47 +02:00
async def close_comment_scheduler(app):
2019-07-20 15:06:34 +02:00
logger.info('Closing comment_scheduler')
await app['comment_scheduler'].close()
2019-05-16 01:17:06 +02:00
async def database_backup_routine(app):
2019-05-21 12:56:27 +02:00
try:
while True:
await asyncio.sleep(app['config']['BACKUP_INT'])
with obtain_connection(app['db_path']) as conn:
logger.debug('backing up database')
2019-05-21 15:02:50 +02:00
schema.db_helpers.backup_database(conn, app['backup'])
except asyncio.CancelledError:
pass
2019-05-21 12:56:27 +02:00
2019-07-19 06:32:14 +02:00
# noinspection PyDeprecation
2019-05-21 12:56:27 +02:00
async def start_background_tasks(app: web.Application):
app['reader'] = obtain_connection(app['db_path'], True)
app['waitful_backup'] = app.loop.create_task(database_backup_routine(app))
2019-07-19 06:32:14 +02:00
app['comment_scheduler'] = await aiojobs.create_scheduler(limit=1, pending_limit=0)
app['db_writer'] = DatabaseWriter(app['db_path'])
app['writer'] = app['db_writer'].connection
def insert_to_config(app, conf=None, db_file=None):
db_file = db_file if db_file else 'DEFAULT'
app['config'] = conf if conf else config
app['db_path'] = conf['PATH'][db_file]
app['backup'] = re.sub(r'\.db$', '.backup.db', app['db_path'])
assert app['db_path'] != app['backup']
2019-05-21 12:56:27 +02:00
async def cleanup_background_tasks(app):
2019-07-20 15:06:34 +02:00
logger.info('Ending background backup loop')
2019-05-21 12:56:27 +02:00
app['waitful_backup'].cancel()
await app['waitful_backup']
app['reader'].close()
app['writer'].close()
2019-05-21 12:56:27 +02:00
def create_app(conf, db_path='DEFAULT', **kwargs):
app = web.Application()
insert_to_config(app, conf, db_path)
app.on_startup.append(setup_db_schema)
2019-05-21 12:56:27 +02:00
app.on_startup.append(start_background_tasks)
app.on_shutdown.append(cleanup_background_tasks)
2019-07-20 15:06:34 +02:00
app.on_shutdown.append(close_comment_scheduler)
aiojobs.aiohttp.setup(app, **kwargs)
2019-07-22 14:10:21 +02:00
app.add_routes([
web.post('/api', api_endpoint),
web.get('/', get_api_endpoint),
web.get('/api', get_api_endpoint)
])
return app
2019-05-16 01:17:06 +02:00
2019-07-20 15:06:34 +02:00
def run_app(config):
appl = create_app(conf=config, db_path='DEFAULT', close_timeout=5.0)
try:
2019-07-20 15:06:34 +02:00
asyncio.run(web.run_app(appl, access_log=logging.getLogger('aiohttp.access'), host=config['HOST'], port=config['PORT']))
except asyncio.CancelledError:
pass
except ValueError:
pass