mirror of
https://github.com/norohind/SquadsActivityMonitor.git
synced 2025-04-13 05:17:12 +03:00
184 lines
6.0 KiB
Python
184 lines
6.0 KiB
Python
from model import model
|
|
import json
|
|
import falcon
|
|
import os
|
|
from EDMCLogging import get_main_logger
|
|
import utils
|
|
from model.sqlite_cache import cache
|
|
from templates_engine import render
|
|
|
|
"""
|
|
/leaderboard/{leaderboard_type}/platform/{platform}?[limit=<int>
|
|
&after=<timestamp (as "Timestamp UTC" column format)>&after=<timestamp (as "Timestamp UTC" column format)>]
|
|
|
|
leaderboard_type - one of
|
|
powerplay
|
|
cqc
|
|
trade
|
|
exploration
|
|
aegis
|
|
bgs
|
|
combat
|
|
|
|
platform - one of
|
|
XBOX
|
|
PS4
|
|
PC
|
|
"""
|
|
|
|
logger = get_main_logger()
|
|
|
|
model.open_model()
|
|
|
|
|
|
class Activity:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, leaderboard: str, platform: str)\
|
|
-> None:
|
|
resp.content_type = falcon.MEDIA_JSON
|
|
|
|
args_activity_changes = {
|
|
'platform': platform,
|
|
'leaderboard_type': leaderboard,
|
|
'limit': req.params.get('limit', 10),
|
|
'high_timestamp': req.params.get('before', '3307-12-12'),
|
|
'low_timestamp': req.params.get('after', '0001-01-01')
|
|
}
|
|
|
|
try:
|
|
resp.text = json.dumps(model.get_activity_changes(**args_activity_changes))
|
|
|
|
except Exception as e:
|
|
logger.warning(
|
|
f'Exception occurred during executing Activity request, args:\n{args_activity_changes}',
|
|
exc_info=e
|
|
)
|
|
raise falcon.HTTPInternalServerError(description=str(e))
|
|
|
|
|
|
class ActivityHtml:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, leaderboard: str, platform: str)\
|
|
-> None:
|
|
resp.content_type = falcon.MEDIA_HTML
|
|
|
|
resp.text = render(
|
|
'table_template.html',
|
|
{
|
|
'target_column_name': 'ActionId',
|
|
'target_new_url': '/diff/',
|
|
})
|
|
|
|
|
|
class ActivityDiff:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, action_id: int) -> None:
|
|
"""
|
|
Give squads tags and diff in their experience for specified action_id - 1 (smart -1)
|
|
|
|
:param action_id:
|
|
:param req:
|
|
:param resp:
|
|
:return:
|
|
"""
|
|
|
|
resp.content_type = falcon.MEDIA_JSON
|
|
resp.text = json.dumps(model.get_diff_action_id(action_id))
|
|
|
|
|
|
class ActivityDiffHtml:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, action_id: int) -> None:
|
|
resp.content_type = falcon.MEDIA_HTML
|
|
resp.text = render(
|
|
'table_template.html',
|
|
{
|
|
'target_column_name': 'Tag',
|
|
'target_new_url': '/squads/now/by-tag/short/'
|
|
}
|
|
)
|
|
|
|
|
|
class SumLeaderboardHistory:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, leaderboard: str, platform: str)\
|
|
-> None:
|
|
resp.content_type = falcon.MEDIA_JSON
|
|
|
|
try:
|
|
resp.text = json.dumps(model.get_leaderboard_sum_history(platform, leaderboard))
|
|
|
|
except Exception as e:
|
|
logger.warning(
|
|
f'Exception occurred during executing history request, LB: {leaderboard!r}; platform: {platform!r}',
|
|
exc_info=e
|
|
)
|
|
raise falcon.HTTPInternalServerError(description=str(e))
|
|
|
|
|
|
class SumLeaderboardHistoryHtml:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, leaderboard: str, platform: str)\
|
|
-> None:
|
|
resp.content_type = falcon.MEDIA_HTML
|
|
resp.text = render(
|
|
'graph_template.html',
|
|
{
|
|
'dataset_title': f'{leaderboard} {platform} points sum'
|
|
}
|
|
)
|
|
|
|
|
|
class LeaderboardByActionID:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, action_id: int) -> None:
|
|
resp.content_type = falcon.MEDIA_JSON
|
|
resp.text = json.dumps(model.get_leaderboard_by_action_id(action_id))
|
|
|
|
|
|
class LeaderboardByActionIDHTML:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response, action_id: int) -> None:
|
|
resp.content_type = falcon.MEDIA_HTML
|
|
resp.text = render(
|
|
'table_template.html',
|
|
{
|
|
'target_column_name': 'Tag',
|
|
'target_new_url': '/api/leaderboard-state/by-action-id/'
|
|
}
|
|
)
|
|
|
|
|
|
class MainPage:
|
|
def on_get(self, req: falcon.request.Request, resp: falcon.response.Response) -> None:
|
|
raise falcon.HTTPMovedPermanently('/index.html')
|
|
|
|
|
|
class Cache:
|
|
def on_post(self, req: falcon.request.Request, resp: falcon.response.Response, action: str) -> None:
|
|
if action.lower() == 'drop':
|
|
cache.delete_all()
|
|
resp.status = falcon.HTTP_204
|
|
return
|
|
|
|
raise falcon.HTTPNotFound
|
|
|
|
|
|
app = falcon.App()
|
|
app.add_route('/api/leaderboard/{leaderboard}/platform/{platform}', Activity())
|
|
app.add_route('/api/diff/{action_id}', ActivityDiff())
|
|
app.add_route('/api/leaderboard-history/leaderboard/{leaderboard}/platform/{platform}', SumLeaderboardHistory())
|
|
app.add_route('/api/leaderboard-state/by-action-id/{action_id}', LeaderboardByActionID())
|
|
|
|
app.add_route('/leaderboard/{leaderboard}/platform/{platform}', ActivityHtml())
|
|
app.add_route('/diff/{action_id}', ActivityDiffHtml())
|
|
app.add_route('/leaderboard-history/leaderboard/{leaderboard}/platform/{platform}', SumLeaderboardHistoryHtml())
|
|
app.add_route('/leaderboard-state/by-action-id/{action_id}', LeaderboardByActionIDHTML())
|
|
|
|
|
|
app.add_route('/api/cache/{action}', Cache())
|
|
|
|
app.add_route('/', MainPage())
|
|
|
|
application = app # for uwsgi
|
|
|
|
|
|
if __name__ == '__main__':
|
|
import waitress
|
|
|
|
app.add_static_route('/js', os.path.join(os.path.join(os.path.dirname(os.path.abspath(__file__)), 'static'), 'js'))
|
|
app.add_static_route('/', os.path.join(os.path.dirname(os.path.abspath(__file__)), 'static'))
|
|
waitress.serve(app, host='127.0.0.1', port=9485)
|