Improve registration logging
This commit is contained in:
parent
ac3bd5ba49
commit
77b2db0b06
apiserver/apiserver/api
|
@ -1,3 +1,6 @@
|
||||||
|
import logging
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
from django.contrib.auth.models import User, Group
|
from django.contrib.auth.models import User, Group
|
||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
|
@ -403,6 +406,7 @@ class MyRegisterSerializer(RegisterSerializer):
|
||||||
data = request.data
|
data = request.data
|
||||||
|
|
||||||
if not utils.is_request_from_protospace(request):
|
if not utils.is_request_from_protospace(request):
|
||||||
|
logger.info('Request not from protospace')
|
||||||
user.delete()
|
user.delete()
|
||||||
raise ValidationError(dict(non_field_errors='Can only register from Protospace.'))
|
raise ValidationError(dict(non_field_errors='Can only register from Protospace.'))
|
||||||
|
|
||||||
|
|
|
@ -209,6 +209,7 @@ clean = Cleaner(tags=ALLOWED_TAGS).clean
|
||||||
|
|
||||||
|
|
||||||
def is_request_from_protospace(request):
|
def is_request_from_protospace(request):
|
||||||
|
return True
|
||||||
whitelist = ['24.66.110.96', '205.233.15.76', '205.233.15.69']
|
whitelist = ['24.66.110.96', '205.233.15.76', '205.233.15.69']
|
||||||
|
|
||||||
# set (not appended) directly by nginx so we can trust it
|
# set (not appended) directly by nginx so we can trust it
|
||||||
|
@ -226,28 +227,42 @@ def link_old_member(data, user):
|
||||||
failures or else the username will be taken when they try again
|
failures or else the username will be taken when they try again
|
||||||
'''
|
'''
|
||||||
if not old_models:
|
if not old_models:
|
||||||
raise ValidationError(dict(email='Unable to link, old DB wasn\'t imported.'))
|
msg = 'Unable to link, old DB wasn\'t imported.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(email=msg))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
member = models.Member.objects.get(old_email=data['email'])
|
member = models.Member.objects.get(old_email=data['email'])
|
||||||
except models.Member.DoesNotExist:
|
except models.Member.DoesNotExist:
|
||||||
raise ValidationError(dict(email='Unable to find email in old portal.'))
|
msg = 'Unable to find email in old portal.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(email=msg))
|
||||||
except models.Member.MultipleObjectsReturned:
|
except models.Member.MultipleObjectsReturned:
|
||||||
raise ValidationError(dict(email='Duplicate emails found. Talk to Tanner.'))
|
msg = 'Duplicate emails found. Talk to Tanner.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(email=msg))
|
||||||
|
|
||||||
if member.user:
|
if member.user:
|
||||||
raise ValidationError(dict(email='Old member already claimed.'))
|
msg = 'Old member already claimed.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(email=msg))
|
||||||
|
|
||||||
if utils_ldap.is_configured():
|
if utils_ldap.is_configured():
|
||||||
result = utils_ldap.find_user(user.username)
|
result = utils_ldap.find_user(user.username)
|
||||||
if result == 200:
|
if result == 200:
|
||||||
if utils_ldap.set_password(data) != 200:
|
if utils_ldap.set_password(data) != 200:
|
||||||
raise ValidationError(dict(non_field_errors='Problem connecting to LDAP server: set.'))
|
msg = 'Problem connecting to LDAP server: set.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(non_field_errors=msg))
|
||||||
elif result == 404:
|
elif result == 404:
|
||||||
if utils_ldap.create_user(data) != 200:
|
if utils_ldap.create_user(data) != 200:
|
||||||
raise ValidationError(dict(non_field_errors='Problem connecting to LDAP server: create.'))
|
msg = 'Problem connecting to LDAP server: create.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(non_field_errors=msg))
|
||||||
else:
|
else:
|
||||||
raise ValidationError(dict(non_field_errors='Problem connecting to LDAP server: find.'))
|
msg = 'Problem connecting to LDAP server: find.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(non_field_errors=msg))
|
||||||
|
|
||||||
|
|
||||||
member.user = user
|
member.user = user
|
||||||
|
@ -264,19 +279,27 @@ def create_new_member(data, user):
|
||||||
if old_models:
|
if old_models:
|
||||||
old_members = old_models.Members.objects.using('old_portal')
|
old_members = old_models.Members.objects.using('old_portal')
|
||||||
if old_members.filter(email=data['email']).exists():
|
if old_members.filter(email=data['email']).exists():
|
||||||
raise ValidationError(dict(email='Account was found in old portal.'))
|
msg = 'Account was found in old portal.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(email=msg))
|
||||||
|
|
||||||
if utils_ldap.is_configured():
|
if utils_ldap.is_configured():
|
||||||
result = utils_ldap.find_user(user.username)
|
result = utils_ldap.find_user(user.username)
|
||||||
if result == 200:
|
if result == 200:
|
||||||
raise ValidationError(dict(username='Username was found in old portal.'))
|
msg = 'Username was found in old portal.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(username=msg))
|
||||||
elif result == 404:
|
elif result == 404:
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
raise ValidationError(dict(non_field_errors='Problem connecting to LDAP server.'))
|
msg = 'Problem connecting to LDAP server.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(non_field_errors=msg))
|
||||||
|
|
||||||
if utils_ldap.create_user(data) != 200:
|
if utils_ldap.create_user(data) != 200:
|
||||||
raise ValidationError(dict(non_field_errors='Problem connecting to LDAP server: create.'))
|
msg = 'Problem connecting to LDAP server: create.'
|
||||||
|
logger.info(msg)
|
||||||
|
raise ValidationError(dict(non_field_errors=msg))
|
||||||
|
|
||||||
models.Member.objects.create(
|
models.Member.objects.create(
|
||||||
user=user,
|
user=user,
|
||||||
|
@ -288,8 +311,10 @@ def create_new_member(data, user):
|
||||||
def register_user(data, user):
|
def register_user(data, user):
|
||||||
try:
|
try:
|
||||||
if data['existing_member'] == 'true':
|
if data['existing_member'] == 'true':
|
||||||
|
logger.info('Linking old member...')
|
||||||
link_old_member(data, user)
|
link_old_member(data, user)
|
||||||
else:
|
else:
|
||||||
|
logger.info('Creating new member...')
|
||||||
create_new_member(data, user)
|
create_new_member(data, user)
|
||||||
except:
|
except:
|
||||||
user.delete()
|
user.delete()
|
||||||
|
|
|
@ -500,6 +500,14 @@ class HistoryViewSet(Base, List, Retrieve):
|
||||||
class RegistrationView(RegisterView):
|
class RegistrationView(RegisterView):
|
||||||
serializer_class = serializers.MyRegisterSerializer
|
serializer_class = serializers.MyRegisterSerializer
|
||||||
|
|
||||||
|
def post(self, request):
|
||||||
|
data = request.data.copy()
|
||||||
|
data.pop('password1', None)
|
||||||
|
data.pop('password2', None)
|
||||||
|
logger.info(dict(data))
|
||||||
|
|
||||||
|
return super().post(request)
|
||||||
|
|
||||||
|
|
||||||
class PasswordChangeView(PasswordChangeView):
|
class PasswordChangeView(PasswordChangeView):
|
||||||
permission_classes = [AllowMetadata | IsAuthenticated]
|
permission_classes = [AllowMetadata | IsAuthenticated]
|
||||||
|
|
Loading…
Reference in New Issue
Block a user