comment-server/src/server/handles.py

128 lines
4 KiB
Python
Raw Normal View History

import asyncio
2019-05-21 07:54:52 -04:00
import logging
import time
2019-05-21 07:54:52 -04:00
2019-05-20 06:49:08 -04:00
from aiohttp import web
2019-05-21 07:54:52 -04:00
from aiojobs.aiohttp import atomic
2019-12-31 04:59:58 -05:00
import src.database.queries as db
2019-12-31 00:41:35 -05:00
from src.database.writes import abandon_comment, create_comment
from src.database.writes import hide_comments
2019-12-31 04:59:58 -05:00
from src.database.writes import edit_comment
from src.server.misc import clean_input_params
from src.server.errors import make_error, report_error
2019-05-21 06:56:27 -04:00
logger = logging.getLogger(__name__)
2019-05-20 06:49:08 -04:00
# noinspection PyUnusedLocal
def ping(*args):
return 'pong'
2019-05-20 06:49:08 -04:00
def handle_get_channel_from_comment_id(app, kwargs: dict):
2019-12-31 04:59:58 -05:00
return db.get_channel_id_from_comment_id(app['reader'], **kwargs)
2019-05-20 06:49:08 -04:00
def handle_get_comment_ids(app, kwargs):
2019-12-31 04:59:58 -05:00
return db.get_comment_ids(app['reader'], **kwargs)
2019-05-20 06:49:08 -04:00
def handle_get_claim_comments(app, kwargs):
2019-12-31 04:59:58 -05:00
return db.get_claim_comments(app['reader'], **kwargs)
2019-05-20 06:49:08 -04:00
def handle_get_comments_by_id(app, kwargs):
2019-12-31 04:59:58 -05:00
return db.get_comments_by_id(app['reader'], **kwargs)
def handle_get_claim_hidden_comments(app, kwargs):
2019-12-31 04:59:58 -05:00
return db.get_claim_hidden_comments(app['reader'], **kwargs)
2019-05-20 06:49:08 -04:00
async def handle_abandon_comment(app, params):
2019-12-31 00:41:35 -05:00
return {'abandoned': await abandon_comment(app, **params)}
2019-05-20 06:49:08 -04:00
async def handle_hide_comments(app, params):
2019-12-31 00:41:35 -05:00
return {'hidden': await hide_comments(app, **params)}
async def handle_edit_comment(app, params):
2019-12-31 04:59:58 -05:00
if await edit_comment(app, **params):
return db.get_comment_or_none(app['reader'], params['comment_id'])
2019-05-20 06:49:08 -04:00
METHODS = {
'ping': ping,
'get_claim_comments': handle_get_claim_comments,
'get_claim_hidden_comments': handle_get_claim_hidden_comments,
2019-05-20 06:49:08 -04:00
'get_comment_ids': handle_get_comment_ids,
'get_comments_by_id': handle_get_comments_by_id,
'get_channel_from_comment_id': handle_get_channel_from_comment_id,
'create_comment': create_comment,
'delete_comment': handle_abandon_comment,
'abandon_comment': handle_abandon_comment,
2019-12-31 00:41:35 -05:00
'hide_comments': handle_hide_comments,
'edit_comment': handle_edit_comment
2019-05-20 06:49:08 -04:00
}
2019-05-21 05:00:01 -04:00
async def process_json(app, body: dict) -> dict:
2019-05-20 06:49:08 -04:00
response = {'jsonrpc': '2.0', 'id': body['id']}
if body['method'] in METHODS:
method = body['method']
params = body.get('params', {})
clean_input_params(params)
2019-07-20 09:06:34 -04:00
logger.debug(f'Received Method {method}, params: {params}')
start = time.time()
2019-05-20 06:49:08 -04:00
try:
2019-05-21 05:00:01 -04:00
if asyncio.iscoroutinefunction(METHODS[method]):
result = await METHODS[method](app, params)
2019-05-20 06:49:08 -04:00
else:
result = METHODS[method](app, params)
2019-05-20 06:49:08 -04:00
response['result'] = result
2019-07-20 09:06:34 -04:00
except Exception as err:
2019-09-06 20:27:14 -04:00
logger.exception(f'Got {type(err).__name__}:')
if type(err) in (ValueError, TypeError): # param error, not too important
response['error'] = make_error('INVALID_PARAMS', err)
2019-07-20 09:06:34 -04:00
else:
response['error'] = make_error('INTERNAL', err)
await app['webhooks'].spawn(report_error(app, err))
2019-09-06 20:27:14 -04:00
2019-07-22 11:10:55 -04:00
finally:
end = time.time()
logger.debug(f'Time taken to process {method}: {end - start} secs')
2019-05-20 06:49:08 -04:00
else:
2019-07-20 09:10:14 -04:00
response['error'] = make_error('METHOD_NOT_FOUND')
2019-05-20 06:49:08 -04:00
return response
2019-05-21 05:00:01 -04:00
@atomic
async def api_endpoint(request: web.Request):
2019-05-20 06:49:08 -04:00
try:
web.access_logger.info(f'Forwarded headers: {request.remote}')
logging.debug(f'Request: {request}')
for k, v in request.items():
logging.debug(f'{k}: {v}')
body = await request.json()
2019-05-20 06:49:08 -04:00
if type(body) is list or type(body) is dict:
if type(body) is list:
# for batching
2019-05-21 05:00:01 -04:00
return web.json_response(
[await process_json(request.app, part) for part in body]
)
2019-05-20 06:49:08 -04:00
else:
2019-05-21 05:00:01 -04:00
return web.json_response(await process_json(request.app, body))
except Exception as e:
return make_error('INVALID_REQUEST', e)
2019-07-22 08:10:21 -04:00
async def get_api_endpoint(request: web.Request):
return web.json_response({
'text': 'OK',
'is_running': True,
2019-08-24 00:19:11 -04:00
'uptime': int(time.time()) - request.app['start_time']
2019-07-22 08:10:21 -04:00
})