Dans Symfony 2.8/3.0, avec nos nouveaux composants de sécurité sophistiqués, comment obtenir l'objet User
() actuellement consigné, à savoir FOSUser ) dans un service sans injecter le conteneur entier?
Est-ce même possible d'une manière non-hacky ?
PS: Ne considérons pas que " le transmette à la fonction de service en tant que paramètre " pour être trivialement évident. Aussi, sale.
Injecter security.token_storage
service dans votre service, puis utilisez:
$this->token_storage->getToken()->getUser();
comme décrit ici: http://symfony.com/doc/current/book/security.html#retrieving-the-user-object et ici: http://symfony.com /doc/current/book/service_container.html#referencing-injecting-services
En utilisant l'injection de dépendance du constructeur, vous pouvez le faire comme suit:
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
class A
{
private $user;
public function __construct(TokenStorageInterface $tokenStorage)
{
$this->user = $tokenStorage->getToken()->getUser();
}
public function foo()
{
dump($this->user);
}
}
Nouveauté de la version 3.4: La classe d’utilitaire de sécurité a été introduite dans Symfony 3.4.
use Symfony\Component\Security\Core\Security;
public function indexAction(Security $security)
{
$user = $security->getUser();
}
https://symfony.com/doc/3.4/security.html#always-check-if-the-user-is-logged-in
Dans symfo 4:
use Symfony\Component\Security\Core\Security;
class ExampleService
{
private $security;
public function __construct(Security $security)
{
$this->security = $security;
}
public function someMethod()
{
$user = $this->security->getUser();
}
}
Voir doc: https://symfony.com/doc/current/security.html#retrieving-the-user-object
De Symfony 3.3
, depuis un contrôleur uniquement , selon ce billet de blog: https://symfony.com/blog/new-in-symfony -3-2-valeur-utilisateur-résolveur-pour-automates
C'est simple comme:
use Symfony\Component\Security\Core\User\UserInterface
public function indexAction(UserInterface $user)
{...}
Symfony fait cela dans Symfony\Bundle\FrameworkBundle\ControllerControllerTrait
protected function getUser()
{
if (!$this->container->has('security.token_storage')) {
throw new \LogicException('The SecurityBundle is not registered in your application.');
}
if (null === $token = $this->container->get('security.token_storage')->getToken()) {
return;
}
if (!is_object($user = $token->getUser())) {
// e.g. anonymous authentication
return;
}
return $user;
}
Donc, si vous injectez simplement et remplacez security.token_storage
, tu es prêt à partir.
si vous classe étendre du contrôleur
$this->get('security.context')->getToken()->getUser();
Ou, si vous avez accès à l'élément de conteneur ..
$container = $this->configurationPool->getContainer();
$user = $container->get('security.context')->getToken()->getUser();
http://symfony.com/blog/new-in-symfony-2-6-security-component-improvements