middleware.py 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. import pytz
  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.conf import settings
  7. from misago.users.bans import get_request_ip_ban, get_user_ban
  8. from misago.users.models import AnonymousUser, Online
  9. from misago.users.online import tracker
  10. class RealIPMiddleware(object):
  11. def process_request(self, request):
  12. x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')
  13. if x_forwarded_for:
  14. request.user_ip = x_forwarded_for.split(',')[0]
  15. else:
  16. request.user_ip = request.META.get('REMOTE_ADDR')
  17. class AvatarServerMiddleware(object):
  18. def process_request(self, request):
  19. if request.path_info.startswith(settings.MISAGO_AVATAR_SERVER_PATH):
  20. request.user = DjAnonymousUser()
  21. resolved_path = resolve(request.path_info)
  22. return resolved_path.func(request, **resolved_path.kwargs)
  23. class UserMiddleware(object):
  24. def process_request(self, request):
  25. if request.user.is_anonymous():
  26. request.user = AnonymousUser()
  27. elif not request.user.is_superuser:
  28. if get_request_ip_ban(request) or get_user_ban(request.user):
  29. logout(request)
  30. class TimezoneMiddleware(object):
  31. def process_request(self, request):
  32. if request.user.is_authenticated():
  33. timezone.activate(pytz.timezone(request.user.timezone))
  34. else:
  35. timezone.activate(pytz.timezone(settings.default_timezone))
  36. current_tz = timezone.get_current_timezone()
  37. utc_offset = current_tz.normalize(timezone.now()).utcoffset()
  38. utc_offset_seconds = int(utc_offset.total_seconds())
  39. request.preloaded_ember_data['utcOffset'] = utc_offset_seconds
  40. class PreloadUserMiddleware(object):
  41. def process_request(self, request):
  42. request.preloaded_ember_data.update({
  43. 'isAuthenticated': request.user.is_authenticated(),
  44. })
  45. if request.user.is_authenticated():
  46. request.preloaded_ember_data.update({
  47. 'user': {
  48. 'username': request.user.username,
  49. 'isAuthenticated': True,
  50. 'isAnonymous': False
  51. }
  52. })
  53. else:
  54. request.preloaded_ember_data.update({
  55. 'user': {
  56. 'isAuthenticated': False,
  57. 'isAnonymous': True,
  58. }
  59. })
  60. class OnlineTrackerMiddleware(object):
  61. def process_request(self, request):
  62. if request.user.is_authenticated():
  63. try:
  64. request._misago_online_tracker = request.user.online_tracker
  65. except Online.DoesNotExist:
  66. tracker.start_tracking(request, request.user)
  67. else:
  68. request._misago_online_tracker = None
  69. def process_response(self, request, response):
  70. if hasattr(request, '_misago_online_tracker'):
  71. online_tracker = request._misago_online_tracker
  72. if online_tracker:
  73. if request.user.is_anonymous():
  74. tracker.stop_tracking(request, online_tracker)
  75. else:
  76. tracker.update_tracker(request, online_tracker)
  77. return response