middleware.py 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. from django.conf import settings
  2. from django.contrib.auth import logout
  3. from django.contrib.auth.models import AnonymousUser as DjAnonymousUser
  4. from django.core.urlresolvers import resolve
  5. from django.utils import timezone
  6. from misago.users.bans import get_request_ip_ban, get_user_ban
  7. from misago.users.models import AnonymousUser, Online
  8. from misago.users.views import avatarserver
  9. class RealIPMiddleware(object):
  10. def process_request(self, request):
  11. x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')
  12. if x_forwarded_for:
  13. request._misago_real_ip = x_forwarded_for.split(',')[0]
  14. else:
  15. request._misago_real_ip = request.META.get('REMOTE_ADDR')
  16. class AvatarServerMiddleware(object):
  17. def process_request(self, request):
  18. if request.path.startswith(settings.MISAGO_AVATAR_SERVER_PATH):
  19. request.user = DjAnonymousUser()
  20. resolved_path = resolve(request.path)
  21. return resolved_path.func(request, **resolved_path.kwargs)
  22. class UserMiddleware(object):
  23. def process_request(self, request):
  24. if request.user.is_anonymous():
  25. request.user = AnonymousUser()
  26. elif not request.user.is_superuser:
  27. if get_request_ip_ban(request) or get_user_ban(request.user):
  28. logout(request)
  29. request.user.ip = request._misago_real_ip
  30. class OnlineTrackerMiddleware(object):
  31. def process_request(self, request):
  32. if request.user.is_authenticated():
  33. try:
  34. request._misago_online_tracker = request.user.online_tracker
  35. except Online.DoesNotExist:
  36. online_tracker = Online.objects.create(
  37. user=request.user, current_ip=request._misago_real_ip)
  38. request.user.online_tracker = online_tracker
  39. request._misago_online_tracker = online_tracker
  40. else:
  41. request._misago_online_tracker = None
  42. def process_response(self, request, response):
  43. if hasattr(request, '_misago_online_tracker'):
  44. tracker = request._misago_online_tracker
  45. if tracker:
  46. if request.user.is_anonymous():
  47. # User logged off, update his last visit and blam tracker
  48. user = tracker.user
  49. user.last_login = tracker.last_click
  50. user.last_ip = tracker.current_ip
  51. user.save(update_fields=['last_login', 'last_ip'])
  52. tracker.delete()
  53. else:
  54. # Bump user's tracker time
  55. tracker.current_ip = request._misago_real_ip
  56. tracker.last_click = timezone.now()
  57. tracker.save(update_fields=['last_click', 'current_ip'])
  58. return response