Преобразование представления на основе функций в представление на основе классов только с формой и без модели (объекта) - PullRequest
4 голосов
/ 28 января 2012

Прямо сейчас, это, как пароль изменяется в профиле пользователя.Каков наилучший способ преобразования этого в представление на основе классов, зная, что модель не используется?

Это представление для изменения пароля

@login_required
def profile_change_password(request):
    """ 
    Change password of user.
    """
    user = get_object_or_404(User, username__iexact=request.user.username)

    if request.method == 'POST':
        form = PasswordChangeFormPrivate(user=user, data=request.POST)
        if form.is_valid():
            form.save()                       
            messages.add_message (request, messages.INFO, 
                                _('password changed'))
            return HttpResponseRedirect(reverse('profile_view_details'))
    else:
        form = PasswordChangeFormPrivate(user=request.user)

    return render_to_response('profiles/profile_change_password.html',
                              { 'form': form,},
                              context_instance=RequestContext(request)
                             )

Это форма для измененияпароль

class PasswordChangeFormPrivate(PasswordChangeForm):
    def __init__(self, *args, **kwargs):
        super(PasswordChangeForm, self).__init__(*args, **kwargs)

    def clean_new_password2(self):
        password1 = self.cleaned_data.get('new_password1')
        password2 = self.cleaned_data.get('new_password2')
        if password1 and password2:
            if password1 != password2:
                raise forms.ValidationError(_("The two password fields didn't match."))

        min_len = getattr(settings, "PASSWORD_MINIMUM_LENGHT", 6)
        if len(password1) < min_len:
            raise forms.ValidationError(_("Password too short! minimum length is ")+" [%d]" % min_len)

        return password2

Это URL

url(r'^password/change/$',
    profile_change_password,
    name='profile_change_password'
),

Как вы видите, модель не используется, так как пароль заменит поле пароля «User» при проверке.Любой простой способ преобразовать это в представление на основе классов?Имеет ли это значение?

1 Ответ

4 голосов
/ 28 января 2012

Не нужно участвовать в модели - вы можете использовать FormView. Это будет выглядеть примерно так:

from django.core.urlresolvers import reverse
from django.utils.decorators import method_decorator
from django.contrib.auth.decorators import login_required
from django.views.generic.edit import FormView

from myapp.forms import PasswordChangeFormPrivate

class ProfileChangePassword(FormView):
    form_class = PasswordChangeFormPrivate
    success_url = reverse('profile_view_details')
    template_name = 'profiles/profile_change_password.html'

    def get_form_kwargs(self):
        kwargs = super(ProfileChangePassword, self).get_form_kwargs()
        kwargs['user'] = self.request.user
        return kwargs

    def form_valid(self, form):
        form.save()
        messages.add_message(self.request, messages.INFO, _('profile changed'))
        return super(ProfileChangePassword, self).form_valid(form)

    @method_decorator(login_required)
    def dispatch(self, *args, **kwargs):
        return super(ProfileChangePassword, self).dispatch(*args, **kwargs)

Я не уверен, почему у вас

user = get_object_or_404(User, username__iexact=request.user.username)

Вам все равно требуется логин для формы, поэтому request.user гарантированно будет действительным пользователем.

...