aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMR Lemon <matt@matthewlemon>2020-05-13 16:08:00 +0100
committerMR Lemon <matt@matthewlemon>2020-05-13 16:08:00 +0100
commite3b629fe001c75caca0f430ee5137305e4386af7 (patch)
treed4da5323b9c5281a4bfdb9ed83f7a51ffd6135fc
parent84f2eccea7759dc694c83b770b0066a11cae7ecd (diff)
refactored populate script into a new core app - better positioned for use in tests
-rw-r--r--config/settings/base.py2
-rw-r--r--ctrack/core/__init__.py0
-rw-r--r--ctrack/core/admin.py3
-rw-r--r--ctrack/core/apps.py5
-rw-r--r--ctrack/core/management/__init__.py0
-rw-r--r--ctrack/core/management/commands/__init__.py0
-rw-r--r--ctrack/core/management/commands/populate_db.py24
-rw-r--r--ctrack/core/migrations/__init__.py0
-rw-r--r--ctrack/core/models.py3
-rw-r--r--ctrack/core/utils.py616
-rw-r--r--ctrack/core/views.py3
-rw-r--r--ctrack/organisations/management/commands/populate_db.py637
-rw-r--r--ctrack/organisations/migrations/0004_auto_20200513_1441.py18
13 files changed, 673 insertions, 638 deletions
diff --git a/config/settings/base.py b/config/settings/base.py
index fd3f502..57028a8 100644
--- a/config/settings/base.py
+++ b/config/settings/base.py
@@ -89,7 +89,7 @@ LOCAL_APPS = [
"ctrack.caf.apps.CafConfig",
"ctrack.register.apps.RegisterConfig",
"ctrack.assessments.apps.AssessmentsConfig",
- # Your stuff: custom apps go here
+ "ctrack.core.apps.CoreConfig",
]
# https://docs.djangoproject.com/en/dev/ref/settings/#installed-apps
INSTALLED_APPS = DJANGO_APPS + THIRD_PARTY_APPS + LOCAL_APPS
diff --git a/ctrack/core/__init__.py b/ctrack/core/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/ctrack/core/__init__.py
diff --git a/ctrack/core/admin.py b/ctrack/core/admin.py
new file mode 100644
index 0000000..8c38f3f
--- /dev/null
+++ b/ctrack/core/admin.py
@@ -0,0 +1,3 @@
+from django.contrib import admin
+
+# Register your models here.
diff --git a/ctrack/core/apps.py b/ctrack/core/apps.py
new file mode 100644
index 0000000..9310a7b
--- /dev/null
+++ b/ctrack/core/apps.py
@@ -0,0 +1,5 @@
+from django.apps import AppConfig
+
+
+class CoreConfig(AppConfig):
+ name = 'ctrack.core'
diff --git a/ctrack/core/management/__init__.py b/ctrack/core/management/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/ctrack/core/management/__init__.py
diff --git a/ctrack/core/management/commands/__init__.py b/ctrack/core/management/commands/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/ctrack/core/management/commands/__init__.py
diff --git a/ctrack/core/management/commands/populate_db.py b/ctrack/core/management/commands/populate_db.py
new file mode 100644
index 0000000..5b8f541
--- /dev/null
+++ b/ctrack/core/management/commands/populate_db.py
@@ -0,0 +1,24 @@
+
+from django.core.management import BaseCommand
+from django.core.management import CommandParser
+from ctrack.core.utils import populate_db
+
+
+class Command(BaseCommand):
+ help = """
+ Creates a large test fixture.
+ """
+
+ def add_arguments(self, parser: CommandParser) -> None:
+ parser.add_argument("number", nargs=1, type=int)
+
+ def handle(self, *args, **options):
+ number = options["number"][0]
+ populate_db(number)
+
+ # TODO - adapt this so that it records more than just Persons created
+ self.stdout.write(
+ self.style.SUCCESS(
+ f"Created {number} Person object[s]! Go forth and multiply."
+ )
+ )
diff --git a/ctrack/core/migrations/__init__.py b/ctrack/core/migrations/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/ctrack/core/migrations/__init__.py
diff --git a/ctrack/core/models.py b/ctrack/core/models.py
new file mode 100644
index 0000000..71a8362
--- /dev/null
+++ b/ctrack/core/models.py
@@ -0,0 +1,3 @@
+from django.db import models
+
+# Create your models here.
diff --git a/ctrack/core/utils.py b/ctrack/core/utils.py
new file mode 100644
index 0000000..039348d
--- /dev/null
+++ b/ctrack/core/utils.py
@@ -0,0 +1,616 @@
+import random
+from random import randint, choice
+
+from faker import Faker
+
+from ctrack.assessments.models import CAFAssessment, CAFObjective, CAFPrinciple, CAFContributingOutcome, \
+ CAFAssessmentOutcomeScore, AchievementLevel, IGP
+from ctrack.caf.models import CAF
+from ctrack.caf.tests.factories import (
+ GradingFactory,
+ FileStoreFactory, CAFFactory, ApplicableSystemFactory,
+)
+from ctrack.organisations.models import AddressType, Person
+from ctrack.organisations.models import Mode
+from ctrack.organisations.models import Submode
+from ctrack.organisations.tests.factories import AddressFactory
+from ctrack.organisations.tests.factories import OrganisationFactory
+from ctrack.organisations.tests.factories import PersonFactory
+from ctrack.organisations.tests.factories import RoleFactory
+from ctrack.organisations.tests.factories import UserFactory
+from ctrack.register.tests.factories import EngagementEventFactory
+from ctrack.register.tests.factories import EngagementTypeFactory
+
+fnames = [
+ "Clock Pylon Systems",
+ "Ultramarine Hanglider Navigator",
+ "Membranous Floor Heaters",
+ "Alan's Wardrobe Hinge Circuits",
+ "Marine Sluicegate Extension Pulleys",
+ "Ironway Prob Modelling Area",
+ "Bufferage Clippers",
+ "Slow Gauze Thread Manipulator",
+ "Terratoast Piling",
+ "Accounting and Warehouse Conducer",
+ "Able Hopscotch Mirrors",
+ "Jolly Main Legacy Circuitry",
+]
+
+
+def _create_caf_app_service(c_descriptors, org, q_descriptors):
+ caf = CAFFactory.create(
+ quality_grading__descriptor=random.choice(q_descriptors),
+ confidence_grading__descriptor=random.choice(c_descriptors),
+ triage_review_date=None,
+ triage_review_inspector=None,
+ )
+ # Each CAF can have up to three systems associated with it
+ for _ in range(random.randint(1, 3)):
+ ApplicableSystemFactory.create(
+ name=random.choice(fnames), organisation=org, caf=caf,
+ )
+
+
+def populate_db(persons):
+ number = persons
+
+ # Set up some reasonable Modes and SubModes
+ m1 = Mode.objects.create(descriptor="Rail")
+ m2 = Mode.objects.create(descriptor="Maritime")
+
+ sb1 = Submode.objects.create(descriptor="Light Rail", mode=m1)
+ sb2 = Submode.objects.create(descriptor="Rail Maintenance", mode=m1)
+ sb3 = Submode.objects.create(descriptor="Rail Infrastructure", mode=m1)
+ sb4 = Submode.objects.create(descriptor="International Rail", mode=m1)
+ sb5 = Submode.objects.create(descriptor="Passenger Port", mode=m2)
+ sb6 = Submode.objects.create(descriptor="Freight Port", mode=m2)
+ sb7 = Submode.objects.create(descriptor="Shipping Infrastructure", mode=m2)
+
+ submodes = [sb1, sb2, sb3, sb4, sb5, sb6, sb7]
+
+ # we need a User object to completed the updated_by fields in Organisation and Person
+ user = (
+ UserFactory.create()
+ ) # we need to have at least one user for the updated_by field
+
+ # Create 40 Organisation objects
+ orgs = [
+ OrganisationFactory.create(submode=submodes[randint(0, len(submodes) - 1)])
+ for org in range(40)
+ ]
+ # Create 40 Address objects
+ addr_type = AddressType.objects.create(descriptor="Primary Address")
+ for org in orgs:
+ AddressFactory.create(type=addr_type, organisation=org)
+
+ roles = [
+ RoleFactory.create() for x in range(10)
+ ] # because we have a many-to-many relationship with Role, we need to create one and pass it in
+ for org in orgs:
+ PersonFactory.create(
+ role=choice(roles),
+ updated_by=user,
+ predecessor=None,
+ organisation__submode=choice(submodes),
+ organisation=org,
+ )
+
+ inspector_role = RoleFactory.create(name="Compliance Inspector")
+
+ # set up some EngagementEvents
+
+ p1 = PersonFactory.create(
+ role=choice(roles),
+ updated_by=user,
+ predecessor=None,
+ organisation__submode=choice(submodes),
+ organisation=org,
+ )
+ p2 = PersonFactory.create(
+ role=choice(roles),
+ updated_by=user,
+ predecessor=None,
+ organisation__submode=choice(submodes),
+ organisation=org,
+ )
+ p3 = PersonFactory.create(
+ role=choice(roles),
+ updated_by=user,
+ predecessor=None,
+ organisation__submode=choice(submodes),
+ organisation=org,
+ )
+
+ regulator_org = OrganisationFactory.create(
+ submode=None,
+ name="The Regulator",
+ designation_type=3,
+ registered_company_name="The Regulator - HMG",
+ comments="This is the real regulator.",
+ )
+
+ inspectors = [
+ PersonFactory.create(
+ role=inspector_role,
+ updated_by=user,
+ job_title="Compliance Inspector",
+ predecessor=None,
+ organisation__submode=None,
+ organisation=regulator_org,
+ )
+ for _ in range(5)
+ ]
+
+ etf1 = EngagementTypeFactory(descriptor="Information Notice")
+ etf2 = EngagementTypeFactory(descriptor="Designation Letter")
+ etf3 = EngagementTypeFactory(
+ descriptor="CAF - Initial Submission", enforcement_instrument=False
+ )
+
+ EngagementEventFactory.create(type=etf1, user=user, participants=[p1, p2])
+ EngagementEventFactory.create(type=etf2, user=user, participants=[p3])
+
+ # Quality gradings
+ q_descriptors = ["Q1", "Q2", "Q3", "Q4", "Q5"]
+ for g in q_descriptors:
+ GradingFactory.create(descriptor=g, type="QUALITY")
+
+ # Confidence gradings
+ c_descriptors = ["C1", "C2", "C3", "C4", "C5"]
+ for g in c_descriptors:
+ GradingFactory.create(descriptor=g, type="CONFIDENCE")
+
+ # File store
+ FileStoreFactory.create(physical_location_organisation=orgs[1])
+
+ # Every org gets on CAF for now
+ for org in orgs:
+ # create a CAF and ApplicableService for it
+ _create_caf_app_service(c_descriptors, org, q_descriptors)
+
+ # CAF submissions - they create EngagementEvents
+ # Get a random CAF
+ _caf = CAF.objects.get(pk=1) # we should have one by now
+ EngagementEventFactory.create(
+ type=etf3, user=user, participants=[inspectors[1], p2], related_caf=_caf
+ )
+
+ # We want to simulate 4 CAF Objectives
+ c_obj_a = CAFObjective.objects.create(name="Objective A: Managing security risk",
+ description="An important objective to fix the world.", order_id=1)
+ c_obj_b = CAFObjective.objects.create(name="Objective B: Protecting Against Cyber Attack",
+ description="An important objective to fix the world.", order_id=2)
+ c_obj_c = CAFObjective.objects.create(name="Objective C: Detecting Cyber Security Events",
+ description="An important objective to fix the world.", order_id=3)
+ c_obj_d = CAFObjective.objects.create(name="Objective D: Minimising the Impact of Cyber Security Incidents",
+ description="An important objective to fix the world.", order_id=4)
+
+ # For each Objective, let's create four Principles
+ p_a1 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_a.id,
+ designation="A1",
+ title="Governance",
+ description="When you don't have Governance, you have nothing.",
+ order_id=1
+ )
+ p_a2 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_a.id,
+ designation="A2",
+ title="Risk Management",
+ description="Don't take a risk, and don't get nowhere.",
+ order_id=2
+ )
+ p_a3 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_a.id,
+ designation="A3",
+ title="Asset Management",
+ description="Without assets, you have no raw materials to work with.",
+ order_id=3
+ )
+ p_a4 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_a.id,
+ designation="A4",
+ title="Supply Chain",
+ description="You need to get your stuff from somewhere.",
+ order_id=4
+ )
+
+ p_b1 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_b.id,
+ designation="B1",
+ title="Service Protection & Policies",
+ description="Put in place the right protections for a future of security.",
+ order_id=1
+ )
+ p_b2 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_b.id,
+ designation="B2",
+ title="Identity and Access Control",
+ description="Stop the wrong people getting at your critical assets, okay.",
+ order_id=2
+ )
+ p_b3 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_b.id,
+ designation="B3",
+ title="Data Security",
+ description="Data is the new oil...",
+ order_id=3
+ )
+ p_b4 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_b.id,
+ designation="B4",
+ title="System Security",
+ description="If you have complicated systems, they need some sort of security.",
+ order_id=4
+ )
+
+ p_b5 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_b.id,
+ designation="B5",
+ title="Resilience Networks and Systems",
+ description="When all else fails, there is always food to be cooked.",
+ order_id=5
+ )
+
+ p_b6 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_b.id,
+ designation="B6",
+ title="Staff Awareness and Training",
+ description="You must ensure your people are trained and equipped for making a difference.",
+ order_id=6
+ )
+
+ # Only two of these
+ p_c1 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_c.id,
+ designation="C1",
+ title="Security Monitoring",
+ description="Monitoring the bits and pieces is the most important aspect of your life.",
+ order_id=1
+ )
+ p_c2 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_c.id,
+ designation="C2",
+ title="Proactive Security and Event Discovery",
+ description="If we're not proactive, we will get found out eventually.",
+ order_id=2
+ )
+
+ # Only two of these too
+ p_d1 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_d.id,
+ designation="D1",
+ title="Response and Recovery Planning",
+ description="Responding to the security problems since 1999...",
+ order_id=1
+ )
+ p_d2 = CAFPrinciple.objects.create(
+ caf_objective_id=c_obj_d.id,
+ designation="D2",
+ title="Improvements",
+ description="Improving all the things.",
+ order_id=2
+ )
+
+ # Based on these principles, it's time to gen some CAFContributingOutcomes
+ cos = [
+ CAFContributingOutcome.objects.create(
+ designation="A1.a",
+ name="Board Direction",
+ description="You have forced your Board to listen to your whinging about cyber.",
+ principle_id=p_a1.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="A1.b",
+ name="Roles and Responsibilities",
+ description="Your elders and betters are impressed and they continue to make money after your project "
+ "implementation.",
+ principle_id=p_a1.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="A1.c",
+ name="Decision-making",
+ description="If you are forced to participate in the Crystal Maze, you'll choose the coorect path across "
+ "the Gordian runway.",
+ principle_id=p_a1.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="A2.a",
+ name="Risk Management Process",
+ description="You take mighty risks, but they are mitigated by more sensible people around you - good.",
+ principle_id=p_a2.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="A2.b",
+ name="Assurance",
+ description="We all make mistakes, but in doing this well you at least have told people what you're doing.",
+ principle_id=p_a2.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="A3.a",
+ name="Asset Management",
+ description="Taking care of these aspects of corporate life is commensurate with the money-making way.",
+ principle_id=p_a3.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="A4.a",
+ name="Supply Chain",
+ description="Task your customers to take on all the risk, the debt, the hassle - you're good to go.",
+ principle_id=p_a4.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B1.a",
+ name="Policy and Process Development",
+ description="You are getting your process and policy development spot on.",
+ principle_id=p_b1.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B1.b",
+ name="Policy and Process Information",
+ description="Differs from the above in a few ways that will be discussed at a later date.",
+ principle_id=p_b1.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B2.a",
+ name="ID Verification, Authentication and Authorisation",
+ description="It is very important for people to be able to confirm they they truly are. Underneath.",
+ principle_id=p_b2.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B2.b",
+ name="Device Management",
+ description="Your devices, and their safe and sustainable use, is crucuial to the longevity of your company.",
+ principle_id=p_b2.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B2.c",
+ name="Privileged User Mangement",
+ description="You ensure that even the most privileged members of your senior management are under the impression "
+ "that they exude inequality, in all instances.",
+ principle_id=p_b2.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B3.a",
+ name="Understanding Data",
+ description="You, more than anyone else in the organisation, know what your data means to you.",
+ principle_id=p_b3.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B3.b",
+ name="Data in Transit",
+ description="You are protecting your data as it moves along the Information Superhighway.",
+ principle_id=p_b3.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B3.c",
+ name="Stored Data",
+ description="You have stored your data in accordance with local environment laws.",
+ principle_id=p_b3.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B3.d",
+ name="Mobile Data",
+ description="Mobile data is when data moves because it is stored in a moving thing.",
+ principle_id=p_b3.id,
+ order_id=4
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B3.e",
+ name="Media/Equipment Sanitisation",
+ description="You routinely wash and clean the legs and bottom brackets of your server racks.",
+ principle_id=p_b3.id,
+ order_id=5
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B4.a",
+ name="Secure by Design",
+ description="You have designed your systems to be secure and you're sure no one is going to hack into them.",
+ principle_id=p_b4.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B4.b",
+ name="Secure Configuration",
+ description="When you are able to configure your systems and software well, you can say you have Secure "
+ "Configuration. Only then, mind.",
+ principle_id=p_b4.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B4.c",
+ name="Secure Management",
+ description="Somehow this one is different from all the others but I'm not sure how.",
+ principle_id=p_b4.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B4.d",
+ name="Vulnerability Management",
+ description="Doing this well means that you are at the top of your vulnerability scale.",
+ principle_id=p_b4.id,
+ order_id=4
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B5.a",
+ name="Resilience Preparation",
+ description="Totally ready for the coming of the cyber apocalyse. You practice this stuff regular.",
+ principle_id=p_b5.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B5.b",
+ name="Design for Resilience",
+ description="This stuff is built into your very working model.",
+ principle_id=p_b5.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B5.c",
+ name="Backups",
+ description="There is nowhere for you to go as a professional if you don't make backups of your data.",
+ principle_id=p_b5.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B6.a",
+ name="Cyber Security Culture",
+ description="You're making them understand that this isn't going to go away in a hurry.",
+ principle_id=p_b6.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="B6.b",
+ name="Cyber Security Training",
+ description="By the way, when youre staff are able to write C code, your company understands buffer "
+ "overflows.",
+ principle_id=p_b6.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C1.a",
+ name="Monitoring Coverage",
+ description="At all times, you are vigilent to the threats out there, and ready to tackle them.",
+ principle_id=p_c1.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C1.b",
+ name="Securing Logs",
+ description="You might think the are a waste of time, but the Board thinks logging is important.",
+ principle_id=p_c1.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C1.c",
+ name="Generating Alerts",
+ description="Boo! There, you coped with it because you're good at this.",
+ principle_id=p_c1.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C1.d",
+ name="Identifying Security Incidents",
+ description="You are wary of all the possible things that could go wrong and you have a plan to deal. Well "
+ "done.",
+ principle_id=p_c1.id,
+ order_id=4
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C1.e",
+ name="Monitoring Tools and Skills",
+ description="All these things matter in today's switched on cyber-aware environment.",
+ principle_id=p_c1.id,
+ order_id=5
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C2.a",
+ name="System Abnormalities for Attack Detection",
+ description="Make sure you know how to look for things that mighty wrong on your network.",
+ principle_id=p_c2.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="C2.b",
+ name="Proactive Attack Discovery",
+ description="When you go out looking for the bad stuff, you usefully find it - and you know this in spades.",
+ principle_id=p_c2.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="D1.a",
+ name="Response Plan",
+ description="Yeah, we know it's boring but you've got to have one.",
+ principle_id=p_d1.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="D1.b",
+ name="Response and Recovery Capability",
+ description="If you can't get back on your feet after you've been beat, where are you, really?",
+ principle_id=p_d1.id,
+ order_id=2
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="D1.c",
+ name="Testing and Exercising",
+ description="One of the most important things you should not be forgetting is this.",
+ principle_id=p_d1.id,
+ order_id=3
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="D2.a",
+ name="Incident Root Cause and Analysis",
+ description="I guess there are always lessons learned, no matter how we good we are.",
+ principle_id=p_d2.id,
+ order_id=1
+ ),
+ CAFContributingOutcome.objects.create(
+ designation="D2.b",
+ name="Using Incidents to Drive Improvements",
+ description="This is the kind of thing that bores us to tears but it simply has to be done.",
+ principle_id=p_d2.id,
+ order_id=2
+ )
+ ]
+
+ achievement_levels = [
+ AchievementLevel.objects.create(
+ descriptor="Not Achieved",
+ colour_description="Red",
+ colour_hex="#000001"
+ ),
+ AchievementLevel.objects.create(
+ descriptor="Partially Achieved",
+ colour_description="Amber",
+ colour_hex="#000002"
+ ),
+ AchievementLevel.objects.create(
+ descriptor="Achieved",
+ colour_description="Green",
+ colour_hex="#000003"
+ )
+ ]
+
+ for al in achievement_levels:
+ for co in cos:
+ for igp in range(1, random.randint(2, 5)):
+ dtext_fake = Faker()
+ fake_txt = f"IGP {igp}/{al.descriptor}/{co.designation}: {dtext_fake.paragraph()}"
+ IGP.objects.create(
+ achievement_level=al,
+ contributing_outcome=co,
+ descriptive_text=fake_txt
+ )
+
+ # We want to create a CAF with a bunch of scoring now...
+ _caf2 = CAF.objects.get(pk=1)
+
+ _completer = Person.objects.get(pk=1)
+ caf_assessment = CAFAssessment.objects.create(
+ caf_id=_caf2.id, completer_id=_completer.id, comments="Random Comments"
+ )
+
+ # TODO Need to create as many of these as there are ContributingOutcomes
+ # Create a single CAFSelfAssessmentOutcomeScore
+ for c in cos:
+ CAFAssessmentOutcomeScore.objects.create(
+ caf_assessment_id=caf_assessment.id,
+ caf_contributing_outcome_id=c.id,
+ assessment_score=random.choice(["Achieved", "Partially Achieved", "Not Achieved"]),
+ baseline_assessment_score=random.choice(["Achieved", "Partially Achieved", "Not Achieved"])
+ )
diff --git a/ctrack/core/views.py b/ctrack/core/views.py
new file mode 100644
index 0000000..91ea44a
--- /dev/null
+++ b/ctrack/core/views.py
@@ -0,0 +1,3 @@
+from django.shortcuts import render
+
+# Create your views here.
diff --git a/ctrack/organisations/management/commands/populate_db.py b/ctrack/organisations/management/commands/populate_db.py
deleted file mode 100644
index c2b8a85..0000000
--- a/ctrack/organisations/management/commands/populate_db.py
+++ /dev/null
@@ -1,637 +0,0 @@
-import random
-from random import randint, choice
-
-from django.core.management import BaseCommand
-from django.core.management import CommandParser
-from faker import Faker
-
-from ctrack.assessments.models import CAFAssessment, CAFObjective, CAFPrinciple, CAFContributingOutcome, \
- CAFAssessmentOutcomeScore, AchievementLevel, IGP
-from ctrack.caf.models import CAF
-from ctrack.caf.tests.factories import (
- GradingFactory,
- FileStoreFactory,
- CAFFactory,
- ApplicableSystemFactory,
-)
-from ctrack.organisations.models import AddressType, Person
-from ctrack.organisations.models import Mode
-from ctrack.organisations.models import Submode
-from ctrack.organisations.tests.factories import AddressFactory
-from ctrack.organisations.tests.factories import OrganisationFactory
-from ctrack.organisations.tests.factories import PersonFactory
-from ctrack.organisations.tests.factories import RoleFactory
-from ctrack.organisations.tests.factories import UserFactory
-from ctrack.register.tests.factories import EngagementEventFactory
-from ctrack.register.tests.factories import EngagementTypeFactory
-
-fnames = [
- "Clock Pylon Systems",
- "Ultramarine Hanglider Navigator",
- "Membranous Floor Heaters",
- "Alan's Wardrobe Hinge Circuits",
- "Marine Sluicegate Extension Pulleys",
- "Ironway Prob Modelling Area",
- "Bufferage Clippers",
- "Slow Gauze Thread Manipulator",
- "Terratoast Piling",
- "Accounting and Warehouse Conducer",
- "Able Hopscotch Mirrors",
- "Jolly Main Legacy Circuitry",
-]
-
-
-class Command(BaseCommand):
- help = """
- Creates a bunch of people and organisations for them to work in.
-
- Also creates users and roles as these are required fields.
- """
-
- def add_arguments(self, parser: CommandParser) -> None:
- parser.add_argument("number", nargs=1, type=int)
-
- def handle(self, *args, **options):
- number = options["number"][0]
-
- # Set up some reasonable Modes and SubModes
- m1 = Mode.objects.create(descriptor="Rail")
- m2 = Mode.objects.create(descriptor="Maritime")
-
- sb1 = Submode.objects.create(descriptor="Light Rail", mode=m1)
- sb2 = Submode.objects.create(descriptor="Rail Maintenance", mode=m1)
- sb3 = Submode.objects.create(descriptor="Rail Infrastructure", mode=m1)
- sb4 = Submode.objects.create(descriptor="International Rail", mode=m1)
- sb5 = Submode.objects.create(descriptor="Passenger Port", mode=m2)
- sb6 = Submode.objects.create(descriptor="Freight Port", mode=m2)
- sb7 = Submode.objects.create(descriptor="Shipping Infrastructure", mode=m2)
-
- submodes = [sb1, sb2, sb3, sb4, sb5, sb6, sb7]
-
- # we need a User object to completed the updated_by fields in Organisation and Person
- user = (
- UserFactory.create()
- ) # we need to have at least one user for the updated_by field
-
- # Create 40 Organisation objects
- orgs = [
- OrganisationFactory.create(submode=submodes[randint(0, len(submodes) - 1)])
- for org in range(40)
- ]
- # Create 40 Address objects
- addr_type = AddressType.objects.create(descriptor="Primary Address")
- for org in orgs:
- AddressFactory.create(type=addr_type, organisation=org)
-
- roles = [
- RoleFactory.create() for x in range(10)
- ] # because we have a many-to-many relationship with Role, we need to create one and pass it in
- for org in orgs:
- PersonFactory.create(
- role=choice(roles),
- updated_by=user,
- predecessor=None,
- organisation__submode=choice(submodes),
- organisation=org,
- )
-
- inspector_role = RoleFactory.create(name="Compliance Inspector")
-
- # set up some EngagementEvents
-
- p1 = PersonFactory.create(
- role=choice(roles),
- updated_by=user,
- predecessor=None,
- organisation__submode=choice(submodes),
- organisation=org,
- )
- p2 = PersonFactory.create(
- role=choice(roles),
- updated_by=user,
- predecessor=None,
- organisation__submode=choice(submodes),
- organisation=org,
- )
- p3 = PersonFactory.create(
- role=choice(roles),
- updated_by=user,
- predecessor=None,
- organisation__submode=choice(submodes),
- organisation=org,
- )
-
- regulator_org = OrganisationFactory.create(
- submode=None,
- name="The Regulator",
- designation_type=3,
- registered_company_name="The Regulator - HMG",
- comments="This is the real regulator.",
- )
-
- inspectors = [
- PersonFactory.create(
- role=inspector_role,
- updated_by=user,
- job_title="Compliance Inspector",
- predecessor=None,
- organisation__submode=None,
- organisation=regulator_org,
- )
- for _ in range(5)
- ]
-
- etf1 = EngagementTypeFactory(descriptor="Information Notice")
- etf2 = EngagementTypeFactory(descriptor="Designation Letter")
- etf3 = EngagementTypeFactory(
- descriptor="CAF - Initial Submission", enforcement_instrument=False
- )
-
- EngagementEventFactory.create(type=etf1, user=user, participants=[p1, p2])
- EngagementEventFactory.create(type=etf2, user=user, participants=[p3])
-
- # Quality gradings
- q_descriptors = ["Q1", "Q2", "Q3", "Q4", "Q5"]
- for g in q_descriptors:
- GradingFactory.create(descriptor=g, type="QUALITY")
-
- # Confidence gradings
- c_descriptors = ["C1", "C2", "C3", "C4", "C5"]
- for g in c_descriptors:
- GradingFactory.create(descriptor=g, type="CONFIDENCE")
-
- # File store
- FileStoreFactory.create(physical_location_organisation=orgs[1])
-
- # Every org gets on CAF for now
- for org in orgs:
- # create a CAF and ApplicableService for it
- self._create_caf_app_service(c_descriptors, org, q_descriptors)
-
- # CAF submissions - they create EngagementEvents
- # Get a random CAF
- _caf = CAF.objects.get(pk=1) # we should have one by now
- EngagementEventFactory.create(
- type=etf3, user=user, participants=[inspectors[1], p2], related_caf=_caf
- )
-
- # We want to simulate 4 CAF Objectives
- c_obj_a = CAFObjective.objects.create(name="Objective A: Managing security risk",
- description="An important objective to fix the world.", order_id=1)
- c_obj_b = CAFObjective.objects.create(name="Objective B: Protecting Against Cyber Attack",
- description="An important objective to fix the world.", order_id=2)
- c_obj_c = CAFObjective.objects.create(name="Objective C: Detecting Cyber Security Events",
- description="An important objective to fix the world.", order_id=3)
- c_obj_d = CAFObjective.objects.create(name="Objective D: Minimising the Impact of Cyber Security Incidents",
- description="An important objective to fix the world.", order_id=4)
-
- # For each Objective, let's create four Principles
- p_a1 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_a.id,
- designation="A1",
- title="Governance",
- description="When you don't have Governance, you have nothing.",
- order_id=1
- )
- p_a2 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_a.id,
- designation="A2",
- title="Risk Management",
- description="Don't take a risk, and don't get nowhere.",
- order_id=2
- )
- p_a3 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_a.id,
- designation="A3",
- title="Asset Management",
- description="Without assets, you have no raw materials to work with.",
- order_id=3
- )
- p_a4 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_a.id,
- designation="A4",
- title="Supply Chain",
- description="You need to get your stuff from somewhere.",
- order_id=4
- )
-
- p_b1 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_b.id,
- designation="B1",
- title="Service Protection & Policies",
- description="Put in place the right protections for a future of security.",
- order_id=1
- )
- p_b2 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_b.id,
- designation="B2",
- title="Identity and Access Control",
- description="Stop the wrong people getting at your critical assets, okay.",
- order_id=2
- )
- p_b3 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_b.id,
- designation="B3",
- title="Data Security",
- description="Data is the new oil...",
- order_id=3
- )
- p_b4 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_b.id,
- designation="B4",
- title="System Security",
- description="If you have complicated systems, they need some sort of security.",
- order_id=4
- )
-
- p_b5 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_b.id,
- designation="B5",
- title="Resilience Networks and Systems",
- description="When all else fails, there is always food to be cooked.",
- order_id=5
- )
-
- p_b6 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_b.id,
- designation="B6",
- title="Staff Awareness and Training",
- description="You must ensure your people are trained and equipped for making a difference.",
- order_id=6
- )
-
- # Only two of these
- p_c1 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_c.id,
- designation="C1",
- title="Security Monitoring",
- description="Monitoring the bits and pieces is the most important aspect of your life.",
- order_id=1
- )
- p_c2 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_c.id,
- designation="C2",
- title="Proactive Security and Event Discovery",
- description="If we're not proactive, we will get found out eventually.",
- order_id=2
- )
-
- # Only two of these too
- p_d1 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_d.id,
- designation="D1",
- title="Response and Recovery Planning",
- description="Responding to the security problems since 1999...",
- order_id=1
- )
- p_d2 = CAFPrinciple.objects.create(
- caf_objective_id=c_obj_d.id,
- designation="D2",
- title="Improvements",
- description="Improving all the things.",
- order_id=2
- )
-
- # Based on these principles, it's time to gen some CAFContributingOutcomes
- cos = [
- CAFContributingOutcome.objects.create(
- designation="A1.a",
- name="Board Direction",
- description="You have forced your Board to listen to your whinging about cyber.",
- principle_id=p_a1.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="A1.b",
- name="Roles and Responsibilities",
- description="Your elders and betters are impressed and they continue to make money after your project "
- "implementation.",
- principle_id=p_a1.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="A1.c",
- name="Decision-making",
- description="If you are forced to participate in the Crystal Maze, you'll choose the coorect path across "
- "the Gordian runway.",
- principle_id=p_a1.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="A2.a",
- name="Risk Management Process",
- description="You take mighty risks, but they are mitigated by more sensible people around you - good.",
- principle_id=p_a2.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="A2.b",
- name="Assurance",
- description="We all make mistakes, but in doing this well you at least have told people what you're doing.",
- principle_id=p_a2.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="A3.a",
- name="Asset Management",
- description="Taking care of these aspects of corporate life is commensurate with the money-making way.",
- principle_id=p_a3.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="A4.a",
- name="Supply Chain",
- description="Task your customers to take on all the risk, the debt, the hassle - you're good to go.",
- principle_id=p_a4.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B1.a",
- name="Policy and Process Development",
- description="You are getting your process and policy development spot on.",
- principle_id=p_b1.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B1.b",
- name="Policy and Process Information",
- description="Differs from the above in a few ways that will be discussed at a later date.",
- principle_id=p_b1.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="B2.a",
- name="ID Verification, Authentication and Authorisation",
- description="It is very important for people to be able to confirm they they truly are. Underneath.",
- principle_id=p_b2.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B2.b",
- name="Device Management",
- description="Your devices, and their safe and sustainable use, is crucuial to the longevity of your company.",
- principle_id=p_b2.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="B2.c",
- name="Privileged User Mangement",
- description="You ensure that even the most privileged members of your senior management are under the impression "
- "that they exude inequality, in all instances.",
- principle_id=p_b2.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="B3.a",
- name="Understanding Data",
- description="You, more than anyone else in the organisation, know what your data means to you.",
- principle_id=p_b3.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B3.b",
- name="Data in Transit",
- description="You are protecting your data as it moves along the Information Superhighway.",
- principle_id=p_b3.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="B3.c",
- name="Stored Data",
- description="You have stored your data in accordance with local environment laws.",
- principle_id=p_b3.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="B3.d",
- name="Mobile Data",
- description="Mobile data is when data moves because it is stored in a moving thing.",
- principle_id=p_b3.id,
- order_id=4
- ),
- CAFContributingOutcome.objects.create(
- designation="B3.e",
- name="Media/Equipment Sanitisation",
- description="You routinely wash and clean the legs and bottom brackets of your server racks.",
- principle_id=p_b3.id,
- order_id=5
- ),
- CAFContributingOutcome.objects.create(
- designation="B4.a",
- name="Secure by Design",
- description="You have designed your systems to be secure and you're sure no one is going to hack into them.",
- principle_id=p_b4.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B4.b",
- name="Secure Configuration",
- description="When you are able to configure your systems and software well, you can say you have Secure "
- "Configuration. Only then, mind.",
- principle_id=p_b4.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="B4.c",
- name="Secure Management",
- description="Somehow this one is different from all the others but I'm not sure how.",
- principle_id=p_b4.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="B4.d",
- name="Vulnerability Management",
- description="Doing this well means that you are at the top of your vulnerability scale.",
- principle_id=p_b4.id,
- order_id=4
- ),
- CAFContributingOutcome.objects.create(
- designation="B5.a",
- name="Resilience Preparation",
- description="Totally ready for the coming of the cyber apocalyse. You practice this stuff regular.",
- principle_id=p_b5.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B5.b",
- name="Design for Resilience",
- description="This stuff is built into your very working model.",
- principle_id=p_b5.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="B5.c",
- name="Backups",
- description="There is nowhere for you to go as a professional if you don't make backups of your data.",
- principle_id=p_b5.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="B6.a",
- name="Cyber Security Culture",
- description="You're making them understand that this isn't going to go away in a hurry.",
- principle_id=p_b6.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="B6.b",
- name="Cyber Security Training",
- description="By the way, when youre staff are able to write C code, your company understands buffer "
- "overflows.",
- principle_id=p_b6.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="C1.a",
- name="Monitoring Coverage",
- description="At all times, you are vigilent to the threats out there, and ready to tackle them.",
- principle_id=p_c1.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="C1.b",
- name="Securing Logs",
- description="You might think the are a waste of time, but the Board thinks logging is important.",
- principle_id=p_c1.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="C1.c",
- name="Generating Alerts",
- description="Boo! There, you coped with it because you're good at this.",
- principle_id=p_c1.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="C1.d",
- name="Identifying Security Incidents",
- description="You are wary of all the possible things that could go wrong and you have a plan to deal. Well "
- "done.",
- principle_id=p_c1.id,
- order_id=4
- ),
- CAFContributingOutcome.objects.create(
- designation="C1.e",
- name="Monitoring Tools and Skills",
- description="All these things matter in today's switched on cyber-aware environment.",
- principle_id=p_c1.id,
- order_id=5
- ),
- CAFContributingOutcome.objects.create(
- designation="C2.a",
- name="System Abnormalities for Attack Detection",
- description="Make sure you know how to look for things that mighty wrong on your network.",
- principle_id=p_c2.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="C2.b",
- name="Proactive Attack Discovery",
- description="When you go out looking for the bad stuff, you usefully find it - and you know this in spades.",
- principle_id=p_c2.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="D1.a",
- name="Response Plan",
- description="Yeah, we know it's boring but you've got to have one.",
- principle_id=p_d1.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="D1.b",
- name="Response and Recovery Capability",
- description="If you can't get back on your feet after you've been beat, where are you, really?",
- principle_id=p_d1.id,
- order_id=2
- ),
- CAFContributingOutcome.objects.create(
- designation="D1.c",
- name="Testing and Exercising",
- description="One of the most important things you should not be forgetting is this.",
- principle_id=p_d1.id,
- order_id=3
- ),
- CAFContributingOutcome.objects.create(
- designation="D2.a",
- name="Incident Root Cause and Analysis",
- description="I guess there are always lessons learned, no matter how we good we are.",
- principle_id=p_d2.id,
- order_id=1
- ),
- CAFContributingOutcome.objects.create(
- designation="D2.b",
- name="Using Incidents to Drive Improvements",
- description="This is the kind of thing that bores us to tears but it simply has to be done.",
- principle_id=p_d2.id,
- order_id=2
- )
- ]
-
- achievement_levels = [
- AchievementLevel.objects.create(
- descriptor="Not Achieved",
- colour_description="Red",
- colour_hex="#000001"
- ),
- AchievementLevel.objects.create(
- descriptor="Partially Achieved",
- colour_description="Amber",
- colour_hex="#000002"
- ),
- AchievementLevel.objects.create(
- descriptor="Achieved",
- colour_description="Green",
- colour_hex="#000003"
- )
- ]
-
- for al in achievement_levels:
- for co in cos:
- for igp in range(1, random.randint(2,5)):
- dtext_fake = Faker()
- fake_txt = f"IGP {igp}/{al.descriptor}/{co.designation}: {dtext_fake.paragraph()}"
- IGP.objects.create(
- achievement_level=al,
- contributing_outcome=co,
- descriptive_text=fake_txt
- )
-
- # We want to create a CAF with a bunch of scoring now...
- _caf2 = CAF.objects.get(pk=1)
-
- _completer = Person.objects.get(pk=1)
- caf_assessment = CAFAssessment.objects.create(
- caf_id=_caf2.id, completer_id=_completer.id, comments="Random Comments"
- )
-
- # TODO Need to create as many of these as there are ContributingOutcomes
- # Create a single CAFSelfAssessmentOutcomeScore
- for c in cos:
- CAFAssessmentOutcomeScore.objects.create(
- caf_assessment_id=caf_assessment.id,
- caf_contributing_outcome_id=c.id,
- assessment_score=random.choice(["Achieved", "Partially Achieved", "Not Achieved"]),
- baseline_assessment_score=random.choice(["Achieved", "Partially Achieved", "Not Achieved"])
- )
-
- # TODO - adapt this so that it records more than just Persons created
-
- self.stdout.write(
- self.style.SUCCESS(
- f"Created {number} Person object[s]! Go forth and multiply."
- )
- )
-
- def _create_caf_app_service(self, c_descriptors, org, q_descriptors):
- caf = CAFFactory.create(
- quality_grading__descriptor=random.choice(q_descriptors),
- confidence_grading__descriptor=random.choice(c_descriptors),
- triage_review_date=None,
- triage_review_inspector=None,
- )
- # Each CAF can have up to three systems associated with it
- for _ in range(random.randint(1, 3)):
- ApplicableSystemFactory.create(
- name=random.choice(fnames), organisation=org, caf=caf,
- )
diff --git a/ctrack/organisations/migrations/0004_auto_20200513_1441.py b/ctrack/organisations/migrations/0004_auto_20200513_1441.py
new file mode 100644
index 0000000..180211a
--- /dev/null
+++ b/ctrack/organisations/migrations/0004_auto_20200513_1441.py
@@ -0,0 +1,18 @@
+# Generated by Django 3.0.5 on 2020-05-13 14:41
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('organisations', '0003_auto_20200424_1607'),
+ ]
+
+ operations = [
+ migrations.AlterField(
+ model_name='organisation',
+ name='oes',
+ field=models.BooleanField(default=True),
+ ),
+ ]