From de426ff0d1045e9dfc2e0843ff9f55b4a3cb0ce8 Mon Sep 17 00:00:00 2001 From: Josh Smith Date: Wed, 23 Jan 2019 03:27:35 -0800 Subject: [PATCH 1/3] Remove custom email field attribute Django already provides this: https://docs.djangoproject.com/en/2.1/topics/auth/customizing/#django.contrib.auth.models.AbstractBaseUser.get_email_field_name --- simple_email_confirmation/models.py | 14 +++----------- 1 file changed, 3 insertions(+), 11 deletions(-) diff --git a/simple_email_confirmation/models.py b/simple_email_confirmation/models.py index 3f43139..60a0615 100644 --- a/simple_email_confirmation/models.py +++ b/simple_email_confirmation/models.py @@ -24,16 +24,8 @@ class SimpleEmailConfirmationUserMixin(object): Provides python-level functionality only. """ - # if your User object stores the User's primary email address - # in a place other than User.email, you can override the - # primary_email_field_name and/or primary_email get/set methods. - # All access to a User's primary_email in this app passes through - # these two get/set methods. - - primary_email_field_name = 'email' - def get_primary_email(self): - return getattr(self, self.primary_email_field_name) + return getattr(self, self.get_email_field_name()) def set_primary_email(self, email, require_confirmed=True): "Set an email address as primary" @@ -44,8 +36,8 @@ def set_primary_email(self, email, require_confirmed=True): if email not in self.confirmed_emails and require_confirmed: raise EmailNotConfirmed() - setattr(self, self.primary_email_field_name, email) - self.save(update_fields=[self.primary_email_field_name]) + setattr(self, self.get_email_field_name(), email) + self.save(update_fields=[self.get_email_field_name()]) primary_email_changed.send( sender=self, old_email=old_email, new_email=email, ) From 40ba30c115ead40fb300c595a6b6e1d0749fb75b Mon Sep 17 00:00:00 2001 From: Josh Smith Date: Thu, 31 Jan 2019 11:57:03 -0800 Subject: [PATCH 2/3] Add backwards compatibility and deprecation notice --- simple_email_confirmation/models.py | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/simple_email_confirmation/models.py b/simple_email_confirmation/models.py index 60a0615..96c3bdc 100644 --- a/simple_email_confirmation/models.py +++ b/simple_email_confirmation/models.py @@ -1,4 +1,5 @@ from __future__ import unicode_literals +import warnings from django.conf import settings from django.contrib.auth import get_user_model @@ -25,7 +26,21 @@ class SimpleEmailConfirmationUserMixin(object): """ def get_primary_email(self): - return getattr(self, self.get_email_field_name()) + if hasattr(self, 'primary_email_field_name'): + # Warn user about 'primary_email_field_name' deprecation + warnings.simplefilter('default') + warnings.warn( + ( + "Use 'EMAIL_FIELD' instead of 'primary_email_field_name' " + 'to set the primary email field name. ' + 'For more information, see: ' + 'https://docs.djangoproject.com/en/2.1/topics/auth/customizing/#django.contrib.auth.models.CustomUser.EMAIL_FIELD' # noqa + ), + DeprecationWarning, + ) + return getattr(self, 'primary_email_field_name') + + return self.get_email_field_name() def set_primary_email(self, email, require_confirmed=True): "Set an email address as primary" @@ -36,8 +51,8 @@ def set_primary_email(self, email, require_confirmed=True): if email not in self.confirmed_emails and require_confirmed: raise EmailNotConfirmed() - setattr(self, self.get_email_field_name(), email) - self.save(update_fields=[self.get_email_field_name()]) + setattr(self, self.get_primary_email(), email) + self.save(update_fields=[self.get_primary_email()]) primary_email_changed.send( sender=self, old_email=old_email, new_email=email, ) From 935d271ad6adae092bd04e79a2fdb155ce9226cc Mon Sep 17 00:00:00 2001 From: Josh Smith Date: Tue, 12 Mar 2019 17:01:53 -0700 Subject: [PATCH 3/3] Working... --- Pipfile | 13 ++++ Pipfile.lock | 108 ++++++++++++++++++++++++++++ simple_email_confirmation/models.py | 2 +- 3 files changed, 122 insertions(+), 1 deletion(-) create mode 100644 Pipfile create mode 100644 Pipfile.lock diff --git a/Pipfile b/Pipfile new file mode 100644 index 0000000..60cfaf4 --- /dev/null +++ b/Pipfile @@ -0,0 +1,13 @@ +[[source]] +name = "pypi" +url = "https://pypi.org/simple" +verify_ssl = true + +[dev-packages] + +[packages] +tox = "*" +coverage = "*" + +[requires] +python_version = "3.7" diff --git a/Pipfile.lock b/Pipfile.lock new file mode 100644 index 0000000..1d4b865 --- /dev/null +++ b/Pipfile.lock @@ -0,0 +1,108 @@ +{ + "_meta": { + "hash": { + "sha256": "7e30636907605f258aab78122bdd67c343e43ad684c556c3dcd737f3213017e9" + }, + "pipfile-spec": 6, + "requires": { + "python_version": "3.7" + }, + "sources": [ + { + "name": "pypi", + "url": "https://pypi.org/simple", + "verify_ssl": true + } + ] + }, + "default": { + "coverage": { + "hashes": [ + "sha256:09e47c529ff77bf042ecfe858fb55c3e3eb97aac2c87f0349ab5a7efd6b3939f", + "sha256:0a1f9b0eb3aa15c990c328535655847b3420231af299386cfe5efc98f9c250fe", + "sha256:0cc941b37b8c2ececfed341444a456912e740ecf515d560de58b9a76562d966d", + "sha256:10e8af18d1315de936d67775d3a814cc81d0747a1a0312d84e27ae5610e313b0", + "sha256:1b4276550b86caa60606bd3572b52769860a81a70754a54acc8ba789ce74d607", + "sha256:1e8a2627c48266c7b813975335cfdea58c706fe36f607c97d9392e61502dc79d", + "sha256:2b224052bfd801beb7478b03e8a66f3f25ea56ea488922e98903914ac9ac930b", + "sha256:447c450a093766744ab53bf1e7063ec82866f27bcb4f4c907da25ad293bba7e3", + "sha256:46101fc20c6f6568561cdd15a54018bb42980954b79aa46da8ae6f008066a30e", + "sha256:4710dc676bb4b779c4361b54eb308bc84d64a2fa3d78e5f7228921eccce5d815", + "sha256:510986f9a280cd05189b42eee2b69fecdf5bf9651d4cd315ea21d24a964a3c36", + "sha256:5535dda5739257effef56e49a1c51c71f1d37a6e5607bb25a5eee507c59580d1", + "sha256:5a7524042014642b39b1fcae85fb37556c200e64ec90824ae9ecf7b667ccfc14", + "sha256:5f55028169ef85e1fa8e4b8b1b91c0b3b0fa3297c4fb22990d46ff01d22c2d6c", + "sha256:6694d5573e7790a0e8d3d177d7a416ca5f5c150742ee703f3c18df76260de794", + "sha256:6831e1ac20ac52634da606b658b0b2712d26984999c9d93f0c6e59fe62ca741b", + "sha256:77f0d9fa5e10d03aa4528436e33423bfa3718b86c646615f04616294c935f840", + "sha256:828ad813c7cdc2e71dcf141912c685bfe4b548c0e6d9540db6418b807c345ddd", + "sha256:85a06c61598b14b015d4df233d249cd5abfa61084ef5b9f64a48e997fd829a82", + "sha256:8cb4febad0f0b26c6f62e1628f2053954ad2c555d67660f28dfb1b0496711952", + "sha256:a5c58664b23b248b16b96253880b2868fb34358911400a7ba39d7f6399935389", + "sha256:aaa0f296e503cda4bc07566f592cd7a28779d433f3a23c48082af425d6d5a78f", + "sha256:ab235d9fe64833f12d1334d29b558aacedfbca2356dfb9691f2d0d38a8a7bfb4", + "sha256:b3b0c8f660fae65eac74fbf003f3103769b90012ae7a460863010539bb7a80da", + "sha256:bab8e6d510d2ea0f1d14f12642e3f35cefa47a9b2e4c7cea1852b52bc9c49647", + "sha256:c45297bbdbc8bb79b02cf41417d63352b70bcb76f1bbb1ee7d47b3e89e42f95d", + "sha256:d19bca47c8a01b92640c614a9147b081a1974f69168ecd494687c827109e8f42", + "sha256:d64b4340a0c488a9e79b66ec9f9d77d02b99b772c8b8afd46c1294c1d39ca478", + "sha256:da969da069a82bbb5300b59161d8d7c8d423bc4ccd3b410a9b4d8932aeefc14b", + "sha256:ed02c7539705696ecb7dc9d476d861f3904a8d2b7e894bd418994920935d36bb", + "sha256:ee5b8abc35b549012e03a7b1e86c09491457dba6c94112a2482b18589cc2bdb9" + ], + "index": "pypi", + "version": "==4.5.2" + }, + "filelock": { + "hashes": [ + "sha256:b8d5ca5ca1c815e1574aee746650ea7301de63d87935b3463d26368b76e31633", + "sha256:d610c1bb404daf85976d7a82eb2ada120f04671007266b708606565dd03b5be6" + ], + "version": "==3.0.10" + }, + "pluggy": { + "hashes": [ + "sha256:8ddc32f03971bfdf900a81961a48ccf2fb677cf7715108f85295c67405798616", + "sha256:980710797ff6a041e9a73a5787804f848996ecaa6f8a1b1e08224a5894f2074a" + ], + "version": "==0.8.1" + }, + "py": { + "hashes": [ + "sha256:bf92637198836372b520efcba9e020c330123be8ce527e535d185ed4b6f45694", + "sha256:e76826342cefe3c3d5f7e8ee4316b80d1dd8a300781612ddbc765c17ba25a6c6" + ], + "version": "==1.7.0" + }, + "six": { + "hashes": [ + "sha256:3350809f0555b11f552448330d0b52d5f24c91a322ea4a15ef22629740f3761c", + "sha256:d16a0141ec1a18405cd4ce8b4613101da75da0e9a7aec5bdd4fa804d0e0eba73" + ], + "version": "==1.12.0" + }, + "toml": { + "hashes": [ + "sha256:229f81c57791a41d65e399fc06bf0848bab550a9dfd5ed66df18ce5f05e73d5c", + "sha256:235682dd292d5899d361a811df37e04a8828a5b1da3115886b73cf81ebc9100e" + ], + "version": "==0.10.0" + }, + "tox": { + "hashes": [ + "sha256:04f8f1aa05de8e76d7a266ccd14e0d665d429977cd42123bc38efa9b59964e9e", + "sha256:25ef928babe88c71e3ed3af0c464d1160b01fca2dd1870a5bb26c2dea61a17fc" + ], + "index": "pypi", + "version": "==3.7.0" + }, + "virtualenv": { + "hashes": [ + "sha256:8b9abfc51c38b70f61634bf265e5beacf6fae11fc25d355d1871f49b8e45f0db", + "sha256:cceab52aa7d4df1e1871a70236eb2b89fcfe29b6b43510d9738689787c513261" + ], + "version": "==16.4.0" + } + }, + "develop": {} +} diff --git a/simple_email_confirmation/models.py b/simple_email_confirmation/models.py index 96c3bdc..c770f89 100644 --- a/simple_email_confirmation/models.py +++ b/simple_email_confirmation/models.py @@ -40,7 +40,7 @@ def get_primary_email(self): ) return getattr(self, 'primary_email_field_name') - return self.get_email_field_name() + return getattr(self, self.get_email_field_name()) def set_primary_email(self, email, require_confirmed=True): "Set an email address as primary"