如何根据 Symfony2/3 中的用户角色自定义表单字段?
How to customize form field based on user roles in Symfony2/3?
是否有根据请求表单的用户角色自定义表单的正确方法?
我的场景非常简单:如果用户没有 ROLE_ADMIN
授权,我需要隐藏一些字段。我试图避免在 Twig 上显示字段,但是
{% if is_granted('ROLE_ADMIN') %}
{{form_row(form.field)}}
{% endif %}
无效,因为表单生成器绕过此检查。
Symfony 版本:2.8.2
编辑
感谢@Rooneyl 我找到了解决方案:
首先,您需要在选项参数中添加'role'键。所以,在 configureOptions() $options['role']
总是 ROLE_USER.
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'MyBundle\Entity\Ticket',
'role' => 'ROLE_USER'
));
}
然后在控制器中你必须传递getRoles()
数组:
$user_roles = $this->getUser()->getRoles();
$form = $this->createForm('MyBundle\Form\TicketType', $ticket, array('role' => $user_roles));
你可以在你的表单中完成。
为您的表单创建服务
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 %}
请注意,这意味着您的字段可能为空。因为您可能希望看到其中一些对某些用户可见而对其他用户不可见。
否则,您可以在您的实体构造方法中设置一个默认值,以确保如果用户不t/can不填写它,该值不会为空。
您可以使用传递给表单生成器的选项来说明生成的元素。
这样您就可以更改完成的内容和验证(使用 validation_groups)。
比如你的controller(假设roles是一个数组);
你控制器;
$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';
}
}
是否有根据请求表单的用户角色自定义表单的正确方法?
我的场景非常简单:如果用户没有 ROLE_ADMIN
授权,我需要隐藏一些字段。我试图避免在 Twig 上显示字段,但是
{% if is_granted('ROLE_ADMIN') %}
{{form_row(form.field)}}
{% endif %}
无效,因为表单生成器绕过此检查。
Symfony 版本:2.8.2
编辑
感谢@Rooneyl
首先,您需要在选项参数中添加'role'键。所以,在 configureOptions() $options['role']
总是 ROLE_USER.
/**
* @param OptionsResolver $resolver
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'MyBundle\Entity\Ticket',
'role' => 'ROLE_USER'
));
}
然后在控制器中你必须传递getRoles()
数组:
$user_roles = $this->getUser()->getRoles();
$form = $this->createForm('MyBundle\Form\TicketType', $ticket, array('role' => $user_roles));
你可以在你的表单中完成。
为您的表单创建服务
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 %}
请注意,这意味着您的字段可能为空。因为您可能希望看到其中一些对某些用户可见而对其他用户不可见。
否则,您可以在您的实体构造方法中设置一个默认值,以确保如果用户不t/can不填写它,该值不会为空。
您可以使用传递给表单生成器的选项来说明生成的元素。
这样您就可以更改完成的内容和验证(使用 validation_groups)。
比如你的controller(假设roles是一个数组);
你控制器;
$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';
}
}