Silex用户具有数据库中的多个角色

时间:2016-02-15 10:27:50

标签: php symfony roles silex user-roles

我的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

我的用户存储在数据库表中,然后我有其他用户/角色关系表。

如何加载这些角色并应用于我的用户?

由于

1 个答案:

答案 0 :(得分:0)

看看writing custom user provider in Symfony2。同样applies to Silex

您基本上必须编写一个自定义User类和UserProvider,用于按用户名加载用户,然后可以获取您可能需要的任何其他数据。
在您的情况下,您还将从数据库加载用户权限,将它们添加到User对象中的某个属性,以后可以使用UserInterface::getRoles()由Symfony2检索。