banmodel.py 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. import re
  2. from django.db import models
  3. from django.db.models import Q
  4. from django.utils import timezone
  5. BAN_NAME_EMAIL = 0
  6. BAN_NAME = 1
  7. BAN_EMAIL = 2
  8. BAN_IP = 3
  9. class BansManager(models.Manager):
  10. def check_ban(self, ip=False, username=False, email=False):
  11. bans_model = Ban.objects.filter(Q(expires=None) | Q(expires__gt=timezone.now()))
  12. if not (ip and username and email):
  13. if ip:
  14. bans_model.filter(test=BAN_IP)
  15. if username:
  16. bans_model.filter(test=BAN_NAME_EMAIL)
  17. bans_model.filter(test=BAN_NAME)
  18. if email:
  19. bans_model.filter(test=BAN_NAME_EMAIL)
  20. bans_model.filter(test=BAN_EMAIL)
  21. for ban in bans_model.order_by('-expires').iterator():
  22. if (
  23. # Check user name
  24. ((username and (ban.test == BAN_NAME_EMAIL or ban.test == BAN_NAME))
  25. and re.search('^' + re.escape(ban.ban).replace('\*', '(.*?)') + '$', username, flags=re.IGNORECASE))
  26. or # Check user email
  27. ((email and (ban.test == BAN_NAME_EMAIL or ban.test == BAN_EMAIL))
  28. and re.search('^' + re.escape(ban.ban).replace('\*', '(.*?)') + '$', email, flags=re.IGNORECASE))
  29. or # Check IP address
  30. (ip and ban.test == BAN_IP
  31. and re.search('^' + re.escape(ban.ban).replace('\*', '(.*?)') + '$', ip, flags=re.IGNORECASE))):
  32. return ban
  33. return False
  34. class Ban(models.Model):
  35. test = models.PositiveIntegerField(default=BAN_NAME_EMAIL)
  36. ban = models.CharField(max_length=255)
  37. reason_user = models.TextField(null=True, blank=True)
  38. reason_admin = models.TextField(null=True, blank=True)
  39. expires = models.DateTimeField(null=True, blank=True)
  40. objects = BansManager()
  41. class Meta:
  42. app_label = 'misago'
  43. class BanCache(object):
  44. def __init__(self):
  45. self.banned = False
  46. self.test = None
  47. self.expires = None
  48. self.reason_user = None
  49. self.version = 0
  50. def check_for_updates(self, request):
  51. if (self.version < request.monitor['bans_version']
  52. or (self.expires != None and self.expires < timezone.now())):
  53. self.version = request.monitor['bans_version']
  54. # Check Ban
  55. if request.user.is_authenticated():
  56. ban = Ban.objects.check_ban(
  57. ip=request.session.get_ip(request),
  58. username=request.user.username,
  59. email=request.user.email
  60. )
  61. else:
  62. ban = Ban.objects.check_ban(ip=request.session.get_ip(request))
  63. # Update ban cache
  64. if ban:
  65. self.banned = True
  66. self.reason_user = ban.reason_user
  67. self.expires = ban.expires
  68. self.test = ban.test
  69. else:
  70. self.banned = False
  71. self.reason_user = None
  72. self.expires = None
  73. self.test = None
  74. return True
  75. return False
  76. def is_banned(self):
  77. return self.banned