models.py 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. from django.db import models
  2. from django.utils import timezone
  3. from django.utils.translation import ugettext_lazy as _
  4. from misago.utils import slugify
  5. class ThreadManager(models.Manager):
  6. def filter_stats(self, start, end):
  7. return self.filter(start__gte=start).filter(start__lte=end)
  8. class Thread(models.Model):
  9. forum = models.ForeignKey('forums.Forum')
  10. weight = models.PositiveIntegerField(default=0,db_index=True)
  11. type = models.PositiveIntegerField(default=0)
  12. name = models.CharField(max_length=255)
  13. slug = models.SlugField(max_length=255)
  14. replies = models.PositiveIntegerField(default=0)
  15. replies_reported = models.PositiveIntegerField(default=0)
  16. replies_moderated = models.PositiveIntegerField(default=0)
  17. replies_deleted = models.PositiveIntegerField(default=0)
  18. merges = models.PositiveIntegerField(default=0,db_index=True)
  19. score = models.PositiveIntegerField(default=30,db_index=True)
  20. upvotes = models.PositiveIntegerField(default=0)
  21. downvotes = models.PositiveIntegerField(default=0)
  22. start = models.DateTimeField(db_index=True)
  23. start_post = models.ForeignKey('Post',related_name='+',null=True,blank=True,on_delete=models.SET_NULL)
  24. start_poster = models.ForeignKey('users.User',null=True,blank=True)
  25. start_poster_name = models.CharField(max_length=255)
  26. start_poster_slug = models.SlugField(max_length=255)
  27. start_poster_style = models.CharField(max_length=255)
  28. last = models.DateTimeField(db_index=True)
  29. last_post = models.ForeignKey('Post',related_name='+',null=True,blank=True,on_delete=models.SET_NULL)
  30. last_poster = models.ForeignKey('users.User',related_name='+',null=True,blank=True)
  31. last_poster_name = models.CharField(max_length=255,null=True,blank=True)
  32. last_poster_slug = models.SlugField(max_length=255,null=True,blank=True)
  33. last_poster_style = models.CharField(max_length=255,null=True,blank=True)
  34. moderated = models.BooleanField(default=False,db_index=True)
  35. deleted = models.BooleanField(default=False,db_index=True)
  36. closed = models.BooleanField(default=False)
  37. objects = ThreadManager()
  38. statistics_name = _('New Threads')
  39. def get_date(self):
  40. return self.start
  41. def sync(self):
  42. # First post
  43. start_post = self.post_set.order_by('merge', 'id')[1:][0]
  44. self.start = start_post.date
  45. self.start_post = start_post
  46. self.start_poster = start_post.user
  47. self.start_poster_name = start_post.user_name
  48. self.start_poster_slug = slugify(start_post.user_name)
  49. self.start_poster_style = start_post.user.rank.style if start_post.user else None
  50. self.upvotes = start_post.upvotes
  51. self.downvotes = start_post.downvotes
  52. # Last post
  53. last_post = self.post_set.order_by('-merge', '-id')[1:][0]
  54. self.last = last_post.date
  55. self.last_post = last_post
  56. self.last_poster = last_post.user
  57. self.last_poster_name = last_post.user_name
  58. self.last_poster_slug = slugify(last_post.user_name)
  59. self.last_poster_style = last_post.user.rank.style if last_post.user else None
  60. # Flags
  61. self.moderated = start_post.moderated
  62. self.deleted = start_post.deleted
  63. self.merges = last_post.merge
  64. # Counters
  65. self.replies = self.post_set.filter(moderated=False).filter(deleted=False).count() - 1
  66. self.replies_reported = self.post_set.filter(reported=True).count()
  67. self.replies_moderated = self.post_set.filter(moderated=True).count()
  68. self.replies_deleted = self.post_set.filter(deleted=True).count()
  69. class PostManager(models.Manager):
  70. def filter_stats(self, start, end):
  71. return self.filter(date__gte=start).filter(date__lte=end)
  72. class Post(models.Model):
  73. forum = models.ForeignKey('forums.Forum')
  74. thread = models.ForeignKey(Thread)
  75. merge = models.PositiveIntegerField(default=0,db_index=True)
  76. user = models.ForeignKey('users.User',null=True,blank=True)
  77. user_name = models.CharField(max_length=255)
  78. ip = models.GenericIPAddressField()
  79. agent = models.CharField(max_length=255)
  80. post = models.TextField()
  81. post_preparsed = models.TextField()
  82. upvotes = models.PositiveIntegerField(default=0)
  83. downvotes = models.PositiveIntegerField(default=0)
  84. date = models.DateTimeField()
  85. edits = models.PositiveIntegerField(default=0)
  86. edit_date = models.DateTimeField(null=True,blank=True)
  87. edit_reason = models.CharField(max_length=255,null=True,blank=True)
  88. edit_user = models.ForeignKey('users.User',related_name='+',null=True)
  89. edit_user_name = models.CharField(max_length=255,null=True,blank=True)
  90. edit_user_slug = models.SlugField(max_length=255,null=True,blank=True)
  91. reported = models.BooleanField(default=False)
  92. moderated = models.BooleanField(default=False,db_index=True)
  93. deleted = models.BooleanField(default=False,db_index=True)
  94. protected = models.BooleanField(default=False)
  95. objects = PostManager()
  96. statistics_name = _('New Posts')
  97. def get_date(self):
  98. return self.date
  99. def set_checkpoint(self, request, action):
  100. if request.user.is_authenticated():
  101. self.checkpoint_set.create(
  102. forum=self.forum,
  103. thread=self.thread,
  104. post=self,
  105. action=action,
  106. user=request.user,
  107. user_name=request.user.username,
  108. user_slug=request.user.username_slug,
  109. date=timezone.now(),
  110. ip=request.session.get_ip(request),
  111. agent=request.META.get('HTTP_USER_AGENT'),
  112. )
  113. class Change(models.Model):
  114. forum = models.ForeignKey('forums.Forum')
  115. thread = models.ForeignKey(Thread)
  116. post = models.ForeignKey(Post)
  117. user = models.ForeignKey('users.User',null=True,blank=True)
  118. user_name = models.CharField(max_length=255)
  119. user_slug = models.CharField(max_length=255)
  120. date = models.DateTimeField()
  121. ip = models.GenericIPAddressField()
  122. agent = models.CharField(max_length=255)
  123. reason = models.CharField(max_length=255,null=True,blank=True)
  124. thread_name_new = models.CharField(max_length=255,null=True,blank=True)
  125. thread_name_old = models.CharField(max_length=255,null=True,blank=True)
  126. post_content = models.TextField()
  127. size = models.IntegerField(default=0)
  128. change = models.IntegerField(default=0)
  129. class Checkpoint(models.Model):
  130. forum = models.ForeignKey('forums.Forum')
  131. thread = models.ForeignKey(Thread)
  132. post = models.ForeignKey(Post)
  133. action = models.CharField(max_length=255)
  134. user = models.ForeignKey('users.User',null=True,blank=True)
  135. user_name = models.CharField(max_length=255)
  136. user_slug = models.CharField(max_length=255)
  137. date = models.DateTimeField()
  138. ip = models.GenericIPAddressField()
  139. agent = models.CharField(max_length=255)