X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/617e60be3c7d2e0f17639f3487a721d4efdc02c0..c6c2f8819fc57f538764f3bccc7580bc6d94e25b:/forum/actions/user.py
diff --git a/forum/actions/user.py b/forum/actions/user.py
index 8f225d2..50d1a73 100644
--- a/forum/actions/user.py
+++ b/forum/actions/user.py
@@ -1,13 +1,14 @@
from django.utils.translation import ugettext as _
from django.db.models import F
-from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned
from forum.models.action import ActionProxy
-from forum.models import Award, Badge, ValidationHash
+from forum.models import Award, Badge, ValidationHash, User
from forum import settings
from forum.settings import APP_SHORT_NAME
-from forum.utils.mail import send_email, send_template_email
+from forum.utils.mail import send_template_email
class UserJoinsAction(ActionProxy):
+ verb = _("joined")
+
def repute_users(self):
self.repute(self.user, int(settings.INITIAL_REP))
@@ -23,6 +24,8 @@ class UserJoinsAction(ActionProxy):
}
class EditProfileAction(ActionProxy):
+ verb = _("edited profile")
+
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)),
@@ -31,26 +34,46 @@ class EditProfileAction(ActionProxy):
}
class BonusRepAction(ActionProxy):
- def process_data(self, value):
+ verb = _("gave bonus")
+
+ def process_data(self, value, affected):
self._value = value
+ self._affected = affected
+
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 +
- '
%s' % self.extra.get('message', _('Thank you')))
+ self.repute(self._affected, self._value)
+
+ if self._value > 0:
+ self._affected.message_set.create(
+ message=_("Congratulations, you have been awarded an extra %s reputation points.") % self._value +
+ '
%s' % self.extra.get('message', _('Thank you')))
+ else:
+ self._affected.message_set.create(
+ message=_("You have been penalized in %s reputation points.") % self._value +
+ '
%s' % self.extra.get('message', ''))
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
- }
+ try:
+ if int(value) > 0:
+ return _("%(user)s awarded an extra %(value)s reputation points to %(users)s: %(message)s") % {
+ 'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+ 'value': value, 'users':self.affected_links(viewer), 'message': message
+ }
+ else:
+ return _("%(user)s penalised %(users)s in %(value)s reputation points: %(message)s") % {
+ 'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)),
+ 'value': value, 'users':self.affected_links(viewer), 'message': message
+ }
+ except Exception, e:
+ return ''
class AwardAction(ActionProxy):
+ verb = _("was awarded")
+
def process_data(self, badge, trigger):
self.__dict__['_badge'] = badge
self.__dict__['_trigger'] = trigger
@@ -95,7 +118,7 @@ class AwardAction(ActionProxy):
return Award.objects.get(user=user, badge=badge).action
else:
return Award.objects.get(user=user, node=node, badge=badge).action
- except ObjectDoesNotExist:
+ except:
return None
def describe(self, viewer=None):
@@ -106,18 +129,25 @@ class AwardAction(ActionProxy):
}
class SuspendAction(ActionProxy):
+ verb = _("suspended")
+
def process_data(self, **kwargs):
+ self._suspended = kwargs.pop('suspended')
self.extra = kwargs
+ def repute_users(self):
+ self.repute(self._suspended, 0)
+
def process_action(self):
- self.user.is_active = False
- self.user.save()
+ self._suspended.is_active = False
+ self._suspended.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."))
+ for u in User.objects.filter(reputes__action=self).distinct():
+ u.is_active = True
+ u._pop_suspension_cache()
+ u.save()
+ u.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):
@@ -125,8 +155,7 @@ class SuspendAction(ActionProxy):
else:
suspension = _("indefinetely")
- return _("%(user)s %(were_was)s suspended %(suspension)s: %(msg)s") % {
+ return _("%(user)s suspended %(users)s %(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'))
+ 'users': self.affected_links(viewer), 'suspension': suspension, 'msg': self.extra.get('publicmsg', _('Bad behaviour'))
}
\ No newline at end of file