diff options
Diffstat (limited to 'ctrack')
26 files changed, 291 insertions, 289 deletions
diff --git a/ctrack/assessments/migrations/0001_initial.py b/ctrack/assessments/migrations/0001_initial.py index a9c6a43..41c364e 100644 --- a/ctrack/assessments/migrations/0001_initial.py +++ b/ctrack/assessments/migrations/0001_initial.py @@ -1,4 +1,4 @@ -# Generated by Django 3.1.2 on 2020-10-14 16:05 +# Generated by Django 3.1.2 on 2020-10-21 15:51 from django.db import migrations, models import django.db.models.deletion diff --git a/ctrack/assessments/migrations/0002_auto_20201014_1605.py b/ctrack/assessments/migrations/0002_cafassessment_caf.py index 3a20060..3873b4b 100644 --- a/ctrack/assessments/migrations/0002_auto_20201014_1605.py +++ b/ctrack/assessments/migrations/0002_cafassessment_caf.py @@ -1,4 +1,4 @@ -# Generated by Django 3.1.2 on 2020-10-14 16:05 +# Generated by Django 3.1.2 on 2020-10-21 15:51 from django.db import migrations, models import django.db.models.deletion @@ -11,7 +11,6 @@ class Migration(migrations.Migration): dependencies = [ ('caf', '0001_initial'), ('assessments', '0001_initial'), - ('organisations', '0001_initial'), ] operations = [ @@ -20,9 +19,4 @@ class Migration(migrations.Migration): name='caf', field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='caf.caf'), ), - migrations.AddField( - model_name='cafassessment', - name='completer', - field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.person'), - ), ] diff --git a/ctrack/assessments/migrations/0003_cafassessment_completer.py b/ctrack/assessments/migrations/0003_cafassessment_completer.py new file mode 100644 index 0000000..db2a960 --- /dev/null +++ b/ctrack/assessments/migrations/0003_cafassessment_completer.py @@ -0,0 +1,22 @@ +# Generated by Django 3.1.2 on 2020-10-21 15:51 + +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + initial = True + + dependencies = [ + ('assessments', '0002_cafassessment_caf'), + ('organisations', '0001_initial'), + ] + + operations = [ + migrations.AddField( + model_name='cafassessment', + name='completer', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.person'), + ), + ] diff --git a/ctrack/caf/migrations/0001_initial.py b/ctrack/caf/migrations/0001_initial.py index ec2898a..c93b0a2 100644 --- a/ctrack/caf/migrations/0001_initial.py +++ b/ctrack/caf/migrations/0001_initial.py @@ -1,8 +1,6 @@ -# Generated by Django 3.1.2 on 2020-10-14 16:05 +# Generated by Django 3.1.2 on 2020-10-21 15:51 -import ctrack.caf.models from django.db import migrations, models -import django.db.models.deletion class Migration(migrations.Migration): @@ -10,7 +8,6 @@ class Migration(migrations.Migration): initial = True dependencies = [ - ('organisations', '0001_initial'), ] operations = [ @@ -28,22 +25,23 @@ class Migration(migrations.Migration): }, ), migrations.CreateModel( - name='Grading', + name='CAF', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('descriptor', models.CharField(help_text='Q1, C1, etc', max_length=2)), - ('description', models.TextField(max_length=250)), - ('type', models.CharField(choices=[('CONFIDENCE', 'Confidence'), ('QUALITY', 'Quality'), ('MISC', 'Misc')], help_text='Type of grading', max_length=20)), + ('version', models.CharField(blank=True, max_length=10, null=True)), + ('triage_review_date', models.DateField(blank=True, null=True)), + ('comments', models.TextField(max_length=1000)), ], + options={ + 'verbose_name': 'CAF', + }, ), migrations.CreateModel( - name='FileStore', + name='DocumentFile', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('descriptor', models.CharField(max_length=100)), - ('virtual_location', models.CharField(help_text='USB, Rosa, email, etc', max_length=100)), - ('physical_location', models.CharField(blank=True, help_text='Cupboard, room, building, etc', max_length=100)), - ('physical_location_organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation')), + ('name', models.CharField(max_length=255)), + ('type', models.IntegerField(choices=[(1, 'Excel'), (2, 'Word'), (3, 'PDF'), (4, 'Hard Copy')], default=1)), ], ), migrations.CreateModel( @@ -52,35 +50,24 @@ class Migration(migrations.Migration): ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('name', models.CharField(max_length=256)), ('description', models.CharField(max_length=512)), - ('organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation')), - ('systems', models.ManyToManyField(to='caf.ApplicableSystem')), ], ), migrations.CreateModel( - name='DocumentFile', + name='FileStore', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('name', models.CharField(max_length=255)), - ('type', models.IntegerField(choices=[(1, 'Excel'), (2, 'Word'), (3, 'PDF'), (4, 'Hard Copy')], default=1)), - ('file_store_location', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='caf.filestore')), + ('descriptor', models.CharField(max_length=100)), + ('virtual_location', models.CharField(help_text='USB, Rosa, email, etc', max_length=100)), + ('physical_location', models.CharField(blank=True, help_text='Cupboard, room, building, etc', max_length=100)), ], ), migrations.CreateModel( - name='CAF', + name='Grading', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('version', models.CharField(blank=True, max_length=10, null=True)), - ('triage_review_date', models.DateField(blank=True, null=True)), - ('comments', models.TextField(max_length=1000)), - ('confidence_grading', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='confidence_grading', to='caf.grading')), - ('file', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='caf.documentfile')), - ('organisation', models.ForeignKey(on_delete=models.SET(ctrack.caf.models.CAF.get_sentinel_org), to='organisations.organisation')), - ('quality_grading', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='quality_grading', to='caf.grading')), - ('systems', models.ManyToManyField(to='caf.ApplicableSystem')), - ('triage_review_inspector', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='organisations.person')), + ('descriptor', models.CharField(help_text='Q1, C1, etc', max_length=2)), + ('description', models.TextField(max_length=250)), + ('type', models.CharField(choices=[('CONFIDENCE', 'Confidence'), ('QUALITY', 'Quality'), ('MISC', 'Misc')], help_text='Type of grading', max_length=20)), ], - options={ - 'verbose_name': 'CAF', - }, ), ] diff --git a/ctrack/caf/migrations/0002_auto_20201021_1551.py b/ctrack/caf/migrations/0002_auto_20201021_1551.py new file mode 100644 index 0000000..bb9659e --- /dev/null +++ b/ctrack/caf/migrations/0002_auto_20201021_1551.py @@ -0,0 +1,68 @@ +# Generated by Django 3.1.2 on 2020-10-21 15:51 + +import ctrack.caf.models +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + initial = True + + dependencies = [ + ('caf', '0001_initial'), + ('organisations', '0001_initial'), + ] + + operations = [ + migrations.AddField( + model_name='filestore', + name='physical_location_organisation', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation'), + ), + migrations.AddField( + model_name='essentialservice', + name='organisation', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation'), + ), + migrations.AddField( + model_name='essentialservice', + name='systems', + field=models.ManyToManyField(to='caf.ApplicableSystem'), + ), + migrations.AddField( + model_name='documentfile', + name='file_store_location', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='caf.filestore'), + ), + migrations.AddField( + model_name='caf', + name='confidence_grading', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='confidence_grading', to='caf.grading'), + ), + migrations.AddField( + model_name='caf', + name='file', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='caf.documentfile'), + ), + migrations.AddField( + model_name='caf', + name='organisation', + field=models.ForeignKey(on_delete=models.SET(ctrack.caf.models.CAF.get_sentinel_org), to='organisations.organisation'), + ), + migrations.AddField( + model_name='caf', + name='quality_grading', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='quality_grading', to='caf.grading'), + ), + migrations.AddField( + model_name='caf', + name='systems', + field=models.ManyToManyField(to='caf.ApplicableSystem'), + ), + migrations.AddField( + model_name='caf', + name='triage_review_inspector', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='organisations.person'), + ), + ] diff --git a/ctrack/organisations/migrations/0001_initial.py b/ctrack/organisations/migrations/0001_initial.py index c5ab495..e13cafb 100644 --- a/ctrack/organisations/migrations/0001_initial.py +++ b/ctrack/organisations/migrations/0001_initial.py @@ -1,6 +1,5 @@ -# Generated by Django 2.2.12 on 2020-08-27 09:40 +# Generated by Django 3.1.2 on 2020-10-21 15:51 -import django.contrib.auth from django.db import migrations, models import django.db.models.deletion import django_extensions.db.fields @@ -15,6 +14,23 @@ class Migration(migrations.Migration): operations = [ migrations.CreateModel( + name='Address', + fields=[ + ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('line1', models.CharField(max_length=255)), + ('line2', models.CharField(blank=True, max_length=255)), + ('line3', models.CharField(blank=True, max_length=255)), + ('city', models.CharField(max_length=100)), + ('county', models.CharField(blank=True, max_length=100)), + ('postcode', models.CharField(max_length=10)), + ('country', models.CharField(max_length=100)), + ('other_details', models.CharField(blank=True, max_length=255)), + ], + options={ + 'verbose_name_plural': 'Addresses', + }, + ), + migrations.CreateModel( name='AddressType', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), @@ -22,6 +38,27 @@ class Migration(migrations.Migration): ], ), migrations.CreateModel( + name='IncidentReport', + fields=[ + ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('person_involved', models.CharField(blank=True, max_length=100, verbose_name='Name of person reporting/detecting incident')), + ('role', models.CharField(blank=True, help_text='Role of person reporting/detecting incident', max_length=100)), + ('phone_number', models.CharField(max_length=30)), + ('email', models.EmailField(max_length=254)), + ('internal_incident_number', models.CharField(blank=True, max_length=30)), + ('date_time_incident_detected', models.DateTimeField(verbose_name='Date/Time incident detected')), + ('date_time_incident_reported', models.DateTimeField(auto_now=True, verbose_name='Date/Time incident reported')), + ('incident_type', models.CharField(choices=[('Cyber', 'Cyber'), ('Non-Cyber', 'Non-Cyber'), ('Both', 'Both'), ('Power Outage', 'Power Outage')], help_text='This can be appoximate', max_length=20)), + ('incident_status', models.CharField(choices=[('Detected', 'Detected'), ('Suspected', 'Suspected'), ('Resolved', 'Resolved')], max_length=20)), + ('incident_stage', models.CharField(choices=[('Ongoing', 'Ongoing'), ('Ended', 'Ended'), ('Ongoing but managed', 'Ongoing but managed')], max_length=20)), + ('summary', models.TextField(help_text='Please provide a summary of your understanding of the incident, including any impact to services and/or users.')), + ('mitigations', models.TextField(help_text='What investigations and/or mitigations have you or a third party performed or plan to perform?', verbose_name='Investigations or mitigations')), + ('others_informed', models.TextField(help_text='Who else has been informed about this incident?(CSIRT, NCSC, NCA, etc)', verbose_name='Others parties informed')), + ('next_steps', models.TextField(help_text='What are your planned next steps?', verbose_name='Planned next steps')), + ('dft_handle_status', models.CharField(choices=[('QUEUED', 'QUEUED'), ('REVIEWING', 'REVIEWING'), ('WAITING', 'WAITING'), ('COMPLETED', 'COMPLETED')], default='QUEUED', max_length=20)), + ], + ), + migrations.CreateModel( name='Mode', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), @@ -67,8 +104,8 @@ class Migration(migrations.Migration): ('active', models.BooleanField(default=True)), ('date_ended', models.DateField(blank=True, null=True)), ('comments', models.TextField(blank=True, max_length=1000)), - ('organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.Organisation')), - ('predecessor', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='previous_person', to='organisations.Person')), + ('organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation')), + ('predecessor', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='previous_person', to='organisations.person')), ], options={ 'verbose_name_plural': 'People', @@ -86,14 +123,14 @@ class Migration(migrations.Migration): fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('descriptor', models.CharField(max_length=100)), - ('mode', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.Mode')), + ('mode', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.mode')), ], ), migrations.CreateModel( name='Stakeholder', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('person', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.Person')), + ('person', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.person')), ], ), migrations.AddField( @@ -101,51 +138,4 @@ class Migration(migrations.Migration): name='role', field=models.ManyToManyField(to='organisations.Role'), ), - migrations.AddField( - model_name='organisation', - name='submode', - field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='organisations.Submode'), - ), - migrations.CreateModel( - name='IncidentReport', - fields=[ - ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('person_involved', models.CharField(blank=True, max_length=100, verbose_name='Name of person reporting/detecting incident')), - ('role', models.CharField(blank=True, help_text='Role of person reporting/detecting incident', max_length=100)), - ('phone_number', models.CharField(max_length=30)), - ('email', models.EmailField(max_length=254)), - ('internal_incident_number', models.CharField(blank=True, max_length=30)), - ('date_time_incident_detected', models.DateTimeField(verbose_name='Date/Time incident detected')), - ('date_time_incident_reported', models.DateTimeField(auto_now=True, verbose_name='Date/Time incident reported')), - ('incident_type', models.CharField(choices=[('Cyber', 'Cyber'), ('Non-Cyber', 'Non-Cyber'), ('Both', 'Both'), ('Power Outage', 'Power Outage')], help_text='This can be appoximate', max_length=20)), - ('incident_status', models.CharField(choices=[('Detected', 'Detected'), ('Suspected', 'Suspected'), ('Resolved', 'Resolved')], max_length=20)), - ('incident_stage', models.CharField(choices=[('Ongoing', 'Ongoing'), ('Ended', 'Ended'), ('Ongoing but managed', 'Ongoing but managed')], max_length=20)), - ('summary', models.TextField(help_text='Please provide a summary of your understanding of the incident, including any impact to services and/or users.')), - ('mitigations', models.TextField(help_text='What investigations and/or mitigations have you or a third party performed or plan to perform?', verbose_name='Investigations or mitigations')), - ('others_informed', models.TextField(help_text='Who else has been informed about this incident?(CSIRT, NCSC, NCA, etc)', verbose_name='Others parties informed')), - ('next_steps', models.TextField(help_text='What are your planned next steps?', verbose_name='Planned next steps')), - ('dft_handle_status', models.CharField(choices=[('QUEUED', 'QUEUED'), ('REVIEWING', 'REVIEWING'), ('WAITING', 'WAITING'), ('COMPLETED', 'COMPLETED')], default='QUEUED', max_length=20)), - ('organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.Organisation')), - ('reporting_person', models.ForeignKey(on_delete=models.SET(django.contrib.auth.get_user_model), to='organisations.Person', verbose_name='Person reporting the incident')), - ], - ), - migrations.CreateModel( - name='Address', - fields=[ - ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('line1', models.CharField(max_length=255)), - ('line2', models.CharField(blank=True, max_length=255)), - ('line3', models.CharField(blank=True, max_length=255)), - ('city', models.CharField(max_length=100)), - ('county', models.CharField(blank=True, max_length=100)), - ('postcode', models.CharField(max_length=10)), - ('country', models.CharField(max_length=100)), - ('other_details', models.CharField(blank=True, max_length=255)), - ('organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='addresses', to='organisations.Organisation')), - ('type', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.AddressType', verbose_name='Address Type')), - ], - options={ - 'verbose_name_plural': 'Addresses', - }, - ), ] diff --git a/ctrack/organisations/migrations/0002_auto_20201015_1955.py b/ctrack/organisations/migrations/0002_auto_20201015_1955.py deleted file mode 100644 index dcc2463..0000000 --- a/ctrack/organisations/migrations/0002_auto_20201015_1955.py +++ /dev/null @@ -1,26 +0,0 @@ -# Generated by Django 3.1.2 on 2020-10-15 19:55 - -import ctrack.organisations.models -from django.conf import settings -from django.db import migrations, models - - -class Migration(migrations.Migration): - - dependencies = [ - migrations.swappable_dependency(settings.AUTH_USER_MODEL), - ('organisations', '0001_initial'), - ] - - operations = [ - migrations.AddField( - model_name='organisation', - name='deputy_lead_inspector', - field=models.ForeignKey(null=True, on_delete=models.SET(ctrack.organisations.models.Organisation.get_sentinel_user), related_name='deputy_inspector', to=settings.AUTH_USER_MODEL), - ), - migrations.AddField( - model_name='organisation', - name='lead_inspector', - field=models.ForeignKey(null=True, on_delete=models.SET(ctrack.organisations.models.Organisation.get_sentinel_user), related_name='lead_inspector', to=settings.AUTH_USER_MODEL), - ), - ] diff --git a/ctrack/organisations/migrations/0002_auto_20201021_1551.py b/ctrack/organisations/migrations/0002_auto_20201021_1551.py new file mode 100644 index 0000000..b9afa58 --- /dev/null +++ b/ctrack/organisations/migrations/0002_auto_20201021_1551.py @@ -0,0 +1,55 @@ +# Generated by Django 3.1.2 on 2020-10-21 15:51 + +import ctrack.organisations.models +from django.conf import settings +import django.contrib.auth +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + initial = True + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('organisations', '0001_initial'), + ] + + operations = [ + migrations.AddField( + model_name='organisation', + name='deputy_lead_inspector', + field=models.ForeignKey(null=True, on_delete=models.SET(ctrack.organisations.models.Organisation.get_sentinel_user), related_name='deputy_inspector', to=settings.AUTH_USER_MODEL), + ), + migrations.AddField( + model_name='organisation', + name='lead_inspector', + field=models.ForeignKey(null=True, on_delete=models.SET(ctrack.organisations.models.Organisation.get_sentinel_user), related_name='lead_inspector', to=settings.AUTH_USER_MODEL), + ), + migrations.AddField( + model_name='organisation', + name='submode', + field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='organisations.submode'), + ), + migrations.AddField( + model_name='incidentreport', + name='organisation', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation'), + ), + migrations.AddField( + model_name='incidentreport', + name='reporting_person', + field=models.ForeignKey(on_delete=models.SET(django.contrib.auth.get_user_model), to='organisations.person', verbose_name='Person reporting the incident'), + ), + migrations.AddField( + model_name='address', + name='organisation', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='addresses', to='organisations.organisation'), + ), + migrations.AddField( + model_name='address', + name='type', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.addresstype', verbose_name='Address Type'), + ), + ] diff --git a/ctrack/organisations/templates/organisations/organisation_detail.html b/ctrack/organisations/templates/organisations/organisation_detail.html index cb5a54d..fe744fe 100644 --- a/ctrack/organisations/templates/organisations/organisation_detail.html +++ b/ctrack/organisations/templates/organisations/organisation_detail.html @@ -150,7 +150,7 @@ </h5> <div class="card-subtitle mb-2"> <span class="badge badge-info">{{ event.type_descriptor }}</span> - <span class="badge badge-light">{{ event.datetime|date:"l j F Y" }}, {{ event.datetime|date:"G:i" }}</span></h5> + <span class="badge badge-light">{{ event.date|date:"l j F Y" }}, {{ event.datetime|date:"G:i" }}</span></h5> </div> <p class="card-text">{{ event.comments }}</p> Participants: diff --git a/ctrack/organisations/tests/factories.py b/ctrack/organisations/tests/factories.py index 330ad79..22f6430 100644 --- a/ctrack/organisations/tests/factories.py +++ b/ctrack/organisations/tests/factories.py @@ -125,7 +125,7 @@ class AddressFactory(DjangoModelFactory): class SingleDateTimeEventFactory(DjangoModelFactory): type_descriptor = None # must pass this in short_description = "Nothing short description" - datetime = "2020-02-10 10:00" + date = "2020-02-10 10:00" comments = "Nothing comments" location = "Gark's basin" user = SubFactory(UserFactory) diff --git a/ctrack/organisations/views.py b/ctrack/organisations/views.py index 5726aa2..324f933 100644 --- a/ctrack/organisations/views.py +++ b/ctrack/organisations/views.py @@ -122,7 +122,7 @@ class OrganisationDetailView(PermissionRequiredMixin, DetailView): ] flat_sdes = sorted( list(itertools.chain.from_iterable(_sdes)), - key=lambda e: e.datetime, + key=lambda e: e.date, reverse=True, ) diff --git a/ctrack/register/admin.py b/ctrack/register/admin.py index 6e6aa26..a896b26 100644 --- a/ctrack/register/admin.py +++ b/ctrack/register/admin.py @@ -16,7 +16,7 @@ class EngagementEventTypeAdmin(admin.ModelAdmin): class SingleDateTimeEventAdmin(admin.ModelAdmin): model = SingleDateTimeEvent - list_display = ("type_descriptor", "short_description", "datetime", "user", "created_date") + list_display = ("type_descriptor", "short_description", "date", "user", "created_date") class CAFSingleDateEventAdmin(admin.ModelAdmin): diff --git a/ctrack/register/forms.py b/ctrack/register/forms.py index cca4cb9..5a612e9 100644 --- a/ctrack/register/forms.py +++ b/ctrack/register/forms.py @@ -51,7 +51,7 @@ class CreateSimpleDateTimeEventForm(forms.ModelForm): "type_descriptor", "private", "short_description", - "datetime", + "date", "participants", "requested_response_date", "response_received_date", @@ -84,7 +84,7 @@ class CreateSimpleDateTimeEventForm(forms.ModelForm): def clean(self): cleaned_data = super().clean() - date = cleaned_data.get("datetime") + date = cleaned_data.get("date") if not date: return cleaned_data # WOOO - walrus operator @@ -128,11 +128,11 @@ class CAFSingleDateEventForm(forms.ModelForm): class CAFTwinDateEventForm(forms.ModelForm): # This constraint in the form prevents two such objects being created # for the same CAF with the same start date, which does not make sense. - def clean_start_date(self): - data = self.cleaned_data["start_date"] + def clean_date(self): + data = self.cleaned_data["date"] caf = self.cleaned_data["related_caf"] existing_obj = ( - CAFTwinDateEvent.objects.filter(start_date=data) + CAFTwinDateEvent.objects.filter(date=data) .filter(related_caf=caf) .first() ) @@ -148,7 +148,7 @@ class CAFTwinDateEventForm(forms.ModelForm): "type_descriptor", "related_caf", "short_description", - "start_date", + "date", "end_date", "comments", ] diff --git a/ctrack/register/migrations/0001_initial.py b/ctrack/register/migrations/0001_initial.py index 1986518..863c575 100644 --- a/ctrack/register/migrations/0001_initial.py +++ b/ctrack/register/migrations/0001_initial.py @@ -1,4 +1,4 @@ -# Generated by Django 3.1.2 on 2020-10-14 16:05 +# Generated by Django 3.1.2 on 2020-10-21 15:51 from django.db import migrations, models @@ -19,10 +19,10 @@ class Migration(migrations.Migration): ('created_date', models.DateTimeField()), ('modified_date', models.DateTimeField()), ('short_description', models.CharField(help_text='Short description of the event. Use Comments field for full detail.', max_length=50)), - ('document_link', models.URLField(blank=True, help_text='URL only - do not try to drag a file here.', max_length=1000, null=True)), + ('document_link', models.URLField(blank=True, help_text='Use this to link to documents on TiME/Sharepoint or elsewhere.', max_length=1000, null=True)), ('comments', models.TextField(blank=True, help_text='Use this to provide further detail about the event.', max_length=1000, null=True)), - ('date', models.DateField()), - ('type_descriptor', models.CharField(choices=[('CAF_INITIAL_CAF_RECEIVED', 'CAF - Initial CAF Received'), ('CAF_FEEDBACK_EMAILED_OES', 'CAF - Emailed to OES'), ('CAF_RECEIVED', 'CAF - Received'), ('CAF_EMAILED_ROSA', 'CAF - Emailed to Rosa'), ('CAF_VALIDATION_SIGN_OFF', 'CAF - Validation Sign Off'), ('CAF_VALIDATION_RECORD_EMAILED_TO_OES', 'CAF - Validation Record Sent to OES')], max_length=50)), + ('date', models.DateField(help_text='DD/MM/YY format')), + ('type_descriptor', models.CharField(choices=[('CAF_INITIAL_CAF_RECEIVED', 'CAF - Initial CAF Received'), ('CAF_FEEDBACK_EMAILED_OES', 'CAF - Emailed to OES'), ('CAF_RECEIVED', 'CAF - Received'), ('CAF_EMAILED_ROSA', 'CAF - Emailed to Rosa'), ('CAF_VALIDATION_SIGN_OFF', 'CAF - Validation Sign Off'), ('CAF_VALIDATION_RECORD_EMAILED_TO_OES', 'CAF - Validation Record Sent to OES')], help_text='Select the event type', max_length=50, verbose_name='Type')), ], ), migrations.CreateModel( @@ -32,9 +32,9 @@ class Migration(migrations.Migration): ('created_date', models.DateTimeField()), ('modified_date', models.DateTimeField()), ('short_description', models.CharField(help_text='Short description of the event. Use Comments field for full detail.', max_length=50)), - ('document_link', models.URLField(blank=True, help_text='URL only - do not try to drag a file here.', max_length=1000, null=True)), + ('document_link', models.URLField(blank=True, help_text='Use this to link to documents on TiME/Sharepoint or elsewhere.', max_length=1000, null=True)), ('comments', models.TextField(blank=True, help_text='Use this to provide further detail about the event.', max_length=1000, null=True)), - ('start_date', models.DateField()), + ('date', models.DateField()), ('end_date', models.DateField(blank=True, null=True)), ('type_descriptor', models.CharField(choices=[('CAF_PEER_REVIEW_PERIOD', 'CAF - Peer Review Period'), ('CAF_VALIDATION_PERIOD', 'CAF - Validation Period')], max_length=50)), ], @@ -64,20 +64,41 @@ class Migration(migrations.Migration): ], ), migrations.CreateModel( + name='NoteEvent', + fields=[ + ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('created_date', models.DateTimeField()), + ('modified_date', models.DateTimeField()), + ('short_description', models.CharField(help_text='Short description of the event. Use Comments field for full detail.', max_length=50)), + ('document_link', models.URLField(blank=True, help_text='Use this to link to documents on TiME/Sharepoint or elsewhere.', max_length=1000, null=True)), + ('comments', models.TextField(blank=True, help_text='Use this to provide further detail about the event.', max_length=1000, null=True)), + ('url', models.URLField(blank=True, help_text='If recording an email, please link to it here. Do not paste the text in the comments box.', max_length=400, null=True, verbose_name='URL')), + ('requested_response_date', models.DateField(blank=True, help_text='DD/MM/YY format', null=True)), + ('response_received_date', models.DateField(blank=True, help_text='DD/MM/YY format', null=True)), + ('private', models.BooleanField(default=False, help_text='Private events can only be seen by you. Official records should not be private, but you can use private events to track your own work.')), + ('type_descriptor', models.CharField(default='NOTE', max_length=50)), + ], + options={ + 'abstract': False, + }, + ), + migrations.CreateModel( name='SingleDateTimeEvent', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_date', models.DateTimeField()), ('modified_date', models.DateTimeField()), ('short_description', models.CharField(help_text='Short description of the event. Use Comments field for full detail.', max_length=50)), - ('document_link', models.URLField(blank=True, help_text='URL only - do not try to drag a file here.', max_length=1000, null=True)), + ('document_link', models.URLField(blank=True, help_text='Use this to link to documents on TiME/Sharepoint or elsewhere.', max_length=1000, null=True)), ('comments', models.TextField(blank=True, help_text='Use this to provide further detail about the event.', max_length=1000, null=True)), - ('location', models.CharField(blank=True, max_length=100)), - ('datetime', models.DateTimeField(help_text='DD/MM/YY HH:MM format please!', verbose_name='Date/Time')), + ('location', models.CharField(blank=True, help_text='If event involved a physical location, indicate here.', max_length=100)), + ('url', models.URLField(blank=True, help_text='If recording an email, please link to it here. Do not paste the text in the comments box.', max_length=400, null=True, verbose_name='URL')), + ('date', models.DateTimeField(help_text='DD/MM/YY HH:MM format please!', verbose_name='Date/Time')), ('requested_response_date', models.DateField(blank=True, help_text='DD/MM/YY format', null=True)), ('response_received_date', models.DateField(blank=True, help_text='DD/MM/YY format', null=True)), - ('type_descriptor', models.CharField(choices=[('MEETING', 'Meeting'), ('PHONE_CALL', 'Phone Call'), ('VIDEO_CALL', 'Video Call'), ('EMAIL', 'Email')], max_length=50)), - ('participants', models.ManyToManyField(blank=True, null=True, to='organisations.Person')), + ('private', models.BooleanField(default=False, help_text='Private events can only be seen by you. Official records should not be private, but you can use private events to track your own work.')), + ('type_descriptor', models.CharField(choices=[('MEETING', 'Meeting'), ('PHONE_CALL', 'Phone Call'), ('VIDEO_CALL', 'Video Call'), ('EMAIL', 'Email')], max_length=50, verbose_name='Event Type')), + ('participants', models.ManyToManyField(to='organisations.Person')), ], options={ 'abstract': False, diff --git a/ctrack/register/migrations/0002_auto_20201014_1605.py b/ctrack/register/migrations/0002_auto_20201021_1551.py index 0d4b440..93c02c8 100644 --- a/ctrack/register/migrations/0002_auto_20201014_1605.py +++ b/ctrack/register/migrations/0002_auto_20201021_1551.py @@ -1,4 +1,4 @@ -# Generated by Django 3.1.2 on 2020-10-14 16:05 +# Generated by Django 3.1.2 on 2020-10-21 15:51 import ctrack.register.models from django.conf import settings @@ -12,10 +12,10 @@ class Migration(migrations.Migration): initial = True dependencies = [ - migrations.swappable_dependency(settings.AUTH_USER_MODEL), - ('organisations', '0001_initial'), - ('caf', '0001_initial'), + ('organisations', '0002_auto_20201021_1551'), ('register', '0001_initial'), + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('caf', '0002_auto_20201021_1551'), ] operations = [ @@ -25,6 +25,16 @@ class Migration(migrations.Migration): field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL), ), migrations.AddField( + model_name='noteevent', + name='organisation', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation'), + ), + migrations.AddField( + model_name='noteevent', + name='user', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL), + ), + migrations.AddField( model_name='engagementevent', name='participants', field=models.ManyToManyField(blank=True, to='organisations.Person'), @@ -66,7 +76,7 @@ class Migration(migrations.Migration): ), migrations.AddConstraint( model_name='caftwindateevent', - constraint=models.CheckConstraint(check=models.Q(_negated=True, end_date__lt=django.db.models.expressions.F('start_date')), name='register_caftwindateevent_cannot_precede_start_date'), + constraint=models.CheckConstraint(check=models.Q(_negated=True, end_date__lt=django.db.models.expressions.F('date')), name='register_caftwindateevent_cannot_precede_start_date'), ), migrations.AddConstraint( model_name='cafsingledateevent', diff --git a/ctrack/register/migrations/0003_auto_20201015_1955.py b/ctrack/register/migrations/0003_auto_20201015_1955.py deleted file mode 100644 index 58d11c1..0000000 --- a/ctrack/register/migrations/0003_auto_20201015_1955.py +++ /dev/null @@ -1,19 +0,0 @@ -# Generated by Django 3.1.2 on 2020-10-15 19:55 - -from django.db import migrations, models - - -class Migration(migrations.Migration): - - dependencies = [ - ('organisations', '0002_auto_20201015_1955'), - ('register', '0002_auto_20201014_1605'), - ] - - operations = [ - migrations.AlterField( - model_name='singledatetimeevent', - name='participants', - field=models.ManyToManyField(blank=True, to='organisations.Person'), - ), - ] diff --git a/ctrack/register/migrations/0004_auto_20201017_1958.py b/ctrack/register/migrations/0004_auto_20201017_1958.py deleted file mode 100644 index d13903d..0000000 --- a/ctrack/register/migrations/0004_auto_20201017_1958.py +++ /dev/null @@ -1,33 +0,0 @@ -# Generated by Django 3.1.2 on 2020-10-17 19:58 - -from django.db import migrations, models - - -class Migration(migrations.Migration): - - dependencies = [ - ('register', '0003_auto_20201015_1955'), - ] - - operations = [ - migrations.AddField( - model_name='singledatetimeevent', - name='private', - field=models.BooleanField(default=False, help_text='Private events can only be seen by you. Official records should not be private, but you can use private events to track your own work.'), - ), - migrations.AddField( - model_name='singledatetimeevent', - name='url', - field=models.URLField(blank=True, help_text='If recording an email, please link to it here. Do not paste the text in the comments box.', max_length=400, null=True, verbose_name='URL'), - ), - migrations.AlterField( - model_name='singledatetimeevent', - name='location', - field=models.CharField(blank=True, help_text='If event involved a physical location, indicate here.', max_length=100), - ), - migrations.AlterField( - model_name='singledatetimeevent', - name='type_descriptor', - field=models.CharField(choices=[('MEETING', 'Meeting'), ('PHONE_CALL', 'Phone Call'), ('VIDEO_CALL', 'Video Call'), ('EMAIL', 'Email'), ('NOTE', 'Note')], max_length=50), - ), - ] diff --git a/ctrack/register/migrations/0005_auto_20201019_0928.py b/ctrack/register/migrations/0005_auto_20201019_0928.py deleted file mode 100644 index ed6f6b5..0000000 --- a/ctrack/register/migrations/0005_auto_20201019_0928.py +++ /dev/null @@ -1,24 +0,0 @@ -# Generated by Django 3.1.2 on 2020-10-19 09:28 - -from django.db import migrations, models - - -class Migration(migrations.Migration): - - dependencies = [ - ('organisations', '0002_auto_20201015_1955'), - ('register', '0004_auto_20201017_1958'), - ] - - operations = [ - migrations.AlterField( - model_name='singledatetimeevent', - name='participants', - field=models.ManyToManyField(to='organisations.Person'), - ), - migrations.AlterField( - model_name='singledatetimeevent', - name='type_descriptor', - field=models.CharField(choices=[('MEETING', 'Meeting'), ('PHONE_CALL', 'Phone Call'), ('VIDEO_CALL', 'Video Call'), ('EMAIL', 'Email'), ('NOTE', 'Note')], max_length=50, verbose_name='Event Type'), - ), - ] diff --git a/ctrack/register/migrations/0006_auto_20201019_1935.py b/ctrack/register/migrations/0006_auto_20201019_1935.py deleted file mode 100644 index 291b594..0000000 --- a/ctrack/register/migrations/0006_auto_20201019_1935.py +++ /dev/null @@ -1,43 +0,0 @@ -# Generated by Django 3.1.2 on 2020-10-19 19:35 - -from django.conf import settings -from django.db import migrations, models -import django.db.models.deletion - - -class Migration(migrations.Migration): - - dependencies = [ - ('organisations', '0002_auto_20201015_1955'), - migrations.swappable_dependency(settings.AUTH_USER_MODEL), - ('register', '0005_auto_20201019_0928'), - ] - - operations = [ - migrations.AlterField( - model_name='singledatetimeevent', - name='type_descriptor', - field=models.CharField(choices=[('MEETING', 'Meeting'), ('PHONE_CALL', 'Phone Call'), ('VIDEO_CALL', 'Video Call'), ('EMAIL', 'Email')], max_length=50, verbose_name='Event Type'), - ), - migrations.CreateModel( - name='NoteEvent', - fields=[ - ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), - ('created_date', models.DateTimeField()), - ('modified_date', models.DateTimeField()), - ('short_description', models.CharField(help_text='Short description of the event. Use Comments field for full detail.', max_length=50)), - ('document_link', models.URLField(blank=True, help_text='URL only - do not try to drag a file here.', max_length=1000, null=True)), - ('comments', models.TextField(blank=True, help_text='Use this to provide further detail about the event.', max_length=1000, null=True)), - ('url', models.URLField(blank=True, help_text='If recording an email, please link to it here. Do not paste the text in the comments box.', max_length=400, null=True, verbose_name='URL')), - ('requested_response_date', models.DateField(blank=True, help_text='DD/MM/YY format', null=True)), - ('response_received_date', models.DateField(blank=True, help_text='DD/MM/YY format', null=True)), - ('private', models.BooleanField(default=False, help_text='Private events can only be seen by you. Official records should not be private, but you can use private events to track your own work.')), - ('type_descriptor', models.CharField(default='NOTE', max_length=50)), - ('organisation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisations.organisation')), - ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), - ], - options={ - 'abstract': False, - }, - ), - ] diff --git a/ctrack/register/models.py b/ctrack/register/models.py index 1ce905a..34dc880 100644 --- a/ctrack/register/models.py +++ b/ctrack/register/models.py @@ -117,7 +117,7 @@ class URLEventMixin(models.Model): class SingleDateTimeEventMixin(models.Model): - datetime = models.DateTimeField( + date = models.DateTimeField( blank=False, verbose_name="Date/Time", help_text="DD/MM/YY HH:MM format please!" ) @@ -133,7 +133,7 @@ class SingleDateMixin(models.Model): class TwinDateMixin(models.Model): - start_date = models.DateField(blank=False, null=False) + date = models.DateField(blank=False, null=False) end_date = models.DateField(blank=True, null=True) class Meta: @@ -249,13 +249,13 @@ class CAFTwinDateEvent(EventBase, CAFMixin, TwinDateMixin): return "".join(["CAFTwinDateEvent(", self.type_descriptor, ")"]) def __str__(self): - return f"CAFTwinDateEvent({self.type_descriptor}) starting {self.start_date}" + return f"CAFTwinDateEvent({self.type_descriptor}) starting {self.date}" class Meta: constraints = [ models.CheckConstraint( name="%(app_label)s_%(class)s_cannot_precede_start_date", - check=~models.Q(end_date__lt=F("start_date")), + check=~models.Q(end_date__lt=F("date")), ) ] diff --git a/ctrack/register/tests/test_forms.py b/ctrack/register/tests/test_forms.py index e059cdf..5a055b6 100644 --- a/ctrack/register/tests/test_forms.py +++ b/ctrack/register/tests/test_forms.py @@ -15,7 +15,7 @@ def test_init(user, org_with_people): { "type_descriptor": "MEETING", # Must be Meeting as that is in the choices param "short_description": "Test short description", - "datetime": "2010-10-10T13:00", + "date": "2010-10-10T13:00", "comments": "Test Comments", "location": "Transient Moats", "participants": people_from_org @@ -33,7 +33,7 @@ def test_simple_event_limited_to_org_participants(user, org, person): { "type_descriptor": "PHONE_CALL", "short_description": "Test Short Description", - "datetime": "2010-10-10 10:00", + "date": "2010-10-10 10:00", "requested_response_date": "2020-12-24", "response_received_date": "2020-12-25", "participants": people_from_org, @@ -49,7 +49,7 @@ def test_cannot_create_disallowed_single_date_event_type_with_form(user, org_wit { "type_descriptor": "NOT ALLOWED EVENT", "short_description": "Test short description", - "datetime": "2020-10-10", + "date": "2020-10-10", "comments": "Test Comments", "participants": org_with_people.get_people() }, @@ -68,7 +68,7 @@ def test_create_simple_datetime_event(user, org_with_people): { "type_descriptor": "PHONE_CALL", "short_description": "Test Short Description", - "datetime": "2010-10-10 10:00", + "date": "2010-10-10 10:00", "requested_response_date": "2020-12-24", "response_received_date": "2020-12-25", "url": "https://fake.url.com", @@ -84,7 +84,7 @@ def test_response_date_cannot_be_before_date(user, org_with_people): { "type_descriptor": "PHONE_CALL", "short_description": "Test Short Description", - "datetime": "2010-10-10 10:00", + "date": "2010-10-10 10:00", "requested_response_date": "2009-12-24", "response_received_date": None, "comments": "Test Comments not needed", @@ -107,7 +107,7 @@ def test_meeting_blank_data(user, org_with_people): user=user, org_slug=None ) assert form.is_valid() is False - assert form.errors == {"datetime": ["This field is required."]} + assert form.errors == {"date": ["This field is required."]} def test_create_note(user, org_with_people): @@ -214,7 +214,7 @@ def test_caf_twin_date_event(user, caf): "type_descriptor": "CAF_PEER_REVIEW_PERIOD", "related_caf": caf, "short_description": "Test Description", - "start_date": "2009-10-01", + "date": "2009-10-01", "end_date": "2015-10-1", "comments": "Meaningless comments", }, @@ -230,7 +230,7 @@ def test_cannot_create_twin_date_event_for_caf_whose_end_date_is_open(allowed_ty "type_descriptor": allowed_type, "related_caf": caf, "short_description": "caf peer review for x company", - "start_date": "2020-10-10", + "date": "2020-10-10", "comments": "nice comments for this event", }, user=user, @@ -240,7 +240,7 @@ def test_cannot_create_twin_date_event_for_caf_whose_end_date_is_open(allowed_ty "type_descriptor": allowed_type, "related_caf": caf, "short_description": "caf peer review for x company", - "start_date": "2020-10-10", + "date": "2020-10-10", "comments": "nice comments for this event", }, user=user, @@ -249,7 +249,7 @@ def test_cannot_create_twin_date_event_for_caf_whose_end_date_is_open(allowed_ty e1.save() assert e2.is_valid() is False assert e2.errors == { - "start_date": ["You cannot have two CAF events starting on the same date."] + "date": ["You cannot have two CAF events starting on the same date."] } @@ -262,7 +262,7 @@ def test_cannot_create_twin_date_event_where_end_date_precedes_start(allowed_typ "type_descriptor": allowed_type, "related_caf": caf, "short_description": "caf peer review for x company", - "start_date": "2020-10-10", + "date": "2020-10-10", "end_date": "2020-10-09", "comments": "nice comments for this event", }, diff --git a/ctrack/register/tests/test_models.py b/ctrack/register/tests/test_models.py index aafd37f..1a89fd5 100644 --- a/ctrack/register/tests/test_models.py +++ b/ctrack/register/tests/test_models.py @@ -47,7 +47,7 @@ def test_caf_twin_date_events(allowed_type, user, caf): type_descriptor=allowed_type, related_caf=caf, short_description="CAF received for X Company", - start_date="2020-10-10", + date="2020-10-10", end_date="2020-10-25", comments="Nice comments for this event", user=user, @@ -64,7 +64,7 @@ def test_caf_twin_date_event_no_end_date(allowed_type, user, caf): type_descriptor=allowed_type, related_caf=caf, short_description="CAF received for X Company", - start_date="2020-10-10", + date="2020-10-10", comments="Nice comments for this event", user=user, ) @@ -173,7 +173,7 @@ def test_single_datetime_event(person, user, allowed_type): url="http://fake.url.com", requested_response_date="2021-01-24", response_received_date=None, - datetime="2020-10-10T15:00", + date="2020-10-10T15:00", comments="Comments on important event", # location is optional user=user, @@ -192,7 +192,7 @@ def test_cannot_create_twin_date_event_model_end_date_precedes_start(allowed_typ CAFTwinDateEvent.objects.create( type_descriptor=allowed_type, related_caf=caf, - start_date="2010-10-10", + date="2010-10-10", end_date="2010-01-01", short_description="Bobbins", user=user, @@ -205,7 +205,7 @@ def test_meeting_event(user, person): e = SingleDateTimeEvent.objects.create( type_descriptor="Meeting", short_description="Big Important Meeting", - datetime="2020-10-10T15:00", + date="2020-10-10T15:00", comments="Nice comments", location="Harvey's House", user=user, diff --git a/ctrack/register/tests/test_views.py b/ctrack/register/tests/test_views.py index 4e8152c..4158692 100644 --- a/ctrack/register/tests/test_views.py +++ b/ctrack/register/tests/test_views.py @@ -25,7 +25,7 @@ class TestSingleDateTimeEvent: expected_fields = [ "type_descriptor", "short_description", - "datetime", + "date", "comments", "location", ] @@ -47,7 +47,7 @@ class TestSingleDateTimeEvent: data = { "type_descriptor": "MEETING", "short_description": "Test Short Description", - "datetime": bad_date, + "date": bad_date, "comments": "Blah...", "location": "The Moon", } diff --git a/ctrack/register/views.py b/ctrack/register/views.py index c8fe1c5..d5b39f3 100644 --- a/ctrack/register/views.py +++ b/ctrack/register/views.py @@ -99,7 +99,7 @@ class SingleDateTimeEventUpdate(UpdateView): fields = [ "type_descriptor", "short_description", - "datetime", + "date", "private", "document_link", "comments", diff --git a/ctrack/users/migrations/0001_initial.py b/ctrack/users/migrations/0001_initial.py index ec91581..a781a77 100644 --- a/ctrack/users/migrations/0001_initial.py +++ b/ctrack/users/migrations/0001_initial.py @@ -1,4 +1,4 @@ -# Generated by Django 3.1.2 on 2020-10-14 16:05 +# Generated by Django 3.1.2 on 2020-10-21 15:51 import django.contrib.auth.models import django.contrib.auth.validators diff --git a/ctrack/users/tests/test_views.py b/ctrack/users/tests/test_views.py index 525e261..e47d22b 100644 --- a/ctrack/users/tests/test_views.py +++ b/ctrack/users/tests/test_views.py @@ -30,7 +30,7 @@ class TestUserProfilePage: url="http://fake.url.com", requested_response_date="2021-01-24", response_received_date=None, - datetime="2020-10-10T15:00", + date="2020-10-10T15:00", comments="Comments on important event", # location is optional user=user, |