From f065fbc48b4380fa9e723518d7465bd0e309b4a9 Mon Sep 17 00:00:00 2001 From: Tim Laszlo Date: Tue, 9 Oct 2012 06:41:11 -0500 Subject: Add prune routines --- src/lib/Bcfg2/Reporting/models.py | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) (limited to 'src/lib/Bcfg2/Reporting/models.py') diff --git a/src/lib/Bcfg2/Reporting/models.py b/src/lib/Bcfg2/Reporting/models.py index 3a540587a..b8fe1b973 100644 --- a/src/lib/Bcfg2/Reporting/models.py +++ b/src/lib/Bcfg2/Reporting/models.py @@ -259,6 +259,12 @@ class Group(models.Model): ordering = ('name',) + @staticmethod + def prune_orphans(): + '''Prune unused groups''' + Group.objects.filter(interaction__isnull=True, group__isnull=True).delete() + + class Bundle(models.Model): """ Bundles extracted from interactions @@ -275,6 +281,12 @@ class Bundle(models.Model): ordering = ('name',) + @staticmethod + def prune_orphans(): + '''Prune unused bundles''' + Bundle.objects.filter(interaction__isnull=True, group__isnull=True).delete() + + # new interaction models class FilePerms(models.Model): owner = models.CharField(max_length=128) @@ -368,6 +380,12 @@ class BaseEntry(models.Model): return isinstance(self, FailureEntry) + @classmethod + def prune_orphans(cls): + '''Remove unused entries''' + cls.objects.filter(interaction__isnull=True).delete() + + class SuccessEntry(BaseEntry): """Base for successful entries""" state = models.IntegerField(choices=TYPE_CHOICES) @@ -411,7 +429,6 @@ class ActionEntry(SuccessEntry): output = models.IntegerField(default=0) ENTRY_TYPE = r"Action" - #TODO - prune class PackageEntry(SuccessEntry): -- cgit v1.2.3-1-g7c22