Handle network error
This commit is contained in:
parent
c13ed2a5b2
commit
dbc4f6f2ee
|
|
@ -13,7 +13,7 @@ from django.conf import settings
|
||||||
from django.contrib.auth import authenticate, login
|
from django.contrib.auth import authenticate, login
|
||||||
from graphene import relay
|
from graphene import relay
|
||||||
|
|
||||||
from core.hep_client import HepClient, HepClientUnauthorizedException
|
from core.hep_client import HepClient, HepClientUnauthorizedException, HepClientException
|
||||||
from registration.models import License
|
from registration.models import License
|
||||||
from users.models import MagentoToken, User, Role, UserRole, SchoolClass
|
from users.models import MagentoToken, User, Role, UserRole, SchoolClass
|
||||||
|
|
||||||
|
|
@ -39,8 +39,7 @@ class Login(relay.ClientIDMutation):
|
||||||
if settings.USE_LOCAL_REGISTRATION:
|
if settings.USE_LOCAL_REGISTRATION:
|
||||||
user = authenticate(username=username, password=password)
|
user = authenticate(username=username, password=password)
|
||||||
if user is None:
|
if user is None:
|
||||||
error = LoginError(field='invalid_credentials')
|
return cls.return_login_error('invalid_credentials')
|
||||||
return cls(success=False, errors=[error])
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
hep_client = HepClient()
|
hep_client = HepClient()
|
||||||
|
|
@ -48,8 +47,9 @@ class Login(relay.ClientIDMutation):
|
||||||
try:
|
try:
|
||||||
token = hep_client.customer_token(username, password)
|
token = hep_client.customer_token(username, password)
|
||||||
except HepClientUnauthorizedException:
|
except HepClientUnauthorizedException:
|
||||||
error = LoginError(field='invalid_credentials')
|
return cls.return_login_error('invalid_credentials')
|
||||||
return cls(success=False, errors=[error])
|
except HepClientException:
|
||||||
|
return cls.return_login_error('unknown_error')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
user = User.objects.get(email=username)
|
user = User.objects.get(email=username)
|
||||||
|
|
@ -60,23 +60,27 @@ class Login(relay.ClientIDMutation):
|
||||||
magento_token.token = token['token']
|
magento_token.token = token['token']
|
||||||
magento_token.save()
|
magento_token.save()
|
||||||
|
|
||||||
if not hep_client.is_email_verified(username):
|
try:
|
||||||
error = LoginError(field='email_not_verified')
|
if not hep_client.is_email_verified(username):
|
||||||
return cls(success=False, errors=[error])
|
return cls.return_login_error('email_not_verified')
|
||||||
|
except HepClientException:
|
||||||
|
return cls.return_login_error('unknown_error')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
license = License.objects.get(licensee=user)
|
license = License.objects.get(licensee=user)
|
||||||
# Todo how handle invalid license? Cron Job? How to select correct license? Save all licenses? History?
|
# Todo how handle invalid license? Cron Job? How to select correct license? Save all licenses? History?
|
||||||
except License.DoesNotExist:
|
except License.DoesNotExist:
|
||||||
product = hep_client.myskillbox_product_for_customer(settings.HEP_ADMIN_TOKEN, user.hep_id)
|
try:
|
||||||
|
product = hep_client.myskillbox_product_for_customer(settings.HEP_ADMIN_TOKEN, user.hep_id)
|
||||||
|
except HepClientException:
|
||||||
|
return cls.return_login_error('unknown_error')
|
||||||
|
|
||||||
if product:
|
if product:
|
||||||
license = License.objects.create_license_for_role(user, product['activated'],
|
license = License.objects.create_license_for_role(user, product['activated'],
|
||||||
product['raw'], product['edition'])
|
product['raw'], product['edition'])
|
||||||
# todo handle no license case
|
# todo handle no license case
|
||||||
else:
|
else:
|
||||||
error = LoginError(field='no_valid_license')
|
return cls.return_login_error('no_valid_license')
|
||||||
return cls(success=False, errors=[error])
|
|
||||||
|
|
||||||
UserRole.objects.create_role_for_user(user, license.for_role.key)
|
UserRole.objects.create_role_for_user(user, license.for_role.key)
|
||||||
|
|
||||||
|
|
@ -84,14 +88,16 @@ class Login(relay.ClientIDMutation):
|
||||||
SchoolClass.create_default_group_for_teacher(user)
|
SchoolClass.create_default_group_for_teacher(user)
|
||||||
|
|
||||||
if not license.is_valid():
|
if not license.is_valid():
|
||||||
error = LoginError(field='no_valid_license')
|
return cls.return_login_error('no_valid_license')
|
||||||
return cls(success=False, errors=[error])
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
login(info.context, user)
|
login(info.context, user)
|
||||||
return cls(success=True, errors=[])
|
return cls(success=True, errors=[])
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def return_login_error(cls, message):
|
||||||
|
error = LoginError(field=message)
|
||||||
|
return cls(success=False, errors=[error])
|
||||||
|
|
||||||
|
|
||||||
class UserMutations:
|
class UserMutations:
|
||||||
login = Login.Field()
|
login = Login.Field()
|
||||||
|
|
|
||||||
|
|
@ -205,6 +205,12 @@ class PasswordResetTests(TestCase):
|
||||||
self.assertFalse(result.get('data').get('login').get('success'))
|
self.assertFalse(result.get('data').get('login').get('success'))
|
||||||
self.assertEqual(result.get('data').get('login').get('errors')[0].get('field'), 'no_valid_license')
|
self.assertEqual(result.get('data').get('login').get('errors')[0].get('field'), 'no_valid_license')
|
||||||
|
|
||||||
|
@patch.object(requests, 'post', return_value=MockResponse(500))
|
||||||
|
def test_user_gets_notified_if_server_error(self, post_mock):
|
||||||
|
result = self.make_login_mutation(ME_DATA['email'], 'test123')
|
||||||
|
|
||||||
|
self.assertFalse(result.get('data').get('login').get('success'))
|
||||||
|
self.assertEqual(result.get('data').get('login').get('errors')[0].get('field'), 'unknown_error')
|
||||||
|
|
||||||
## can login with license and user
|
## can login with license and user
|
||||||
## can login with no user and license
|
## can login with no user and license
|
||||||
|
|
@ -213,37 +219,6 @@ class PasswordResetTests(TestCase):
|
||||||
## cannot login with user and not verfied
|
## cannot login with user and not verfied
|
||||||
## cannot login with user and no license
|
## cannot login with user and no license
|
||||||
## cannot login with user and expired license
|
## cannot login with user and expired license
|
||||||
# non 200 error
|
## non 200 error
|
||||||
# if more than one valid license take correct
|
# if more than one valid license take correct
|
||||||
# if mulitple licenses and one correct take one test in own class
|
# if mulitple licenses and one correct take one test in own class
|
||||||
|
|
||||||
|
|
||||||
# def test_user_cannot_login_with_invalid_password(self):
|
|
||||||
# password = 'test123'
|
|
||||||
# self.user.set_password(password)
|
|
||||||
# self.user.save()
|
|
||||||
#
|
|
||||||
# result = self.make_login_mutation(self.user.email, 'test1234')
|
|
||||||
# self.assertFalse(result.get('data').get('login').get('success'))
|
|
||||||
#
|
|
||||||
# def test_user_with_active_license_can_login(self):
|
|
||||||
# password = 'test123'
|
|
||||||
# self.user.set_password(password)
|
|
||||||
# self.user.save()
|
|
||||||
#
|
|
||||||
# LicenseFactory(license_type=self.teacher_license_type, licensee=self.user)
|
|
||||||
#
|
|
||||||
# result = self.make_login_mutation(self.user.email, password)
|
|
||||||
# self.assertTrue(result.get('data').get('login').get('success'))
|
|
||||||
#
|
|
||||||
# def test_user_with_inactive_license_cannot_login(self):
|
|
||||||
# password = 'test123'
|
|
||||||
# self.user.set_password(password)
|
|
||||||
# self.user.save()
|
|
||||||
#
|
|
||||||
# self.teacher_license_type.active = False
|
|
||||||
# self.teacher_license_type.save()
|
|
||||||
# LicenseFactory(license_type=self.teacher_license_type, licensee=self.user)
|
|
||||||
#
|
|
||||||
# result = self.make_login_mutation(self.user.email, password)
|
|
||||||
# self.assertFalse(result.get('data').get('login').get('success'))
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue