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

116 lines
3.3 KiB
Python
Raw Normal View History

2020-08-11 20:36:09 -04:00
import sys
2020-08-13 10:38:36 -04:00
import json
2020-08-11 20:36:09 -04:00
import logging
import tornado.web
import tornado.escape
from app.classes.shared.helpers import helper
from app.classes.web.base_handler import BaseHandler
from app.classes.shared.console import console
2020-08-13 10:38:36 -04:00
from app.classes.shared.models import Users, fn
2020-08-11 20:36:09 -04:00
logger = logging.getLogger(__name__)
try:
import bleach
except ModuleNotFoundError as e:
logger.critical("Import Error: Unable to load {} module".format(e, e.name))
console.critical("Import Error: Unable to load {} module".format(e, e.name))
sys.exit(1)
class PublicHandler(BaseHandler):
def set_current_user(self, user):
expire_days = helper.get_setting("WEB", 'cookie_expire')
# if helper comes back with false
if not expire_days:
expire_days = "5"
if user:
2020-08-13 10:38:36 -04:00
self.set_secure_cookie("user", tornado.escape.json_encode(user), expires_days=int(expire_days))
2020-08-11 20:36:09 -04:00
else:
self.clear_cookie("user")
def get(self, page=None):
self.clear_cookie("user")
self.clear_cookie("user_data")
page_data = {
'version': helper.get_version_string()
}
error = bleach.clean(self.get_argument('error', ""))
2020-08-11 20:36:09 -04:00
if error:
error_msg = "Invalid Login!"
else:
error_msg = ""
2020-08-13 10:38:36 -04:00
# sensible defaults
template = "public/404.html"
2020-08-11 20:36:09 -04:00
if page == "login":
template = "public/login.html"
page_data['error'] = error_msg
2020-08-11 20:36:09 -04:00
# if we have no page, let's go to login
2020-08-11 20:36:09 -04:00
else:
template = "public/404.html"
2020-08-11 20:36:09 -04:00
2020-08-13 10:38:36 -04:00
self.render(template, data=page_data)
2020-08-11 20:36:09 -04:00
def post(self, page=None):
if page == 'login':
next_page = "/public/login"
2020-08-13 10:38:36 -04:00
entered_username = bleach.clean(self.get_argument('username'))
entered_password = bleach.clean(self.get_argument('password'))
2020-08-13 10:38:36 -04:00
user_data = Users.get_or_none(fn.Lower(Users.username) == entered_username.lower())
2020-08-13 10:38:36 -04:00
# if we don't have a user
if not user_data:
next_page = "/public/login?error=Login_Failed"
self.redirect(next_page)
return False
2020-08-13 10:38:36 -04:00
# if they are disabled
if not user_data.enabled:
next_page = "/public/login?error=Login_Failed"
self.redirect(next_page)
return False
login_result = helper.verify_pass(entered_password, user_data.password)
# Valid Login
if login_result:
2020-08-13 10:38:36 -04:00
self.set_current_user(entered_username)
logger.info("User: {} Logged in from IP: {}".format(user_data, self.get_remote_ip()))
2020-08-13 10:38:36 -04:00
# record this login
Users.update({
2020-08-13 10:38:36 -04:00
Users.last_ip: self.get_remote_ip(),
Users.last_login: helper.get_time_as_string()
}).where(Users.username == entered_username).execute()
cookie_data = {
2020-08-13 10:38:36 -04:00
"username": user_data.username,
"user_id": user_data.id,
"account_type": user_data.allowed_servers,
}
self.set_secure_cookie('user_data', json.dumps(cookie_data))
2020-08-13 10:38:36 -04:00
next_page = "/panel/dashboard"
self.redirect(next_page)
else:
self.redirect("/public/login")