2020-09-06 04:13:42 +00:00
|
|
|
import os
|
|
|
|
import secrets
|
|
|
|
import threading
|
|
|
|
import tornado.web
|
|
|
|
import tornado.escape
|
|
|
|
import logging
|
|
|
|
|
2021-03-22 04:02:18 +00:00
|
|
|
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__)
|
|
|
|
|
|
|
|
|
2021-03-22 04:02:18 +00:00
|
|
|
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")
|
2021-03-22 04:02:18 +00:00
|
|
|
# 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
|
|
|
|
2021-03-22 04:02:18 +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
|
2021-03-22 04:02:18 +00:00
|
|
|
self.finish(self.write({"servers": self.controller.stats.get_servers_stats()}))
|
2020-09-06 04:58:17 +00:00
|
|
|
|
|
|
|
|
2021-03-22 04:02:18 +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
|
2021-03-22 04:02:18 +00:00
|
|
|
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))
|