crafty-4/app/classes/web/api_handler.py

60 lines
1.9 KiB
Python
Raw Normal View History

2020-09-06 04:13:42 +00:00
import os
import secrets
import threading
import tornado.web
import tornado.escape
import logging
from app.classes.web.base_handler import BaseHandler
2020-09-06 04:13:42 +00:00
from app.classes.shared.models import Users
log = logging.getLogger(__name__)
class ApiHandler(BaseHandler):
2020-09-06 04:13:42 +00:00
def return_response(self, data: dict):
# Define a standardized response
self.write(data)
def access_denied(self, user):
log.info("User %s was denied access to API route", user)
self.set_status(403)
self.finish(self.return_response(403, {'error':'ACCESS_DENIED', 'info':'You were denied access to the requested resource'}))
2020-09-06 04:58:17 +00:00
def authenticate_user(self):
2020-09-06 04:13:42 +00:00
try:
log.debug("Searching for specified token")
# TODO: YEET THIS
2020-09-06 04:58:17 +00:00
user_data = Users.get(api_token=self.get_argument('token'))
2020-09-06 04:13:42 +00:00
log.debug("Checking results")
if user_data:
2020-09-06 04:58:17 +00:00
# Login successful! Check perms
2020-09-06 04:13:42 +00:00
log.info("User {} has authenticated to API".format(user_data.username))
2020-09-06 04:58:17 +00:00
# TODO: Role check
2020-09-06 04:13:42 +00:00
else:
logging.debug("Auth unsuccessful")
2020-09-06 04:58:17 +00:00
return self.access_denied("unknown")
2020-09-06 04:13:42 +00:00
except:
log.warning("Traceback occurred when authenticating user to API. Most likely wrong token")
2020-09-06 04:58:17 +00:00
return self.access_denied("unknown")
2020-09-06 04:13:42 +00:00
pass
2020-09-06 04:58:17 +00:00
class ServersStats(ApiHandler):
2020-09-06 04:58:17 +00:00
def get(self):
"""Get details about all servers"""
self.authenticate_user()
# Get server stats
self.finish(self.write({"servers": self.controller.stats.get_servers_stats()}))
2020-09-06 04:58:17 +00:00
class NodeStats(ApiHandler):
2020-09-06 04:58:17 +00:00
def get(self):
"""Get stats for particular node"""
self.authenticate_user()
# Get node stats
node_stats = self.controller.stats.get_node_stats()
2020-09-06 04:58:17 +00:00
node_stats.pop("servers")
self.finish(self.write(node_stats))