我需要创建一个名为 STATUS 的新ROLE,以显示在用户CRUD的ROLE MANAGER中,就像链接中的图像一样 see image,此角色基于管理类中定义的自定义路由和自定义控制器。
我已经解决了修改配置文件,添加information
参数和默认的ROLE列表,但是这将适用于服务中定义的所有管理类,我不希望这样,我想要定义特定管理类的ROLE,也可以出现在角色管理器中,以便为用户分配。
欢迎任何建议
感谢您的帮助!
这些是我的配置:
config.yml
#SONATAADMINBUNDLE
sonata_admin:
security:
handler: sonata.admin.security.handler.role
information:
EDIT: EDIT
LIST: LIST
CREATE: CREATE
VIEW: VIEW
DELETE: DELETE
EXPORT: EXPORT
OPERATOR: OPERATOR
MASTER: MASTER
STATUS: STATUS
AdminClass
//..
use Sonata\AdminBundle\Route\RouteCollection;
class SolicitudMantenimientoAdmin extends Admin
{
//...
protected function configureRoutes(RouteCollection $collection)
{
$collection->add('status',$this->getRouterIdParameter().'/status');
}
}
服务
<service id="sonata.admin.solicitudmantenimiento" class="Minsal\SimBundle\Admin\SolicitudMantenimientoAdmin">
<tag name="sonata.admin" manager_type="orm" group="Solicitud" label="Solicitud Mantenimiento" />
<argument />
<argument>Minsal\SimBundle\Entity\SolicitudMantenimiento</argument>
<argument>MinsalSimBundle:SolicitudMantenimiento</argument>
</service>
控制器
use Sonata\AdminBundle\Controller\CRUDController;
class SolicitudMantenimientoController extends CRUDController {
//..
public function statusAction() {
//... code here
return new Response('<html><body>Test</body></html>');
}
答案 0 :(得分:1)
最后我解决了问题,我更深入地阅读了文档(Role Handler),我在以下文件中做了下一个更改:
security.yml
我在安全文件中的 role_hierarchy 部分添加了新角色,如下所示:
security:
role_hierarchy:
ROLE_SONATA_SOLICITUDMANTENIMIENTO:
- ROLE_SONATA_ADMIN_SOLICITUDMANTENIMIENTO_STATUS
当我添加新角色时,它出现在用户CRUD的ROLE MANAGER中,就像链接see image上的图像一样
它有效!!! ...