<?php
namespace App\Listener;
use App\Entity\Users;
use Symfony\Component\Security\Core\SecurityContext;
use Doctrine\ORM\EntityManager;
//use Symfony\Component\HttpKernel\Event\GetResponseEvent;
use Symfony\Component\HttpKernel\Event\RequestEvent;
use Symfony\Component\Security\Core\Encoder\EncoderFactoryInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use DateTime;
/**
* Listener que actualiza la last activity de cada usuario autenticado
*/
class ChangePasswordListener
{
protected $container;
protected $context;
protected $em;
protected $encoderFactory;
public function __construct(ContainerInterface $container, EntityManager $em, EncoderFactoryInterface $encoderFactory)
{
$this->container = $container;
$this->em = $em;
$this->encoderFactory = $encoderFactory;
}
/**
* En cada request vamos a chequear si el password el usuario es igual al predeterminado
*
* @param \Symfony\Component\HttpKernel\Event\GetResponseEvent; $event
* @return void
*/
public function onKernelRequest(RequestEvent $event)
{
if ($this->container->get('security.token_storage')->getToken()) {
$user = $this->container->get('security.token_storage')->getToken()->getUser();
if($user instanceof Users)
{
$encoder = $this->encoderFactory->getEncoder($user);
//$encoder = $this->container -> get('security.encoder_factory') -> getEncoder($user);
$passwordCodificado = $encoder -> encodePassword('veritas01', $user-> getSalt());
if($user->getPassword()==$passwordCodificado)
{
$this->container->get('session')->getFlashBag()->set('danger', 'Antes de continuar debe actualizar su contraseƱa');
$this->container->get('session')->set('reset', '1');;
}else{
$this->container->get('session')->set('reset', '0');;
}
}
}
}
}