gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 19:59:30 25 4
gpt4 key购买 nike

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

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

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

不起作用,因为表单生成器绕过了此检查。

Symfony 版本:2.8.2

编辑

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

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

最佳答案

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

为您的表单提供服务

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 %}

请注意,这意味着您的字段可能为空。因为也许您希望看到其中一些对某些用户可见,而另一些则不可见。

否则,您可以在实体构造方法中设置默认值,以确保如果用户不/无法填写值,则值不会为空。

关于symfony - Symfony2/3中如何根据用户角色自定义表单字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35433295/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com