Mysql
 sql >> Base de données >  >> RDS >> Mysql

Symfony3 comment stocker les rôles d'utilisateur dans la base de données

Voici ce que j'ai fait pour résoudre le problème,

Définissez les rôles dans /app/config/security.yml comme ci-dessous,

role_hierarchy:
    ROLE_ADMIN:         [ROLE_ADMIN]
    ROLE_SUPER_ADMIN:   [ROLE_SUPER_ADMIN, ROLE_ALLOWED_TO_SWITCH]
    ROLE_TEACHER:       [ROLE_TEACHER]
    ROLE_STUDENT:       [ROLE_STUDENT]
    ROLE_PARENT:        [ROLE_PARENT]

dans le contrôleur, obtenez les rôles de /app/config/security.yml en utilisant le code suivant

$roles = $this->getParameter('security.role_hierarchy.roles');

et c'est le code des rôles dans le formtype,

$roles = $this->getParent('security.role_hierarchy.roles');

puis dans le formtype, (ici c'est multi select)

->add('roles', ChoiceType::class, array(
    'attr'  =>  array('class' => 'form-control',
    'style' => 'margin:5px 0;'),
    'choices' => 
    array
    (
        'ROLE_ADMIN' => array
        (
            'Yes' => 'ROLE_ADMIN',
        ),
        'ROLE_TEACHER' => array
        (
            'Yes' => 'ROLE_TEACHER'
        ),
        'ROLE_STUDENT' => array
        (
            'Yes' => 'ROLE_STUDENT'
        ),
        'ROLE_PARENT' => array
        (
            'Yes' => 'ROLE_PARENT'
        ),
    ) 
    ,
    'multiple' => true,
    'required' => true,
    )
)

Modifier Les rôles d'utilisateur doivent être définis dans /app/config/security.yml comme ci-dessous

role_hierarchy:
    ROLE_ADMIN:         [ROLE_ADMIN]
    ROLE_SUPER_ADMIN:   [ROLE_SUPER_ADMIN, ROLE_ALLOWED_TO_SWITCH]
    ROLE_TEACHER:       [ROLE_TEACHER]
    ROLE_STUDENT:       [ROLE_STUDENT]
    ROLE_PARENT:        [ROLE_PARENT]