OnlineJudge/account/middleware.py

39 lines
1.5 KiB
Python
Raw Normal View History

from django.db import connection
2017-10-06 17:46:14 +08:00
from django.utils.timezone import now
from django.utils.deprecation import MiddlewareMixin
2016-11-19 12:32:23 +08:00
from utils.api import JSONResponse
2017-01-23 16:48:04 +08:00
class SessionRecordMiddleware(MiddlewareMixin):
def process_request(self, request):
if request.user.is_authenticated():
session = request.session
2017-10-06 17:46:14 +08:00
session["user_agent"] = request.META.get("HTTP_USER_AGENT", "")
2017-10-21 20:39:39 +08:00
session["ip"] = request.META.get("HTTP_X_REAL_IP", request.META.get("REMOTE_ADDR"))
2017-10-06 17:46:14 +08:00
session["last_activity"] = now()
user_sessions = request.user.session_keys
2017-10-06 17:46:14 +08:00
if session.session_key not in user_sessions:
user_sessions.append(session.session_key)
request.user.save()
class AdminRoleRequiredMiddleware(MiddlewareMixin):
2016-09-25 14:07:45 +08: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-10-02 04:33:43 +08:00
return JSONResponse.response({"error": "login-required", "data": "Please login in first"})
class LogSqlMiddleware(MiddlewareMixin):
def process_response(self, request, response):
print("\033[94m", "#" * 30, "\033[0m")
time_threshold = 0.03
for query in connection.queries:
if float(query["time"]) > time_threshold:
print("\033[93m", query, "\n", "-" * 30, "\033[0m")
else:
print(query, "\n", "-" * 30)
return response