Добавил логирование действии пользователей сайта (экспериментально)
This commit is contained in:
29
music_storage/logger/middleware.py
Normal file
29
music_storage/logger/middleware.py
Normal file
@@ -0,0 +1,29 @@
|
||||
from .models import AccessLog
|
||||
|
||||
|
||||
class AccessLogMiddleware:
|
||||
def __init__(self, get_response):
|
||||
self.get_response = get_response
|
||||
|
||||
def __call__(self, request):
|
||||
response = self.get_response(request)
|
||||
|
||||
user = getattr(request, "user", None)
|
||||
username = user.username if user and user.is_authenticated else "Anonymous"
|
||||
method = request.method
|
||||
path = request.get_full_path()
|
||||
ip_address = self.get_client_ip(request)
|
||||
|
||||
AccessLog.objects.create(
|
||||
username=username, method=method, path=path, ip_address=ip_address
|
||||
)
|
||||
|
||||
return response
|
||||
|
||||
def get_client_ip(self, request):
|
||||
x_forwarded_for = request.META.get("HTTP_X_FORWARDED_FOR")
|
||||
if x_forwarded_for:
|
||||
ip = x_forwarded_for.split(",")[0]
|
||||
else:
|
||||
ip = request.META.get("REMOTE_ADDR")
|
||||
return ip
|
||||
Reference in New Issue
Block a user