mirror of
https://github.com/Tivix/django-rest-auth.git
synced 2025-02-11 15:30:34 +03:00
Merge pull request #367 from philippeluickx/d/pre_existing_acounts_check
Checking for pre-existing accounts
This commit is contained in:
commit
ee791a402e
|
@ -1,6 +1,7 @@
|
|||
from django.http import HttpRequest
|
||||
from django.conf import settings
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from django.contrib.auth import get_user_model
|
||||
|
||||
try:
|
||||
from allauth.account import app_settings as allauth_settings
|
||||
|
@ -111,6 +112,20 @@ class SocialLoginSerializer(serializers.Serializer):
|
|||
raise serializers.ValidationError(_('Incorrect value'))
|
||||
|
||||
if not login.is_existing:
|
||||
# We have an account already signed up in a different flow
|
||||
# with the same email address: raise an exception.
|
||||
# This needs to be handled in the frontend. We can not just
|
||||
# link up the accounts due to security constraints
|
||||
if(allauth_settings.UNIQUE_EMAIL):
|
||||
# Do we have an account already with this email address?
|
||||
existing_account = get_user_model().objects.filter(
|
||||
email=login.user.email,
|
||||
).count()
|
||||
if(existing_account != 0):
|
||||
# There is an account already
|
||||
raise serializers.ValidationError(
|
||||
_("A user is already registered with this e-mail address."))
|
||||
|
||||
login.lookup()
|
||||
login.save(request, connect=True)
|
||||
attrs['user'] = login.account.user
|
||||
|
|
|
@ -2,3 +2,4 @@ django-allauth>=0.25.0
|
|||
responses>=0.3.0
|
||||
flake8==2.4.0
|
||||
djangorestframework-jwt>=1.7.2
|
||||
djangorestframework>=3.6.4
|
||||
|
|
|
@ -275,8 +275,12 @@ class TestSocialAuth(TestsMixin, TestCase):
|
|||
'access_token': 'abc123'
|
||||
}
|
||||
|
||||
self.post(self.fb_login_url, data=payload, status_code=200)
|
||||
self.assertIn('key', self.response.json.keys())
|
||||
# You should not have access to an account created through register
|
||||
# by loging in through FB with an account that has the same
|
||||
# email address.
|
||||
self.post(self.fb_login_url, data=payload, status_code=400)
|
||||
# self.post(self.fb_login_url, data=payload, status_code=200)
|
||||
# self.assertIn('key', self.response.json.keys())
|
||||
|
||||
@responses.activate
|
||||
@override_settings(
|
||||
|
|
Loading…
Reference in New Issue
Block a user