Как настроить поле формы на основе ролей пользователей в Symfony2 / 3?
есть ли правильный способ настроить форму в зависимости от роли пользователя, который ее запрашивает?
мой сценарий довольно прост: мне нужно скрыть некоторые поля, если у пользователя нет ROLE_ADMIN
удовлетворено. Я пытался избежать отображения поля на веточке, но
{% if is_granted('ROLE_ADMIN') %}
{{form_row(form.field)}}
{% endif %}
не работает, потому что конструктор форм обходит эту проверку.
версию Symfony: 2.8.2
редактировать
спасибо @Rooneyl предложение я нашел решение:
сначала вам нужно добавить ключ "роль" в параметр options. Итак, в configureOptions() $options['role']
всегда ROLE_USER.
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'MyBundleEntityTicket',
'role' => 'ROLE_USER'
));
}
затем в контроллере вы должны передать getRoles()
время:
$user_roles = $this->getUser()->getRoles();
$form = $this->createForm('MyBundleFormTicketType', $ticket, array('role' => $user_roles));
2 ответов
вы можете использовать опцию, переданную построителю форм, чтобы сказать, какие элементы генерируются.
Таким образом, вы можете изменить содержимое и проверку, которая выполняется (используя validation_groups).
Например, ваш контроллер (предполагая, что роли-это массив);
вы контролер;
$form = $this->createForm(new MyType(), $user, ['role' => $this->getUser()->getRoles()]);
форма:
<?php
namespace AppBundle\Form\Entity;
use AppBundle\Entity\UserRepository;
use Symfony\Component\Form\AbstractType,
Symfony\Component\Form\FormBuilderInterface,
Symfony\Component\OptionsResolver\OptionsResolver;
class MyType extends AbstractType
{
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'AppBundle\Entity\User',
'validation_groups' => ['create'],
'role' => ['ROLE_USER']
));
}
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
// dump($options['roles']);
if (in_array('ROLE_ADMIN', $options['role'])) {
// do as you want if admin
$builder
->add('name', 'text');
} else {
$builder
->add('supername', 'text');
}
}
/**
* @return string
*/
public function getName()
{
return 'appbundle_my_form';
}
}
вы можете сделать это в форме.
сделайте услугу для вашей формы
app.form.type.task:
class: AppBundle\Form\FormType
arguments: ["@security.authorization_checker"]
tags:
- { name: form.type }
в вашем FormType добавьте конструктор, чтобы получить свой сервис.
private $authorization;
public function __construct(AuthorizationChecker $authorizationChecker)
{
$this->authorization = $authorizationChecker;
}
затем в вашем конструкторе вы сможете проверить разрешение пользователя
$builder->add('foo');
if($this->authorization->isGranted('ROLE_ADMIN'))
{
$builder->add('bar');
}
и затем, наконец, вы можете отобразить свою форму
{% if form.formbar is defined %}
{{ form_row(form.formbar ) }}
{% endif %}
обратите внимание, что это означает, что поле может быть null. Потому что, возможно, вы хотите увидеть некоторые из них видимыми некоторыми пользователями и другими не.
Else, вы можете установить значение по умолчанию в методе построения сущности, чтобы убедиться, что значение не будет null, если пользователь не / не может его заполнить.