Mercurial > public > sg101
view gpp/polls/forms.py @ 507:8631d32e6b16
Some users are still having problems with the pop-up login. I think they are actually getting 403s because of the CSRF protection. So I have modified the base template to always have a javascript variable called csrf_token available when they aren't logged in. The ajax_login.js script was then modified to send this value with the ajax post. Fingers crossed.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sun, 04 Dec 2011 03:05:21 +0000 |
parents | 1f139de929c4 |
children |
line wrap: on
line source
"""Forms for the Polls application.""" from django import forms from django.db.models import F from polls.models import Choice class VoteForm(forms.Form): """Form for voting in a poll.""" choices = forms.ModelChoiceField(label='', empty_label=None, queryset=Choice.objects.none(), widget=forms.RadioSelect) def __init__(self, poll, *args, **kwargs): self.user = kwargs.pop('user', None) self.user_choice = kwargs.pop('user_choice', None) super(VoteForm, self).__init__(*args, **kwargs) self.fields['choices'].queryset = poll.choice_set.all() def clean(self): if self.user_choice: raise forms.ValidationError("You've already voted in this poll!") return self.cleaned_data def save(self): choice = self.cleaned_data['choices'] Choice.objects.filter(id=choice.id).update(votes=F('votes') + 1) choice.voters.add(self.user)