Подтвердите данные формы A, используя данные формы B - PullRequest
0 голосов
/ 11 апреля 2011

Итак, у меня есть эти две формы. Я хотел бы иметь возможность доступа к данным в форме env_form, когда я проверяю add_uRG для моей другой формы. Можно ли сделать это? Моя форма env является очень распространенной формой в моем приложении, поэтому я хотел бы хранить ее отдельно, а не включать в каждую форму.

class env_form(forms.Form):
            env = forms.ChoiceField(choices=ENV, required=True)

    class add_uRG(forms.Form):
            user = forms.CharField(max_length=50)
            group = forms.CharField(required=True)
            role = forms.CharField(required=True)

            def clean_user(self):
                    post_user = self.cleaned_data['user']
                    post_env = self.cleaned_data['env']
                    c = User.objects.filter(user__contains=post_user, env__contains=post_env ).count()
                    if (c == 0):
                         raise forms.ValidationError(u"User Not Found.")
                    else:
                         user_info = User.objects.filter(user__contains=post_user).values('password').distinct().count()
                         user_env = User.objects.filter(user__contains=post_user).values('env').distinct().count()
                         if not (user_env == user_info):
                            raise forms.ValidationError(u'User is using same password')
                    return(post_user)

Ответы [ 2 ]

0 голосов
/ 12 апреля 2011

Если я правильно читаю ваш вопрос, я думаю, что здесь можно использовать наследование форм.

class env_form(forms.Form):
    env = forms.ChoiceField(choices=ENV, required=True)

class add_uRG(env_form):
    user = forms.CharField(max_length=50)
    group = forms.CharField(required=True)
    role = forms.CharField(required=True)

    def clean_user(self):
        post_user = self.cleaned_data['user']
        post_env = self.cleaned_data['env']
        c = User.objects.filter(user__contains=post_user, env__contains=post_env ).count()
        if (c == 0):
            raise forms.ValidationError(u"User Not Found.")
        else:
            user_info = User.objects.filter(user__contains=post_user).values('password').distinct().count()
            user_env = User.objects.filter(user__contains=post_user).values('env').distinct().count()
            if not (user_env == user_info):
                raise forms.ValidationError(u'User is using same password')
        return(post_user)


    def __init__(self, *args, **kwargs):
        super(env_form, self).__init__(*args, **kwargs)

class SomeOtherForm(env_form):
    some_field = forms.CharField()

    def __init__(self,*args,**kwargs):
        super(env_form, self).__init__(*args,**kwargs)
0 голосов
/ 12 апреля 2011

Вы можете назначить свойство в форме add_uRG после проверки env_form или передать значение в форму add_uRG в качестве параметра.

#forms.py
class AdduRGForm(forms.Form):
    def __init__(self, *args, **kwargs):
        super(AdduRGForm, self).__init__(*args, **kwargs)
        self.env = None

#my_view.py
def my_view(request):
    env_form = env_form(request.POST or None)

    if request.POST:
        if env_form.is_valid():
            add_uRG_form = AdduRGForm(request.POST or None)
            add_uRG_form.env = env_form.cleaned_data.get('env')
            if add_uRG_form.is_valid():
                #do something else
    return render_to_response('template.html',
        {'env_form' : env_form, 'add_uRG_form' : add_uRG_form})

Я не совсем уверен в вашем рабочем процессе, поэтому, если эти формы не существуют в одном представлении, например, если вы сначала обрабатываете env_form, а затем переходите к другому представлению и нуждаетесь в значении, которое кто-то ранее выбрал, Вы можете передать запрос env_form и установить выборку в сеансе, которую вы можете снова выбрать во второй форме, используя описанный мною метод.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...