是否有根据请求表单的用户角色来自定义表单的正确方法?

我的情况很简单:如果用户未授予ROLE_ADMIN,则需要隐藏一些字段。我试图避免在Twig上显示字段,但是

  {% if is_granted('ROLE_ADMIN') %}
              {{form_row(form.field)}}
  {% endif %}

不起作用,因为表单构建器会绕过此检查。

Symfony版本: 2.8.2

编辑

感谢@Rooneyl suggestion,我找到了解决方案:

首先,您需要将'role'键添加到options参数。因此,在configureOptions()中,$options['role']始终为ROLE_USER。
/**
 * @param OptionsResolver $resolver
 */
public function configureOptions(OptionsResolver $resolver)
{
    $resolver->setDefaults(array(
        'data_class' => 'MyBundle\Entity\Ticket',
        'role' => 'ROLE_USER'
    ));
}

然后,在 Controller 中,您必须传递getRoles()数组:
$user_roles = $this->getUser()->getRoles();
$form = $this->createForm('MyBundle\Form\TicketType', $ticket, array('role' => $user_roles));

最佳答案

您可以使用传递给表单构建器的选项来说明生成了哪些元素。
这样,您可以更改内容和完成的验证(使用validation_groups)。
例如,您的 Controller (假设角色是一个数组);
您控制;

$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';
    }

}

10-08 09:08
查看更多