src/EventSubscriber/EasyAdminSubscriber.php line 33

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Entity\User;
  4. use Doctrine\ORM\EntityManagerInterface;
  5. use EasyCorp\Bundle\EasyAdminBundle\Event\BeforeEntityPersistedEvent;
  6. use EasyCorp\Bundle\EasyAdminBundle\Event\BeforeEntityUpdatedEvent;
  7. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  8. use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
  9. class EasyAdminSubscriber implements EventSubscriberInterface
  10. {
  11.     private $entityManager;
  12.     private $passwordEncoder;
  13.     public function __construct(EntityManagerInterface $entityManagerUserPasswordEncoderInterface $passwordEncoder)
  14.     {
  15.         $this->entityManager $entityManager;
  16.         $this->passwordEncoder $passwordEncoder;
  17.     }
  18.     public static function getSubscribedEvents()
  19.     {
  20.         return [
  21.             BeforeEntityPersistedEvent::class => ['addUser'],
  22.             BeforeEntityUpdatedEvent::class => ['updateUser'], //surtout utile lors d'un reset de mot passe plutôt qu'un réel update, car l'update va de nouveau encrypter le mot de passe DEJA encrypté ...
  23.         ];
  24.     }
  25.     // Uncomment this function to crypt password on update
  26.     public function updateUser(BeforeEntityUpdatedEvent $event)
  27.     {
  28.         $entity $event->getEntityInstance();
  29.         // dd($entity);
  30.         if (!($entity instanceof User)) {
  31.             return;
  32.         }
  33.         if ($entity->getPlainPassword() == null) {
  34.             return;
  35.         }
  36.         $this->setPassword($entity);
  37.     }
  38.     public function addUser(BeforeEntityPersistedEvent $event)
  39.     {
  40.         $entity $event->getEntityInstance();
  41.         // dd($entity);
  42.         if (!($entity instanceof User)) {
  43.             return;
  44.         }
  45.         $this->setPassword($entity);
  46.     }
  47.     /**
  48.      * @param User $entity
  49.      */
  50.     public function setPassword(User $entity): void
  51.     {
  52.         $pass $entity->getPlainPassword();
  53.         //dd($entity);
  54.         $entity->setPassword(
  55.             $this->passwordEncoder->encodePassword(
  56.                 $entity,
  57.                 $pass
  58.             )
  59.         );
  60.         $this->entityManager->persist($entity);
  61.         $this->entityManager->flush();
  62.     }
  63. }