X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/ca88510e4dd14206f623cababfda1e8a9daf70d4..8b52676543e3f5f1350d8d0eeaedee6fe35f49b3:/forum/actions/user.py diff --git a/forum/actions/user.py b/forum/actions/user.py index aef541a..8f225d2 100644 --- a/forum/actions/user.py +++ b/forum/actions/user.py @@ -1,26 +1,33 @@ 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 +from forum.models import Award, Badge, ValidationHash from forum import settings from forum.settings import APP_SHORT_NAME +from forum.utils.mail import send_email, send_template_email class UserJoinsAction(ActionProxy): def repute_users(self): self.repute(self.user, int(settings.INITIAL_REP)) + def process_action(self): + hash = ValidationHash.objects.create_new(self.user, 'email', [self.user.email]) + send_template_email([self.user], "auth/welcome_email.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'), _('hes')), - '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): @@ -29,17 +36,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 + - '
%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 + + '
%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): @@ -58,8 +66,20 @@ class AwardAction(ActionProxy): award.save() award.badge.awarded_count = F('awarded_count') + 1 award.badge.save() - self.user.message_set.create(message=_("""Congratulations, you have received a badge '%(badge_name)s'. Check out your profile.""") % - dict(badge_name=award.badge.name, profile_url=self.user.get_profile_url())) + + if award.badge.type == Badge.GOLD: + self.user.gold += 1 + if award.badge.type == Badge.SILVER: + self.user.silver += 1 + if award.badge.type == Badge.BRONZE: + self.user.bronze += 1 + + self.user.save() + + self.user.message_set.create(message=_( + """Congratulations, you have received a badge '%(badge_name)s'. Check out your profile.""" + ) % + dict(badge_name=award.badge.name, profile_url=self.user.get_profile_url())) def cancel_action(self): award = self.award @@ -75,12 +95,38 @@ 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: + except ObjectDoesNotExist: return None 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