From 95a66e4e45e7006a0e65d7e056cb800a23a6b37e Mon Sep 17 00:00:00 2001 From: bart-maykin Date: Thu, 12 Oct 2023 17:14:10 +0200 Subject: [PATCH] :card_file_box: [#65] added actor model fields --- .../klantinteracties/migrations/0005_actor.py | 275 ++++++++++++++++++ .../klantinteracties/models/__init__.py | 1 + .../klantinteracties/models/actoren.py | 157 ++++++++++ .../klantinteracties/models/klantcontacten.py | 22 +- .../klantinteracties/models/mixins.py | 52 ++++ 5 files changed, 506 insertions(+), 1 deletion(-) create mode 100644 src/openklant/components/klantinteracties/migrations/0005_actor.py create mode 100644 src/openklant/components/klantinteracties/models/actoren.py create mode 100644 src/openklant/components/klantinteracties/models/mixins.py diff --git a/src/openklant/components/klantinteracties/migrations/0005_actor.py b/src/openklant/components/klantinteracties/migrations/0005_actor.py new file mode 100644 index 00000000..fcdc1cc8 --- /dev/null +++ b/src/openklant/components/klantinteracties/migrations/0005_actor.py @@ -0,0 +1,275 @@ +# Generated by Django 3.2.18 on 2023-10-13 13:39 + +from django.db import migrations, models +import django.db.models.deletion +import uuid + + +class Migration(migrations.Migration): + dependencies = [ + ("klantinteracties", "0004_digitaaladres"), + ] + + operations = [ + migrations.CreateModel( + name="Actor", + fields=[ + ( + "actoridentifcator_objecttype", + models.CharField( + help_text="Type van het object, bijvoorbeeld: 'INGESCHREVEN NATUURLIJK PERSOON'.", + max_length=200, + verbose_name="Objecttype", + ), + ), + ( + "actoridentifcator_soort_object_id", + models.CharField( + help_text="Naam van de eigenschap die het object identificeert, bijvoorbeeld: 'Burgerservicenummer'.", + max_length=200, + verbose_name="Soort Object ID", + ), + ), + ( + "actoridentifcator_object_id", + models.CharField( + help_text="Waarde van de eigenschap die het object identificeert, bijvoorbeeld: '123456788'.", + max_length=200, + verbose_name="Object ID", + ), + ), + ( + "actoridentifcator_register", + models.CharField( + help_text="Binnen het landschap van registers unieke omschrijving van het register waarin het object is geregistreerd, bijvoorbeeld: 'BRP'.", + max_length=200, + verbose_name="Object ID", + ), + ), + ( + "id", + models.UUIDField( + default=uuid.uuid4, + help_text="Unieke (technische) identificatiecode van de actor.", + primary_key=True, + serialize=False, + unique=True, + ), + ), + ( + "naam", + models.CharField( + help_text="Naam van de actor.", + max_length=200, + verbose_name="Naam", + ), + ), + ( + "soort_actor", + models.CharField( + choices=[ + ("medewerker", "Medewerker"), + ("geautomatiseerde_actor", "Geautomatiseerde actor"), + ("organisatorische_eenheid", "Organisatorische eenheid"), + ], + help_text="Geeft aan van welke specifieke soort actor sprake is.", + max_length=24, + verbose_name="Soort actor", + ), + ), + ( + "indicatie_actief", + models.BooleanField( + help_text="Geeft aan of aan de actor nog betrokken mag worden bij nieuwe klantcontacten. Voor niet-actieve is dit niet toegestaan.", + verbose_name="Indicatie actief", + ), + ), + ], + options={ + "verbose_name": "actor", + "verbose_name_plural": "actoren", + }, + ), + migrations.AddField( + model_name="klantcontact", + name="klantcontact", + field=models.ForeignKey( + blank=True, + help_text="De persoon of organisatie die betrokken was bij een klantcontact.", + null=True, + on_delete=django.db.models.deletion.SET_NULL, + related_name="klantcontacten", + to="klantinteracties.klantcontact", + verbose_name="Klant contact", + ), + ), + migrations.CreateModel( + name="OrganisatorischeEenheid", + fields=[ + ( + "id", + models.AutoField( + auto_created=True, + primary_key=True, + serialize=False, + verbose_name="ID", + ), + ), + ( + "omschrijving", + models.CharField( + blank=True, + help_text="Omschrijving van de geautomatiseerde actor.", + max_length=200, + verbose_name="Omschrijving", + ), + ), + ( + "email", + models.EmailField( + blank=True, + help_text="Elektronisch postadres waaronder de MEDEWERKER in de regel bereikbaar is.", + max_length=254, + verbose_name="email address", + ), + ), + ( + "faxnummer", + models.CharField( + help_text="Faxnummer waaronder de organisatorische eenheid in de regel bereikbaar is.", + max_length=20, + verbose_name="Faxnummer", + ), + ), + ( + "telefoonnummer", + models.CharField( + help_text="Telefoonnummer waaronder de MEDEWERKER in de regel bereikbaar is.", + max_length=20, + verbose_name="Telefoonnummer", + ), + ), + ( + "actor", + models.ForeignKey( + help_text="'GeautomatiseerdeActor' was 'Actor'", + on_delete=django.db.models.deletion.CASCADE, + related_name="organisatorische_eenheid", + to="klantinteracties.actor", + verbose_name="Actor", + ), + ), + ], + options={ + "verbose_name": "organisatorische eenheid", + }, + ), + migrations.CreateModel( + name="Medewerker", + fields=[ + ( + "id", + models.AutoField( + auto_created=True, + primary_key=True, + serialize=False, + verbose_name="ID", + ), + ), + ( + "functie", + models.CharField( + help_text="Functie van de geautomatiseerde actor of beschrijving van de werkzaamheden die deze uitvoert.", + max_length=40, + verbose_name="Functie", + ), + ), + ( + "email", + models.EmailField( + blank=True, + help_text="Elektronisch postadres waaronder de MEDEWERKER in de regel bereikbaar is.", + max_length=254, + verbose_name="email address", + ), + ), + ( + "telefoonnummer", + models.CharField( + help_text="Telefoonnummer waaronder de MEDEWERKER in de regel bereikbaar is.", + max_length=20, + verbose_name="Telefoonnummer", + ), + ), + ( + "actor", + models.ForeignKey( + help_text="'GeautomatiseerdeActor' was 'Actor'", + on_delete=django.db.models.deletion.CASCADE, + related_name="medewerker", + to="klantinteracties.actor", + verbose_name="Actor", + ), + ), + ], + options={ + "verbose_name": "medewerker", + "verbose_name_plural": "Mederwerkers", + }, + ), + migrations.CreateModel( + name="GeautomatiseerdeActor", + fields=[ + ( + "id", + models.AutoField( + auto_created=True, + primary_key=True, + serialize=False, + verbose_name="ID", + ), + ), + ( + "functie", + models.CharField( + help_text="Functie van de geautomatiseerde actor of beschrijving van de werkzaamheden die deze uitvoert.", + max_length=40, + verbose_name="Functie", + ), + ), + ( + "omschrijving", + models.CharField( + blank=True, + help_text="Omschrijving van de geautomatiseerde actor.", + max_length=200, + verbose_name="Omschrijving", + ), + ), + ( + "actor", + models.ForeignKey( + help_text="'GeautomatiseerdeActor' was 'Actor'", + on_delete=django.db.models.deletion.CASCADE, + related_name="geautomatiseerde_actor", + to="klantinteracties.actor", + verbose_name="Actor", + ), + ), + ], + options={ + "verbose_name": "geautomatiseerde actor", + "verbose_name_plural": "geautomatiseerde actoren", + }, + ), + migrations.AddField( + model_name="klantcontact", + name="actoren", + field=models.ManyToManyField( + help_text="De actoren die tijdens het klantcontant contact had met klanten of hun vertegenwoordigers.", + related_name="klantcontacten", + to="klantinteracties.Actor", + verbose_name="Actoren", + ), + ), + ] diff --git a/src/openklant/components/klantinteracties/models/__init__.py b/src/openklant/components/klantinteracties/models/__init__.py index 7167c60a..84012ef7 100644 --- a/src/openklant/components/klantinteracties/models/__init__.py +++ b/src/openklant/components/klantinteracties/models/__init__.py @@ -1,3 +1,4 @@ +from .actoren import * # noqa from .digitaal_adres import * # noqa from .klantcontacten import * # noqa from .partijen import * # noqa diff --git a/src/openklant/components/klantinteracties/models/actoren.py b/src/openklant/components/klantinteracties/models/actoren.py new file mode 100644 index 00000000..a4a351f2 --- /dev/null +++ b/src/openklant/components/klantinteracties/models/actoren.py @@ -0,0 +1,157 @@ +import uuid + +from django.db import models +from django.utils.translation import gettext_lazy as _ + +from .constants import SoortActor +from .mixins import ActorIdentifcatorMixin + + +class Actor(ActorIdentifcatorMixin): + id = models.UUIDField( + primary_key=True, + unique=True, + default=uuid.uuid4, + help_text=_("Unieke (technische) identificatiecode van de actor."), + ) + # TODO: add FK to Interne Taak + naam = models.CharField( + _("Naam"), + help_text=_("Naam van de actor."), + max_length=200, + ) + soort_actor = models.CharField( + _("Soort actor"), + help_text=_("Geeft aan van welke specifieke soort actor sprake is."), + choices=SoortActor.choices, + max_length=24, + ) + indicatie_actief = models.BooleanField( + _("Indicatie actief"), + help_text=_( + "Geeft aan of aan de actor nog betrokken mag worden bij nieuwe klantcontacten. " + "Voor niet-actieve is dit niet toegestaan." + ), + blank=False, + ) + + class Meta: + verbose_name = _("actor") + verbose_name_plural = _("actoren") + + def __str__(self): + return self.naam + + +class GeautomatiseerdeActor(models.Model): + actor = models.ForeignKey( + Actor, + on_delete=models.CASCADE, + verbose_name=_("Actor"), + related_name="geautomatiseerde_actor", + help_text=_("'GeautomatiseerdeActor' was 'Actor'"), + null=False, + ) + functie = models.CharField( + _("Functie"), + help_text=_( + "Functie van de geautomatiseerde actor of beschrijving van de werkzaamheden die deze uitvoert." + ), + max_length=40, + ) + omschrijving = models.CharField( + _("Omschrijving"), + help_text=_("Omschrijving van de geautomatiseerde actor."), + max_length=200, + blank=True, + ) + + class Meta: + verbose_name = _("geautomatiseerde actor") + verbose_name_plural = _("geautomatiseerde actoren") + + def __str__(self): + return self.functie + + +class Medewerker(models.Model): + actor = models.ForeignKey( + Actor, + on_delete=models.CASCADE, + verbose_name=_("Actor"), + related_name="medewerker", + help_text=_("'GeautomatiseerdeActor' was 'Actor'"), + null=False, + ) + functie = models.CharField( + _("Functie"), + help_text=_( + "Functie van de geautomatiseerde actor of beschrijving van de werkzaamheden die deze uitvoert." + ), + max_length=40, + ) + email = models.EmailField( + _("email address"), + help_text=_( + "Elektronisch postadres waaronder de MEDEWERKER in de regel bereikbaar is." + ), + blank=True, + ) + telefoonnummer = models.CharField( + _("Telefoonnummer"), + help_text=_( + "Telefoonnummer waaronder de MEDEWERKER in de regel bereikbaar is." + ), + max_length=20, + ) + + class Meta: + verbose_name = _("medewerker") + verbose_name_plural = _("Mederwerkers") + + def __str__(self): + return self.functie + + +class OrganisatorischeEenheid(models.Model): + actor = models.ForeignKey( + Actor, + on_delete=models.CASCADE, + verbose_name=_("Actor"), + related_name="organisatorische_eenheid", + help_text=_("'GeautomatiseerdeActor' was 'Actor'"), + null=False, + ) + omschrijving = models.CharField( + _("Omschrijving"), + help_text=_("Omschrijving van de geautomatiseerde actor."), + max_length=200, + blank=True, + ) + email = models.EmailField( + _("email address"), + help_text=_( + "Elektronisch postadres waaronder de MEDEWERKER in de regel bereikbaar is." + ), + blank=True, + ) + faxnummer = models.CharField( + _("Faxnummer"), + help_text=_( + "Faxnummer waaronder de organisatorische eenheid in de regel bereikbaar is." + ), + max_length=20, + ) + telefoonnummer = models.CharField( + _("Telefoonnummer"), + help_text=_( + "Telefoonnummer waaronder de MEDEWERKER in de regel bereikbaar is." + ), + max_length=20, + ) + + class Meta: + verbose_name = _("organisatorische eenheid") + + def __str__(self): + return self.omschrijving diff --git a/src/openklant/components/klantinteracties/models/klantcontacten.py b/src/openklant/components/klantinteracties/models/klantcontacten.py index e8918809..2fbf7354 100644 --- a/src/openklant/components/klantinteracties/models/klantcontacten.py +++ b/src/openklant/components/klantinteracties/models/klantcontacten.py @@ -6,6 +6,7 @@ from vng_api_common.descriptors import GegevensGroepType +from .actoren import Actor from .constants import Initiator, Klantcontrol from .digitaal_adres import DigitaalAdres @@ -19,7 +20,26 @@ class Klantcontact(models.Model): "Unieke (technische) identificatiecode van de betrokkene bij klantcontact." ), ) - # TODO: add fk to Actor + klantcontact = models.ForeignKey( + "self", + on_delete=models.SET_NULL, + related_name="klantcontacten", + verbose_name=_("Klant contact"), + help_text=_( + "De persoon of organisatie die betrokken was bij een klantcontact." + ), + blank=True, + null=True, + ) + actoren = models.ManyToManyField( + Actor, + verbose_name=_("Actoren"), + related_name="klantcontacten", + help_text=_( + "De actoren die tijdens het klantcontant contact had met klanten of hun vertegenwoordigers." + ), + blank=False, + ) # TODO: add fk to Onderwerpobject # TODO: add fk to Inhoudsobject nummer = models.CharField( diff --git a/src/openklant/components/klantinteracties/models/mixins.py b/src/openklant/components/klantinteracties/models/mixins.py new file mode 100644 index 00000000..91224800 --- /dev/null +++ b/src/openklant/components/klantinteracties/models/mixins.py @@ -0,0 +1,52 @@ +from django.db import models +from django.utils.translation import gettext_lazy as _ + +from vng_api_common.descriptors import GegevensGroepType + + +class ActorIdentifcatorMixin(models.Model): + actoridentifcator_objecttype = models.CharField( + _("Objecttype"), + help_text=_( + "Type van het object, bijvoorbeeld: 'INGESCHREVEN NATUURLIJK PERSOON'." + ), + max_length=200, + blank=False, + ) + actoridentifcator_soort_object_id = models.CharField( + _("Soort Object ID"), + help_text=_( + "Naam van de eigenschap die het object identificeert, bijvoorbeeld: 'Burgerservicenummer'." + ), + max_length=200, + blank=False, + ) + actoridentifcator_object_id = models.CharField( + _("Object ID"), + help_text=_( + "Waarde van de eigenschap die het object identificeert, bijvoorbeeld: '123456788'." + ), + max_length=200, + blank=False, + ) + actoridentifcator_register = models.CharField( + _("Object ID"), + help_text=_( + "Binnen het landschap van registers unieke omschrijving van het register waarin " + "het object is geregistreerd, bijvoorbeeld: 'BRP'." + ), + max_length=200, + blank=False, + ) + + actoridentifcator = GegevensGroepType( + { + "objecttype": actoridentifcator_objecttype, + "soort object id": actoridentifcator_soort_object_id, + "object id": actoridentifcator_object_id, + "register": actoridentifcator_register, + } + ) + + class Meta: + abstract = True