Skip to main content

Django app to make one-to-one relations easier to work with

Project description

Smart One-To-One Field

For Django

pypi pre-commit.ci status tests ci

django-smartonetoonefield provides utility fields discussed in this Fusionbox blog post

Compatibility

  • Python: >= 3.12
  • Django: >= 4.2

Installation

  1. Install the latest version:

    pip install django-smartonetoonefield
    
    poetry add django-smartonetoonefield
    
  2. Add smartonetoonefield to INSTALLED_APPS in your project's settings.py.

Usage

AutoOneToOneField

If you can create a related model by just filling in one field, then AutoOneToOneField will simplify your code.

To use, define an AutoOneToOneField field on a model with a relation to another field. This will ensure that the related model object will always exist, even if it must be created upon first access.

models.py:

class CustomerProfile(models.Model):
    user = AutoOneToOneField('User', related_name='customer_profile')
user = User.objects.all()[0]
user.customer_profile  # Always returns a customer profile

SoftOneToOneField

If you cannot create the related model by simply setting the foreign key on the related model, then a SoftOneToOneField might work better for you.

With SoftOneToOneField, if the related model object exists, the lookup will work as normal. But if the related model object does not exist, then the attribute will be None.

models.py:

class CustomerProfile(models.Model):
    user = SoftOneToOneField('User', related_name='customer_profile')

views.py:

class MyProfileView(DetailView):
    def get_context_data(self, **kwargs):
        kwargs = super(MyProfileView, self).get_context_data(**kwargs)
        # This will not raise an exception if the customer_profile does
        # not exist
        kwargs.update(my_profile=self.customer_profile)
        return kwargs

AddFlagOneToOneField

Sometimes, when you need to check if a related model exists or not, it can be unwieldy to query the relation directly. A workaround to this is to define properties on the reverse related model:

models.py:

class User(AbstractUser):
    # ...
    def is_customer(self):
        return hasattr(self, 'customer_profile')


class CustomerProfile(models.Model):
    user = models.OneToOneField('User', related_name='customer_profile')

However, this can necessitate creating a custom default user model for a project, and this can be impossible if you need to override a model in a third party Django app.

Instead of overriding models or querying the related fields directly, the AddFlagOneToOneField will automatically add flags to the related model to make it easier to query related fields:

models.py:

class CustomerProfile(models.Model):
    user = AddFlagOneToOneField('auth.User', related_name='customer_profile',
                                flag_name='is_customer')


class MerchantProfile(models.Model):
    user = AddFlagOneToOneField('auth.User', related_name='merchant_profile',
                                flag_name='is_merchant')


class EmployeeProfile(models.Model):
    user = AddFlagOneToOneField('auth.User', related_name='employee_profile',
                                flag_name='is_employee')

views.py:

user = User.objects.get(email='customer@example.com')
user.is_customer  # True
user.is_merchant  # False
user.is_employee  # False

Since the AddFlagOneToOneField won't throw exceptions on access, you don't have to override, inherit, or modify other models when using the specified flags.

TODO

I have intentionally kept this app very small to minimize the maintenance burden. But contributions are very welcome!

License

BSD

Project details


Download files

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

Source Distribution

django_smartonetoonefield-0.1.0.tar.gz (3.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_smartonetoonefield-0.1.0-py3-none-any.whl (4.0 kB view details)

Uploaded Python 3

File details

Details for the file django_smartonetoonefield-0.1.0.tar.gz.

File metadata

File hashes

Hashes for django_smartonetoonefield-0.1.0.tar.gz
Algorithm Hash digest
SHA256 045ac72ac6f35bccd16cf67277a27c1bd19ec74b0c35ebffee3197795d4c22a0
MD5 41b8083276205d924e3be717c87ffd16
BLAKE2b-256 9af03965dfe4ef3eeee4c1d315acfd2bd6cbcaca30bf93a6343f242d4258839b

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_smartonetoonefield-0.1.0.tar.gz:

Publisher: publish.yaml on blag/django-smartonetoonefield

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file django_smartonetoonefield-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_smartonetoonefield-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 83aa35417a4f142385d28942ca3d3ccb3d9983fb2bea4d6a425ecfbaefa15f11
MD5 6836a0f1ed7557c199e2869824edfd28
BLAKE2b-256 559268dc3c45a8b483506f980f07fc56b8170cc3cb7302809fe711e3eea4441f

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_smartonetoonefield-0.1.0-py3-none-any.whl:

Publisher: publish.yaml on blag/django-smartonetoonefield

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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