mirror of
https://gitlab.com/allianceauth/allianceauth.git
synced 2025-07-09 12:30:15 +02:00
52 lines
2.2 KiB
Python
52 lines
2.2 KiB
Python
from __future__ import unicode_literals
|
|
from django import forms
|
|
from django.utils.translation import ugettext_lazy as _
|
|
from django.contrib.auth.models import User
|
|
from django.conf import settings
|
|
import re
|
|
|
|
|
|
class LoginForm(forms.Form):
|
|
username = forms.CharField(label=_('Username'), max_length=32, required=True)
|
|
password = forms.CharField(label=_('Password'), widget=forms.PasswordInput())
|
|
|
|
if getattr(settings, 'CAPTCHA_ENABLED', False):
|
|
from captcha.fields import ReCaptchaField
|
|
captcha = ReCaptchaField()
|
|
|
|
|
|
class RegistrationForm(forms.Form):
|
|
username = forms.CharField(label=_('Username'), max_length=30, required=True)
|
|
password = forms.CharField(label=_('Password'), widget=forms.PasswordInput(), required=True)
|
|
password_again = forms.CharField(label=_('Password Again'), widget=forms.PasswordInput(), required=True)
|
|
email = forms.CharField(label=_('Email'), max_length=254, required=True)
|
|
email_again = forms.CharField(label=_('Email Again'), max_length=254, required=True)
|
|
|
|
if getattr(settings, 'CAPTCHA_ENABLED', False):
|
|
from captcha.fields import ReCaptchaField
|
|
captcha = ReCaptchaField()
|
|
|
|
def clean(self):
|
|
if ' ' in self.cleaned_data['username']:
|
|
raise forms.ValidationError('Username cannot contain a space')
|
|
|
|
# We attempt to get the user object if we succeed we know email as been used
|
|
try:
|
|
User.objects.get(email=self.cleaned_data['email'])
|
|
raise forms.ValidationError('Email as already been used')
|
|
except User.DoesNotExist:
|
|
pass
|
|
|
|
if not re.match("^\w+$", self.cleaned_data['username']):
|
|
raise forms.ValidationError('Username contains illegal characters')
|
|
|
|
if 'password' in self.cleaned_data and 'password_again' in self.cleaned_data:
|
|
if self.cleaned_data['password'] != self.cleaned_data['password_again']:
|
|
raise forms.ValidationError('Passwords do not match')
|
|
|
|
if 'email' in self.cleaned_data and 'email_again' in self.cleaned_data:
|
|
if self.cleaned_data['email'] != self.cleaned_data['email_again']:
|
|
raise forms.ValidationError('Emails do not match')
|
|
|
|
return self.cleaned_data
|