changeset 348:d1b11096595b

Fix #168; when nailing a spammer, clear their profile text fields. Guard against topics and forums that don't exist when deleting posts in the signal handler. Make the forum stats template tag only display the latest active users.
author Brian Neal <bgneal@gmail.com>
date Wed, 02 Mar 2011 02:18:28 +0000 (2011-03-02)
parents 69d0306a6fe7
children a43add8af83d
files gpp/accounts/admin.py gpp/bio/admin.py gpp/forums/signals.py gpp/forums/templatetags/forum_tags.py gpp/forums/tools.py gpp/forums/views/spam.py
diffstat 6 files changed, 32 insertions(+), 11 deletions(-) [+]
line wrap: on
line diff
--- a/gpp/accounts/admin.py	Wed Mar 02 01:11:32 2011 +0000
+++ b/gpp/accounts/admin.py	Wed Mar 02 02:18:28 2011 +0000
@@ -19,6 +19,8 @@
        for pending_user in qs:
            create_new_user(pending_user, admin_activation=True)
 
+       self.message_user(request, "%s accounts activated" % qs.count())
+
    activate_account.short_description = "Activate accounts for selected users"
 
 
--- a/gpp/bio/admin.py	Wed Mar 02 01:11:32 2011 +0000
+++ b/gpp/bio/admin.py	Wed Mar 02 02:18:28 2011 +0000
@@ -98,6 +98,12 @@
         for profile in qs:
             Comment.objects.filter(user=profile.user).delete()
             delete_user_posts(profile.user)
+            profile.location = ''
+            profile.occupation = ''
+            profile.interests = ''
+            profile.profile_text = ''
+            profile.signature = ''
+            profile.save()
     mark_spammer.short_description = "Mark selected users as spammers"
 
     def mark_stranger(self, request, qs):
--- a/gpp/forums/signals.py	Wed Mar 02 01:11:32 2011 +0000
+++ b/gpp/forums/signals.py	Wed Mar 02 02:18:28 2011 +0000
@@ -4,7 +4,7 @@
 from django.db.models.signals import post_save
 from django.db.models.signals import post_delete
 
-from forums.models import Topic, Post
+from forums.models import Forum, Topic, Post
 from forums.views.subscriptions import notify_topic_subscribers
 
 
@@ -41,12 +41,18 @@
     post = kwargs['instance']
 
     # update the topic
-    post.topic.post_count_update()
-    post.topic.save()
-
-    # update the forum
-    post.topic.forum.post_count_update()
-    post.topic.forum.save()
+    try:
+        post.topic.post_count_update()
+        post.topic.save()
+    except Topic.DoesNotExist:
+        pass
+    else:
+        # update the forum
+        try:
+            post.topic.forum.post_count_update()
+            post.topic.forum.save()
+        except Forum.DoesNotExist:
+            pass
 
 
 post_save.connect(on_topic_save, sender=Topic, dispatch_uid='forums.signals')
--- a/gpp/forums/templatetags/forum_tags.py	Wed Mar 02 01:11:32 2011 +0000
+++ b/gpp/forums/templatetags/forum_tags.py	Wed Mar 02 02:18:28 2011 +0000
@@ -167,7 +167,8 @@
     user_count = User.objects.all().count()
 
     if user_count > 0:
-        latest_user = User.objects.values_list('username', flat=True).order_by('-date_joined')[0]
+        latest_user = User.objects.filter(is_active=True).values_list(
+                'username', flat=True).order_by('-date_joined')[0]
     else:
         latest_user = None
 
--- a/gpp/forums/tools.py	Wed Mar 02 01:11:32 2011 +0000
+++ b/gpp/forums/tools.py	Wed Mar 02 02:18:28 2011 +0000
@@ -52,7 +52,7 @@
             else:
                 forum.last_post = None
             forum.save()
-    
+
     # Delete pending topics now because forums have just adjusted their
     # foreign keys into Post
     if pending_delete:
@@ -63,7 +63,7 @@
         for forum in forums:
             forum.topic_count = Topic.objects.filter(forum=forum).count()
             forum.save()
-            
+
     # All foreign keys are accounted for, we can now delete the posts in bulk.
     # Since some posts in our original queryset may have been deleted already,
     # run a new query (although it may be ok)
--- a/gpp/forums/views/spam.py	Wed Mar 02 01:11:32 2011 +0000
+++ b/gpp/forums/views/spam.py	Wed Mar 02 02:18:28 2011 +0000
@@ -28,7 +28,8 @@
 
 def deactivate_spammer(user):
     """This function deactivate's the user, marks them as a spammer, then
-    deletes the user's comments and forum posts.
+    deletes the user's comments and forum posts. The spammer's profile is
+    cleared so any spam links won't show up anymore.
     """
     user.is_active = False
     user.save()
@@ -36,6 +37,11 @@
     profile = user.get_profile()
     profile.status = bio.models.STA_SPAMMER
     profile.status_date = datetime.datetime.now()
+    profile.location = ''
+    profile.occupation = ''
+    profile.interests = ''
+    profile.profile_text = ''
+    profile.signature = ''
     profile.save()
 
     Comment.objects.filter(user=user).delete()