Skip to main content

Patient registration module for clinicedc/edc projects

Project description

pypi actions codecov downloads

edc-registration

The model RegisteredSubject is used by the Edc as the master subject registration table. Only one record may exist per individual. The table has space for PII so typically a RegisteredSubject instance is created or updated on completion of the informed consent. As always, PII in the Edc is encrypted at rest using django-crypto-field.

For the model and signal to be registered you need to add the AppConfig to your INSTALLED_APPS:

INSTALLED_APPS = (
    ....
    'edc_registration.apps.AppConfig',
    ....
)

UpdatesOrCreatesRegistrationModelMixin

RegisteredSubject is never edited directly by the user. Instead some other model with the needed attributes is used as a proxy. To have a model perform the task of creating or updating RegisteredSubject, declare it with the UpdatesOrCreatesRegistrationModelMixin.

For example, a model, SubjectEligibility or a screening model creates or updates RegisteredSubject without a subject identifier then a model such as the SubjectConsent in tests.models, also creates or updates a subject’s RegisteredSubject instance on save. For this to happen, both models are declared with the UpdatesOrCreatesRegistrationModelMixin:

class SubjectEligibility(UniqueSubjectIdentifierModelMixin,
                         UpdatesOrCreatesRegistrationModelMixin, BaseUuidModel):

    screening_identifier = models.CharField(
        max_length=36,
        null=True,
        unique=True)

    @property
    def registration_unique_field(self):
        return 'screening_identifier'

    def update_subject_identifier_on_save(self):
        """Overridden to not set the subject identifier on save.
        """
        if not self.subject_identifier:
            self.subject_identifier = self.subject_identifier_as_pk.hex
            self.subject_identifier_aka = self.subject_identifier_as_pk.hex
        return self.subject_identifier

class SubjectConsent(
    ConsentModelMixin, UpdatesOrCreatesRegistrationModelMixin,
    CreateAppointmentsMixin, IdentityFieldsMixin, ReviewFieldsMixin,
    PersonalFieldsMixin, CitizenFieldsMixin, VulnerabilityFieldsMixin,
    BaseUuidModel):

            @property
        def registration_unique_field(self):
            return 'screening_identifier'

        class Meta:
            app_label = 'my_app'

The property registration_unique_field returns a model attribute that is used to set a registration identifier on RegisteredSubject.

A subject’s RegisteredSubject instance is created and updated in a post_save signal. As mentioned, it is never edited directly by the user.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

edc-registration-0.3.30.tar.gz (35.9 kB view details)

Uploaded Source

Built Distribution

edc_registration-0.3.30-py3-none-any.whl (48.5 kB view details)

Uploaded Python 3

File details

Details for the file edc-registration-0.3.30.tar.gz.

File metadata

  • Download URL: edc-registration-0.3.30.tar.gz
  • Upload date:
  • Size: 35.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for edc-registration-0.3.30.tar.gz
Algorithm Hash digest
SHA256 d5c38d330a2c6eb81ac0a44d65ceba28e4a1ed195a65c18ea8a767e7d86f48f6
MD5 ff3ad945c83fe9bfd931f68d219a7b21
BLAKE2b-256 e40320e16f2325aad01855571cf4f552a62fa21947d53fb2f073fe722e136a0a

See more details on using hashes here.

File details

Details for the file edc_registration-0.3.30-py3-none-any.whl.

File metadata

File hashes

Hashes for edc_registration-0.3.30-py3-none-any.whl
Algorithm Hash digest
SHA256 51ba0b15dd9010e01bde2bea9c90ac86e1b40fb1a4c6500a0ecbaf9a20aede63
MD5 06a81a4be382948a8f658e0dc8e97a49
BLAKE2b-256 e2e0348b9f3ff0c7ba76217cb93b4171d7c18bc2e6ca0eff3d9737d2c1eceefa

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page