X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/f5fda79fa40310950e0c6f40a40619c701fd3f08..cf523df2eb6e7b696c693e68b449a2c541bbaa67:/forum/models/action.py diff --git a/forum/models/action.py b/forum/models/action.py index 7fd2e6f..e8d0765 100644 --- a/forum/models/action.py +++ b/forum/models/action.py @@ -16,7 +16,7 @@ class ActionQuerySet(CachedQuerySet): return super(ActionQuerySet, self).obj_from_datadict(datadict) def get(self, *args, **kwargs): - action = super(ActionQuerySet, self).get(*args, **kwargs).leaf() + action = super(ActionQuerySet, self).get(*args, **kwargs).leaf if not isinstance(action, self.model): raise self.model.DoesNotExist() @@ -42,9 +42,9 @@ class ActionManager(CachedManager): class Action(BaseModel): user = models.ForeignKey('User', related_name="actions") real_user = models.ForeignKey('User', related_name="proxied_actions", null=True) - ip = models.CharField(max_length=16) + ip = models.CharField(max_length=39) node = models.ForeignKey('Node', null=True, related_name="actions") - action_type = models.CharField(max_length=16) + action_type = models.CharField(max_length=32) action_date = models.DateTimeField(default=datetime.datetime.now) extra = PickledObjectField() @@ -52,7 +52,7 @@ class Action(BaseModel): canceled = models.BooleanField(default=False) canceled_by = models.ForeignKey('User', null=True, related_name="canceled_actions") canceled_at = models.DateTimeField(null=True) - canceled_ip = models.CharField(max_length=16) + canceled_ip = models.CharField(max_length=39) hooks = {} @@ -101,6 +101,7 @@ class Action(BaseModel): cancel = ActionRepute(action=self, user=repute.user, value=(-repute.value), by_canceled=True) cancel.save() + @property def leaf(self): leaf_cls = ActionProxyMetaClass.types.get(self.action_type, None) @@ -299,7 +300,7 @@ class ActionRepute(models.Model): return 0 def _add_to_rep(self, value): - if self.user.reputation + value < 0: + if (self.user.reputation + value < 1) and not settings.ALLOW_NEGATIVE_REPUTATION: return 0 else: return models.F('reputation') + value