]> git.openstreetmap.org Git - osqa.git/blobdiff - forum/actions/user.py
Adds a new function in the profile menu for admins to suspend users, indefinetly...
[osqa.git] / forum / actions / user.py
index df90c66f562ffd163ea818597968a96e6550c405..a3856a83bbd53d2dd5fbc011d56490b6678067d1 100644 (file)
@@ -15,17 +15,18 @@ class UserJoinsAction(ActionProxy):
         send_template_email([self.user], "auth/email_validation.html", {'validation_code': hash})
 
     def describe(self, viewer=None):
-        return _("%(user)s as joined the %(app_name)s Q&A community") % {
-            'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
-            'app_name': APP_SHORT_NAME,
+        return _("%(user)s %(have_has)s joined the %(app_name)s Q&A community") % {
+        'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+        'have_has': self.viewer_or_user_verb(viewer, self.user, _('have'), _('has')),
+        'app_name': APP_SHORT_NAME,
         }
 
 class EditProfileAction(ActionProxy):
     def describe(self, viewer=None):
         return _("%(user)s edited %(hes_or_your)s %(profile_link)s") % {
-            'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
-            'hes_or_your': self.viewer_or_user_verb(viewer, self.user, _('your'), _('his')),
-            'profile_link': self.hyperlink(self.user.get_profile_url(), _('profile')),
+        'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+        'hes_or_your': self.viewer_or_user_verb(viewer, self.user, _('your'), _('his')),
+        'profile_link': self.hyperlink(self.user.get_profile_url(), _('profile')),
         }
 
 class BonusRepAction(ActionProxy):
@@ -34,17 +35,18 @@ class BonusRepAction(ActionProxy):
 
     def repute_users(self):
         self.repute(self.user, self._value)
-        self.user.message_set.create(message=_("Congratulations, you have been awarded an extra %s reputation points.") % self._value +
-                                     '<br />%s' % self.extra.get('message', _('Thank you')))
-        
+        self.user.message_set.create(
+                message=_("Congratulations, you have been awarded an extra %s reputation points.") % self._value +
+                '<br />%s' % self.extra.get('message', _('Thank you')))
+
     def describe(self, viewer=None):
         value = self.extra.get('value', _('unknown'))
         message = self.extra.get('message', '')
 
         return _("%(user)s %(was_were)s awarded %(value)s reputation points: %(message)s") % {
-            'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
-            'was_were': self.viewer_or_user_verb(viewer, self.user, _('were'), _('was')),
-            'value': value, 'message': message
+        'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+        'was_were': self.viewer_or_user_verb(viewer, self.user, _('were'), _('was')),
+        'value': value, 'message': message
         }
 
 class AwardAction(ActionProxy):
@@ -73,8 +75,10 @@ class AwardAction(ActionProxy):
 
         self.user.save()
 
-        self.user.message_set.create(message=_("""Congratulations, you have received a badge '%(badge_name)s'. Check out <a href=\"%(profile_url)s\">your profile</a>.""") %
-                                     dict(badge_name=award.badge.name, profile_url=self.user.get_profile_url()))
+        self.user.message_set.create(message=_(
+                """Congratulations, you have received a badge '%(badge_name)s'. Check out <a href=\"%(profile_url)s\">your profile</a>."""
+                ) %
+        dict(badge_name=award.badge.name, profile_url=self.user.get_profile_url()))
 
     def cancel_action(self):
         award = self.award
@@ -95,7 +99,33 @@ class AwardAction(ActionProxy):
 
     def describe(self, viewer=None):
         return _("%(user)s %(were_was)s awarded the %(badge_name)s badge") % {
-            'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
-            'were_was': self.viewer_or_user_verb(viewer, self.user, _('were'), _('was')),
-            'badge_name': self.award.badge.name,
+        'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+        'were_was': self.viewer_or_user_verb(viewer, self.user, _('were'), _('was')),
+        'badge_name': self.award.badge.name,
+        }
+
+class SuspendAction(ActionProxy):
+    def process_data(self, **kwargs):
+        self.extra = kwargs
+
+    def process_action(self):
+        self.user.is_active = False
+        self.user.save()
+
+    def cancel_action(self):
+        self.user.is_active = True
+        self.user._pop_suspension_cache()
+        self.user.save()
+        self.user.message_set.create(message=_("Your suspension has been removed."))
+
+    def describe(self, viewer=None):
+        if self.extra.get('bantype', 'indefinitely') == 'forxdays' and self.extra.get('forxdays', None):
+            suspension = _("for %s days") % self.extra['forxdays']
+        else:
+            suspension = _("indefinetely")
+
+        return _("%(user)s %(were_was)s suspended %(suspension)s: %(msg)s") % {
+        'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+        'were_was': self.viewer_or_user_verb(viewer, self.user, _('were'), _('was')),
+        'suspension': suspension, 'msg': self.extra.get('publicmsg', _('Bad behaviour'))
         }
\ No newline at end of file