33 lines
992 B
Python

import logging
from django.conf import settings
from python_ipware import IpWare
logger = logging.getLogger("paperless.auth")
# https://docs.djangoproject.com/en/4.1/ref/contrib/auth/#django.contrib.auth.signals.user_login_failed
def handle_failed_login(sender, credentials, request, **kwargs):
ipware = IpWare(proxy_list=settings.TRUSTED_PROXIES)
client_ip, _ = ipware.get_client_ip(
meta=request.META,
)
username = credentials.get("username")
log_output = (
"No authentication provided"
if username is None
else f"Login failed for user `{username}`"
)
if client_ip is None:
log_output += ". Unable to determine IP address."
else:
if client_ip.is_global:
# We got the client's IP address
log_output += f" from IP `{client_ip}`."
else:
# The client's IP address is private
log_output += f" from private IP `{client_ip}`."
logger.info(log_output)