2022-11-18 05:57:57 -08:00
|
|
|
import logging
|
|
|
|
from django.dispatch import receiver
|
|
|
|
from django.contrib.auth.signals import user_login_failed
|
2023-05-26 18:16:49 +05:30
|
|
|
from utilities.request import get_client_ip
|
2022-11-18 05:57:57 -08:00
|
|
|
|
|
|
|
|
|
|
|
@receiver(user_login_failed)
|
|
|
|
def log_user_login_failed(sender, credentials, request, **kwargs):
|
|
|
|
logger = logging.getLogger('netbox.auth.login')
|
|
|
|
username = credentials.get("username")
|
2023-05-26 18:16:49 +05:30
|
|
|
if client_ip := get_client_ip(request):
|
|
|
|
logger.info(f"Failed login attempt for username: {username} from {client_ip}")
|
|
|
|
else:
|
|
|
|
logger.warning(
|
|
|
|
"Client IP address could not be determined for validation. Check that the HTTP server is properly "
|
|
|
|
"configured to pass the required header(s)."
|
|
|
|
)
|
|
|
|
logger.info(f"Failed login attempt for username: {username}")
|