OnlineJudge/account/middleware.py

35 lines
1.3 KiB
Python
Raw Normal View History

import time
2017-01-23 08:48:04 +00:00
2017-01-24 05:21:49 +00:00
import pytz
from django.contrib import auth
2017-01-24 05:21:49 +00:00
from django.utils import timezone
2017-01-23 08:48:04 +00:00
from django.utils.translation import ugettext as _
2016-11-19 04:32:23 +00:00
from utils.api import JSONResponse
2017-01-23 08:48:04 +00:00
class SessionSecurityMiddleware(object):
def process_request(self, request):
if request.user.is_authenticated() and request.user.is_admin_role():
if "last_activity" in request.session:
2016-07-31 12:26:11 +00:00
# 24 hours passed since last visit
if time.time() - request.session["last_activity"] >= 24 * 60 * 60:
auth.logout(request)
2016-11-19 04:32:23 +00:00
return JSONResponse.response({"error": "login-required", "data": _("Please login in first")})
2016-09-25 06:07:45 +00:00
# update last active time
request.session["last_activity"] = time.time()
2016-09-25 06:07:45 +00:00
class AdminRoleRequiredMiddleware(object):
2016-09-25 06:07:45 +00:00
def process_request(self, request):
path = request.path_info
if path.startswith("/admin/") or path.startswith("/api/admin/"):
if not(request.user.is_authenticated() and request.user.is_admin_role()):
2017-01-23 08:25:14 +00:00
return JSONResponse.response({"error": "login-required", "data": _("Please login in first")})
2017-01-24 05:21:49 +00:00
class TimezoneMiddleware(object):
def process_request(self, request):
if request.user.is_authenticated():
timezone.activate(pytz.timezone(request.user.userprofile.time_zone))