我的SecurityServiceProvider的silex项目如下:
$this->app->register(new SecurityServiceProvider(), array(
'security.firewalls' => array(
'login' => array(
'pattern' => '^/login$',
),
'secured' => [
'pattern' => '^/admin.*$',
'anonymous' => true,
'form' => array(
'login_path' => '/login',
'check_path' => '/admin/auth'
),
'logout' => array(
'logout_path' => '/admin/logout'
),
'users' => $this->app->share(function() use ($self) {
return new AuthenticationSuccessHandler($self->app['db']);
}),
]
),
'security.role_hierarchy' => [
'ROLE_USER' => [],
'ROLE_BACKEND_USER' => ['ROLE_USER'],
'ROLE_SUPER_ADMIN' => ['ROLE_USER','ROLE_BACKEND_USER']
],
'security.access_rules' => array(
['^/.*$', 'ROLE_USER'],
['^/admin.*$', 'ROLE_SUPER_ADMIN'],
['^/admin.*$', 'ROLE_BACKEND_USER']
)
));
现在我有一个包含角色列表的数据库表:
22 ROLE_ACCESS_NODES_DELETE
23 ROLE_ACCESS_NODES_STATUS
24 ROLE_ACCESS_NEWSLETTERS_SEND
25 ROLE_USER
26 ROLE_BACKEND_USER
我的用户存储在数据库表中,然后我有其他用户/角色关系表。
如何加载这些角色并应用于我的用户?
由于
答案 0 :(得分:0)
看看writing custom user provider in Symfony2。同样applies to Silex。
您基本上必须编写一个自定义User
类和UserProvider
,用于按用户名加载用户,然后可以获取您可能需要的任何其他数据。
在您的情况下,您还将从数据库加载用户权限,将它们添加到User
对象中的某个属性,以后可以使用UserInterface::getRoles()由Symfony2检索。