如何根据 Symfony2/3 中的用户角色自定义表单字段



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

我的方案非常简单:如果用户没有授予ROLE_ADMIN,我需要隐藏一些字段。我试图避免在 Twig 上显示字段,但是

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

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

符号版本:2.8.2

编辑

多亏了@Rooneyl建议,我找到了解决方案:

首先,您需要将"角色"键添加到选项参数中。因此,在 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));

您可以在表单中执行此操作。

为您的表单提供服务

app.form.type.task:
    class: AppBundleFormFormType
    arguments: ["@security.authorization_checker"]
    tags:
        - { name: form.type }

在窗体类型中,添加一个构造函数以获取服务。

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。

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

$form = $this->createForm(new MyType(), $user, ['role' => $this->getUser()->getRoles()]);

和您的表格:

<?php 
namespace AppBundleFormEntity;
use AppBundleEntityUserRepository;
use SymfonyComponentFormAbstractType,
    SymfonyComponentFormFormBuilderInterface,
    SymfonyComponentOptionsResolverOptionsResolver;
class MyType extends AbstractType 
{
    /**
     * @param OptionsResolver $resolver
     */
    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults(array(
            'data_class' => 'AppBundleEntityUser',
            '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';
    }
}

最新更新