X-Git-Url: https://git.mdrn.pl/django-cas-provider.git/blobdiff_plain/4f3dc0c8018d8ca6ff31429043d64ccbdae8b956..413bf45b20e253acdf45c0e43d4f05b1ecf33c0d:/cas_provider/forms.py?ds=sidebyside diff --git a/cas_provider/forms.py b/cas_provider/forms.py index ba6aff0..e4df105 100644 --- a/cas_provider/forms.py +++ b/cas_provider/forms.py @@ -1,37 +1,24 @@ +from __future__ import unicode_literals + from django import forms -from django.conf import settings -from django.contrib.auth import authenticate -from django.contrib.auth.forms import AuthenticationForm -from django.forms import ValidationError from django.utils.translation import ugettext_lazy as _ -from models import LoginTicket -import datetime - - -__all__ = ['LoginForm', ] -class LoginForm(AuthenticationForm): - lt = forms.CharField(widget=forms.HiddenInput) +class LoginForm(forms.Form): + username = forms.CharField(widget=forms.TextInput(attrs={'autofocus': 'autofocus', + 'max_length': '255'}), + label=_('Username')) + password = forms.CharField(widget=forms.PasswordInput(), label=_('Password')) service = forms.CharField(widget=forms.HiddenInput, required=False) - def clean_lt(self): - ticket = self.cleaned_data['lt'] - timeframe = datetime.datetime.now() - \ - datetime.timedelta(minutes=settings.CAS_TICKET_EXPIRATION) - try: - return LoginTicket.objects.get(ticket=ticket, created__gte=timeframe) - except LoginTicket.DoesNotExist: - raise ValidationError(_('Login ticket expired. Please try again.')) - return ticket + def __init__(self, *args, **kwargs): + # renew = kwargs.pop('renew', None) + # gateway = kwargs.pop('gateway', None) + request = kwargs.pop('request', None) + super(LoginForm, self).__init__(*args, **kwargs) + self.request = request - def clean(self): - AuthenticationForm.clean(self) - self.cleaned_data.get('lt').delete() - return self.cleaned_data - def get_errors(self): - errors = [] - for k, error in self.errors.items(): - errors += [e for e in error] - return errors +class MergeLoginForm(LoginForm): + username = forms.CharField(max_length=255, widget=forms.HiddenInput, + label=_('Username'))