else:
return super(ActionQuerySet, self).obj_from_datadict(datadict)
- def get(self, *args, **kwargs):
- return super(ActionQuerySet, self).get(*args, **kwargs).leaf()
+ def get(self, *args, **kwargs):
+ action = super(ActionQuerySet, self).get(*args, **kwargs).leaf()
+
+ if not isinstance(action, self.model):
+ raise self.model.DoesNotExist()
+
+ return action
class ActionManager(CachedManager):
use_for_related_fields = True
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)
node = models.ForeignKey('Node', null=True, related_name="actions")
action_type = models.CharField(max_length=16)
def get_type(cls):
return re.sub(r'action$', '', cls.__name__.lower())
- def save(self, data=None, *args, **kwargs):
+ def save(self, data=None, threaded=True, *args, **kwargs):
isnew = False
if not self.id:
if (self.node is None) or (not self.node.nis.wiki):
self.repute_users()
self.process_action()
- self.trigger_hooks(True)
+ self.trigger_hooks(threaded, True)
return self
Action.hooks[cls].append(fn)
- def trigger_hooks(self, new=True):
- thread = Thread(target=trigger_hooks_threaded, args=[self, Action.hooks, new])
- thread.setDaemon(True)
- thread.start()
+ def trigger_hooks(self, threaded, new=True):
+ if threaded:
+ thread = Thread(target=trigger_hooks, args=[self, Action.hooks, new])
+ thread.setDaemon(True)
+ thread.start()
+ else:
+ trigger_hooks(self, Action.hooks, new)
class Meta:
app_label = 'forum'
-def trigger_hooks_threaded(action, hooks, new):
+def trigger_hooks(action, hooks, new):
for cls, hooklist in hooks.items():
if isinstance(action, cls):
for hook in hooklist:
'node_desc': node_desc,
}
+ def affected_links(self, viewer):
+ return ", ".join([self.hyperlink(u.get_profile_url(), self.friendly_username(viewer, u)) for u in set([r.user for r in self.reputes.all()])])
+
class Meta:
proxy = True