Merge branch 'dev-FixingLoginAndLogoutCookies' into 'dev'

Fixing Cookies at Logout

See merge request crafty-controller/crafty-commander!210
This commit is contained in:
Andrew 2022-03-14 23:10:22 +00:00
commit e8951848e4
2 changed files with 64 additions and 16 deletions

View File

@ -27,7 +27,9 @@ class PublicHandler(BaseHandler):
if user_id is not None:
self.set_cookie("token", authentication.generate(user_id), expires_days=int(expire_days))
else:
self.clear_cookie("user")
self.clear_cookie("token")
#self.clear_cookie("user")
#self.clear_cookie("user_data")
def get(self, page=None):
@ -37,8 +39,11 @@ class PublicHandler(BaseHandler):
page_data = {
'version': helper.get_version_string(),
'error': error, 'lang': helper.get_setting('language'),
'lang_page': helper.getLangPage(helper.get_setting('language'))
'lang_page': helper.getLangPage(helper.get_setting('language')),
'query': ""
}
if (self.request.query):
page_data['query'] = self.request.query
# sensible defaults
template = "public/404.html"
@ -53,14 +58,18 @@ class PublicHandler(BaseHandler):
template = "public/error.html"
elif page == "logout":
self.clear_cookie("user")
self.clear_cookie("user_data")
self.clear_cookie("token")
#self.clear_cookie("user")
#self.clear_cookie("user_data")
self.redirect('/public/login')
return
# if we have no page, let's go to login
else:
self.redirect('/public/login')
if (self.request.query):
self.redirect('/public/login?'+self.request.query)
else:
self.redirect('/public/login')
return
self.render(
@ -72,8 +81,23 @@ class PublicHandler(BaseHandler):
def post(self, page=None):
error = bleach.clean(self.get_argument('error', "Invalid Login!"))
error_msg = bleach.clean(self.get_argument('error_msg', ''))
page_data = {
'version': helper.get_version_string(),
'error': error, 'lang': helper.get_setting('language'),
'lang_page': helper.getLangPage(helper.get_setting('language')),
'query': ""
}
if (self.request.query):
page_data['query'] = self.request.query
if page == 'login':
next_page = "/public/login"
if (self.request.query):
next_page = '/public/login?'+self.request.query
entered_username = bleach.clean(self.get_argument('username'))
entered_password = bleach.clean(self.get_argument('password'))
@ -85,17 +109,25 @@ class PublicHandler(BaseHandler):
# if we don't have a user
if not user_data:
error_msg = "Incorrect username or password. Please try again."
self.clear_cookie("user")
self.clear_cookie("user_data")
self.redirect(f'/public/login?error_msg={error_msg}')
#self.clear_cookie("user")
#self.clear_cookie("user_data")
self.clear_cookie("token")
if (self.request.query):
self.redirect(f'/public/login?error_msg={error_msg}&{self.request.query}')
else:
self.redirect(f'/public/login?error_msg={error_msg}')
return
# if they are disabled
if not user_data.enabled:
error_msg = "User account disabled. Please contact your system administrator for more info."
self.clear_cookie("user")
self.clear_cookie("user_data")
self.redirect(f'/public/login?error_msg={error_msg}')
#self.clear_cookie("user")
#self.clear_cookie("user_data")
self.clear_cookie("token")
if (self.request.query):
self.redirect(f'/public/login?error_msg={error_msg}&{self.request.query}')
else:
self.redirect(f'/public/login?error_msg={error_msg}')
return
login_result = helper.verify_pass(entered_password, user_data.password)
@ -114,14 +146,26 @@ class PublicHandler(BaseHandler):
# log this login
self.controller.management.add_to_audit_log(user_data.user_id, "Logged in", 0, self.get_remote_ip())
next_page = "/panel/dashboard"
if (self.request.query_arguments.get('next')):
next_page = self.request.query_arguments.get('next')[0].decode()
else:
next_page = "/panel/dashboard"
self.redirect(next_page)
else:
self.clear_cookie("user")
self.clear_cookie("user_data")
#self.clear_cookie("user")
#self.clear_cookie("user_data")
self.clear_cookie("token")
error_msg = "Inncorrect username or password. Please try again."
# log this failed login attempt
self.controller.management.add_to_audit_log(user_data.user_id, "Tried to log in", 0, self.get_remote_ip())
self.redirect(f'/public/login?error_msg={error_msg}')
if (self.request.query):
self.redirect(f'/public/login?error_msg={error_msg}&{self.request.query}')
else:
self.redirect(f'/public/login?error_msg={error_msg}')
else:
self.redirect("/public/login")
if (self.request.query):
self.redirect('/public/login?'+self.request.query)
else:
self.redirect('/public/login')

View File

@ -55,7 +55,11 @@
box-shadow: 0 12px 16px 0 hsla(0, 0%, 0%, 0.4);
}
</style>
{% if data['query'] %}
<form action="/public/login?{{ data['query'] }}" method="post">
{% else %}
<form action="/public/login" method="post">
{% end %}
{% raw xsrf_form_html() %}
<div class="form-group">
<label class="label">{{ translate('login', 'username', data['lang']) }}</label>