mirror of
https://gitlab.com/crafty-controller/crafty-4.git
synced 2024-08-30 18:23:09 +00:00
Merge branch 'dev-FixingLoginAndLogoutCookies' into 'dev'
Fixing Cookies at Logout See merge request crafty-controller/crafty-commander!210
This commit is contained in:
commit
e8951848e4
@ -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')
|
||||
|
@ -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>
|
||||
|
Loading…
Reference in New Issue
Block a user