X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/efc62f41304bf4bd783018f6008f3472f4c4ad92..094acc5f44c3a7779f42b3d84c86213ba6a1003c:/forum/actions/meta.py diff --git a/forum/actions/meta.py b/forum/actions/meta.py index 5063746..f5c12cd 100644 --- a/forum/actions/meta.py +++ b/forum/actions/meta.py @@ -2,7 +2,7 @@ from django.utils.translation import ugettext as _ from django.db.models import F from forum.models.action import ActionProxy, DummyActionProxy from forum.models import Vote, Flag -import settings +from forum import settings class VoteAction(ActionProxy): def update_node_score(self, inc): @@ -15,7 +15,7 @@ class VoteAction(ActionProxy): vote.save() def cancel_action(self): - vote = self.vote.all()[0] + vote = self.vote self.update_node_score(-vote.value) vote.delete() @@ -27,6 +27,14 @@ class VoteAction(ActionProxy): except: return None + @classmethod + def get_action_for(cls, user, node): + try: + vote = Vote.objects.get(user=user, node=node) + return vote.action + except: + return None + def describe_vote(self, vote_desc, viewer=None): return _("%(user)s %(vote_desc)s %(post_desc)s") % { 'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)), @@ -94,11 +102,11 @@ class FlagAction(ActionProxy): if self.node.flag_count == int(settings.FLAG_COUNT_TO_DELETE_POST): self.repute(self.node.author, -int(settings.REP_LOST_BY_FLAGGED_5_TIMES)) - if not self.node.deleted: + if not self.node.nis.deleted: DeleteAction(node=self.node, user=self.user, extra="BYFLAGGED").save() def cancel_action(self): - self.flag.all()[0].delete() + self.flag.delete() self.node.reset_flag_count_cache() @classmethod @@ -125,18 +133,16 @@ class AcceptAnswerAction(ActionProxy): self.repute(self.node.author, int(settings.REP_GAIN_BY_ACCEPTED)) def process_action(self): - self.node.parent.extra_ref = self.node - self.node.parent.save() self.node.marked = True - self.node.extra_action = self + self.node.nstate.accepted = self self.node.save() + self.node.question.reset_accepted_count_cache() def cancel_action(self): - self.node.parent.extra_ref = None - self.node.parent.save() self.node.marked = False - self.node.extra_action = None + self.node.nstate.accepted = None self.node.save() + self.node.question.reset_accepted_count_cache() def describe(self, viewer=None): answer = self.node @@ -149,7 +155,7 @@ class AcceptAnswerAction(ActionProxy): return _("%(user)s accepted %(answerer)s answer on %(asker)s question %(question)s") % { 'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)), - 'answerer': self.hyperlink(answer.author.get_profile_url(), self.friendly_username(viewer, answer.author)), + 'answerer': self.hyperlink(answer.author.get_profile_url(), self.friendly_ownername(viewer, answer.author)), 'asker': asker, 'question': self.hyperlink(question.get_absolute_url(), question.title) } @@ -171,23 +177,21 @@ class FavoriteAction(ActionProxy): class DeleteAction(ActionProxy): def process_action(self): - self.node.deleted = self - self.node.save() + self.node.mark_deleted(self) if self.node.node_type == "answer": self.node.question.reset_answer_count_cache() def cancel_action(self): - self.node.deleted = None - self.node.save() + self.node.mark_deleted(None) if self.node.node_type == "answer": self.node.question.reset_answer_count_cache() def describe(self, viewer=None): - return _("%(user)s deleted %(post_desc)s: %(reason)s") % { + return _("%(user)s deleted %(post_desc)s") % { 'user': self.hyperlink(self.user.get_profile_url(), self.friendly_username(viewer, self.user)), - 'post_desc': self.describe_node(viewer, self.node), 'reason': self.reason(), + 'post_desc': self.describe_node(viewer, self.node) } def reason(self): @@ -196,6 +200,9 @@ class DeleteAction(ActionProxy): else: return _("flagged by multiple users: ") + "; ".join([f.extra for f in FlagAction.objects.filter(node=self.node)]) +class UnknownAction(ActionProxy): + pass + class QuestionViewAction(DummyActionProxy): def __init__(self, node, user, ip=None):