authbackends.py 1.1 KB

123456789101112131415161718192021222324252627282930
  1. from django.contrib.auth import get_user_model
  2. from django.contrib.auth.backends import ModelBackend
  3. UserModel = get_user_model()
  4. class MisagoBackend(ModelBackend):
  5. def authenticate(self, request, username=None, password=None, **kwargs):
  6. if kwargs.get('email'):
  7. username = kwargs['email'] # Bias to email if it was passed explictly
  8. try:
  9. user = UserModel.objects.get_by_username_or_email(username)
  10. except UserModel.DoesNotExist:
  11. # Run the default password hasher once to reduce the timing
  12. # difference between an existing and a non-existing user (#20760).
  13. UserModel().set_password(password)
  14. else:
  15. if user.check_password(password) and self.user_can_authenticate(user):
  16. return user
  17. def get_user(self, pk):
  18. try:
  19. manager = UserModel._default_manager
  20. relations = ('rank', 'online_tracker', 'ban_cache')
  21. user = manager.select_related(*relations).get(pk=pk)
  22. except UserModel.DoesNotExist:
  23. return None
  24. return user if self.user_can_authenticate(user) else None