def real_dispatch(self, request, target): form = CategoryRoleForm(instance=target) perms_forms = get_permissions_forms(target) if request.method == 'POST': perms_forms = get_permissions_forms(target, request.POST) valid_forms = 0 for permissions_form in perms_forms: if permissions_form.is_valid(): valid_forms += 1 form = CategoryRoleForm(request.POST, instance=target) if form.is_valid() and len(perms_forms) == valid_forms: new_permissions = {} for permissions_form in perms_forms: cleaned_data = permissions_form.cleaned_data new_permissions[permissions_form.prefix] = cleaned_data form.instance.permissions = new_permissions form.instance.save() messages.success(request, self.message_submit % {'name': target.name}) if 'stay' in request.POST: return redirect(request.path) else: return redirect(self.root_link) elif form.is_valid() and len(perms_forms) != valid_forms: form.add_error(None, _("Form contains errors.")) return self.render( request, { 'form': form, 'target': target, 'perms_forms': perms_forms, }, )
def fake_post_data(target, data_dict): """ In order for form to don't fail submission, all permission fields need to receive values. This function populates data dict with default values for permissions, making form validation pass """ for form in get_permissions_forms(target): for field in form: if field.value() is True: data_dict[field.html_name] = 1 elif field.value() is False: data_dict[field.html_name] = 0 else: data_dict[field.html_name] = field.value() return data_dict