From 1676c7749229eb075a5c7aa72f06f93ed8b4c2eb Mon Sep 17 00:00:00 2001 From: Raphael Gaschignard Date: Wed, 9 Oct 2024 13:58:24 +1000 Subject: [PATCH] Add an orphaned queryset method to Tags --- CHANGELOG.rst | 2 ++ taggit/admin.py | 2 +- taggit/management/commands/remove_orphaned_tags.py | 2 +- taggit/models.py | 11 +++++++++++ 4 files changed, 15 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index eefdd7b8..6a3ced30 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -4,6 +4,8 @@ Changelog (Unreleased) ~~~~~~~~~~~~ +* Add an admin command to remove orphaned tags + 6.1.0 (2024-09-29) ~~~~~~~~~~~~~~~~~~ diff --git a/taggit/admin.py b/taggit/admin.py index 611efa16..7d0847bb 100644 --- a/taggit/admin.py +++ b/taggit/admin.py @@ -88,7 +88,7 @@ def merge_tags_view(self, request): @admin.action(description="Remove orphaned tags") def remove_orphaned_tags_action(self, request, queryset): try: - orphaned_tags = Tag.objects.filter(taggit_taggeditem_items=None) + orphaned_tags = queryset.objects.orphaned() count, _ = orphaned_tags.delete() self.message_user( request, f"Successfully removed {count} orphaned tags.", level="success" diff --git a/taggit/management/commands/remove_orphaned_tags.py b/taggit/management/commands/remove_orphaned_tags.py index 1bd799e7..12e89740 100644 --- a/taggit/management/commands/remove_orphaned_tags.py +++ b/taggit/management/commands/remove_orphaned_tags.py @@ -7,6 +7,6 @@ class Command(BaseCommand): help = "Remove orphaned tags" def handle(self, *args, **options): - orphaned_tags = Tag.objects.filter(taggit_taggeditem_items=None) + orphaned_tags = Tag.objects.orphaned() count = orphaned_tags.delete() self.stdout.write(f"Successfully removed {count} orphaned tags") diff --git a/taggit/models.py b/taggit/models.py index 091d733b..9f6aa684 100644 --- a/taggit/models.py +++ b/taggit/models.py @@ -105,7 +105,18 @@ def slugify(self, tag, i=None): return slug +class TagQuerySet(models.QuerySet): + + def orphaned(self): + return self.filter(taggit_taggeditem_items=None) + + class Tag(TagBase): + + objects = NaturalKeyManager.from_queryset(TagQuerySet)() + + + class Meta: verbose_name = _("tag") verbose_name_plural = _("tags")