X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/13bee2f2e6aea2d936909861f3ab60bb09821a60..675f602707bc783c6c6db282ac4e14334ef20df7:/forum/models/tag.py diff --git a/forum/models/tag.py b/forum/models/tag.py index 44e0a74..5cbaf8a 100644 --- a/forum/models/tag.py +++ b/forum/models/tag.py @@ -2,12 +2,39 @@ import datetime from base import * from django.utils.translation import ugettext as _ -import django.dispatch class ActiveTagManager(models.Manager): def get_query_set(self): - return super(ActiveTagManager, self).get_query_set().exclude(used_count__lt=1) + qs = super(ActiveTagManager, self).get_query_set().exclude(used_count__lt=1) + CurrentUserHolder = None + + # We try to import the moderation module and if the import is successful we make the filtration + try: + moderation_import = 'from %s.moderation.startup import CurrentUserHolder' % MODULES_PACKAGE + exec moderation_import + + moderation_enabled= True + except: + moderation_enabled = False + + # If the moderation module has been enabled we make the filtration + if CurrentUserHolder is not None and moderation_enabled: + user = CurrentUserHolder.user + + try: + filter_content = not user.is_staff and not user.is_superuser + except: + filter_content = True + + if filter_content: + moderation_import = 'from %s.moderation.hooks import get_tag_ids' % MODULES_PACKAGE + exec moderation_import + qs = qs.exclude(id__in=get_tag_ids('deleted')).exclude(id__in=get_tag_ids('rejected')).exclude( + id__in=get_tag_ids('in_moderation') + ) + + return qs class Tag(BaseModel): name = models.CharField(max_length=255, unique=True)