Аутентификация контроля доступа РОЛИ
Используя symfony2.1 и FOSFacebookBundle:
Если пользователь вводит www.example.com, например, пользователь закрыл свой браузер, тогда я хочу выполнить перенаправление на www.example.com/secured, если он все еще аутентифицирован.
Я не могу попасть в indexAction, если пользователь аутентифицирован.
Мой Security.yml:
security:
encoders:
Symfony\Component\Security\Core\User\User: plaintext
role_hierarchy:
ROLE_ADMIN: ROLE_USER
ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]
providers:
in_memory:
memory:
users:
user: { password: userpass, roles: [ 'ROLE_USER' ] }
admin: { password: adminpass, roles: [ 'ROLE_ADMIN' ] }
my_fos_facebook_provider:
id: my.facebook.user
//How can I add here a ROLE_USER?
firewalls:
//standard thing from FosFacebookBundle
access_control:
- { path: ^/, roles: [IS_AUTHENTICATED_ANONYMOUSLY] }
Мой indexAction:
if( $this->container->get('security.context')
->isGranted('IS_AUTHENTICATED_FULLY') ){
echo 'asdf'; //this is working in the secured area www.example.com/secured/
}
Мое сообщение об ошибке: контекст безопасности не содержит токен аутентификации. Одной из возможных причин может быть то, что для этого URL не настроен брандмауэр.
В охраняемой зоне у пользователя нет ролей. Как я могу это изменить?
Что случилось?
ОБНОВИТЬ
namespace Frontend\FbAccountBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* User
*
* @ORM\Table(name="user")
* @ORM\Entity
*/
class User
{
/**
* @var integer
*
* @ORM\Column(name="id", type="bigint", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var integer
*
* @ORM\Column(name="facebook_id", type="bigint", nullable=false)
*/
private $facebookId;
/**
* @param Array
*/
public function setFBData($fbdata)
{
if (isset($fbdata['id'])) {
$this->setFacebookId($fbdata['id']);
$this->addRole('ROLE_FACEBOOK');
}
}
security.yml:
services:
my.facebook.user:
class: Frontend\FbAccountBundle\Security\User\Provider\FacebookProvider
arguments:
facebook: "@fos_facebook.api"
userManager: "@fos_user.user_manager"
validator: "@validator"
container: "@service_container"
1 ответ
Вам нужно написать провайдера пользователя, чтобы добавить роль к вашему пользователю. Это описано в документации FOSFacebookBundle. Взгляните на определение сервиса и метод setFBData в сущности User в нижней части страницы. Это должно дать вам твердое начало.