summaryrefslogtreecommitdiffstats
path: root/instruments/models.py
diff options
context:
space:
mode:
authorYulqen <246857+yulqen@users.noreply.github.com>2024-04-23 11:22:21 +0100
committerGitHub <noreply@github.com>2024-04-23 11:22:21 +0100
commitceca6fa956b21c43263e53c328d619c4ede21914 (patch)
treea48384210cdc168e3bd3ccff6d6d516eeed9e748 /instruments/models.py
parent8b084e9fe7a5f3a04c32daf9a24f7f2cf67300f9 (diff)
parent0f951dcf029d4af284467543a3afdf5bf6581a20 (diff)
Merge pull request #22 from defencedigital/pyswitch
switched to Django
Diffstat (limited to '')
-rw-r--r--instruments/models.py56
1 files changed, 56 insertions, 0 deletions
diff --git a/instruments/models.py b/instruments/models.py
new file mode 100644
index 0000000..e266fb2
--- /dev/null
+++ b/instruments/models.py
@@ -0,0 +1,56 @@
+from django.db import models
+
+from engagements.models import EngagementEffort, Organisation
+
+
+class Common(models.Model):
+ date_created = models.DateTimeField(auto_now_add=True)
+ last_modified = models.DateTimeField(auto_now=True)
+
+ class Meta:
+ abstract = True
+
+
+class Instrument(Common):
+ "JSP 628, JSP 440, the ONR ones, etc"
+ name = models.CharField(max_length=512, null=False, blank=False)
+ long_title = models.CharField(max_length=1024, null=True, blank=True)
+ designator = models.CharField(max_length=3, null=True, blank=True)
+ owner = models.ForeignKey(Organisation, null=False, blank=False, on_delete=models.CASCADE)
+ link = models.URLField(max_length=1024, null=True, blank=True)
+
+ def __str__(self):
+ return self.name
+
+ class Meta:
+ verbose_name_plural = "Instruments"
+
+
+class SubInstrument(Common):
+ "DSCs, Chapters, Supplements, Leaflets..."
+ choices = (
+ ("DSC", "Defence Security Condition (DSC)"),
+ ("DSYAP", "Defence Security Assessment Principle (DSyAP)"),
+ ("DSTAIG", "Defence Security Testing And I Don't Know (DSTAIG)"),
+ )
+ is_guidance = models.BooleanField(null=True, blank=True, default=False)
+ itype = models.CharField(choices=choices, max_length=6, verbose_name="Instrument Type")
+ title = models.CharField(max_length=512, null=False, blank=False)
+ parent = models.ForeignKey(Instrument, on_delete=models.CASCADE, verbose_name="Parent Instrument")
+ description = models.TextField(null=True, blank=True)
+ rationale = models.TextField(null=True, blank=True)
+ relative = models.ManyToManyField("self")
+ short = models.CharField(max_length=10, null=True, blank=True)
+
+ def effort(self):
+ return EngagementEffort.objects.filter(sub_instruments__contains=self)
+
+ def effort_for_org(self, org):
+ eff = EngagementEffort.objects.filter(engagement__external_party=org).filter(effort_type="REGULATION")
+ return sum(e.effort_total_hours() for e in eff)
+
+ def __str__(self):
+ return self.title
+
+ class Meta:
+ verbose_name_plural = "Sub Instruments"