src/EventSubscriber/EasyAdminSubscriber.php line 32

  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\PasswordHasher\Hasher\UserPasswordHasherInterface;
  9. class EasyAdminSubscriber implements EventSubscriberInterface
  10. {
  11.     private EntityManagerInterface $entityManager;
  12.     private UserPasswordHasherInterface $passwordEncoder;
  13.     public function __construct(EntityManagerInterface $entityManagerUserPasswordHasherInterface $passwordEncoder)
  14.     {
  15.         $this->entityManager $entityManager;
  16.         $this->passwordEncoder $passwordEncoder;
  17.     }
  18.     public static function getSubscribedEvents(): array
  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.     public function updateUser(BeforeEntityUpdatedEvent $event)
  26.     {
  27.         $entity $event->getEntityInstance();
  28.         if (!($entity instanceof User)) {
  29.             return;
  30.         }
  31.         $this->setPassword($entity);
  32.     }
  33.     public function addUser(BeforeEntityPersistedEvent $event)
  34.     {
  35.         $entity $event->getEntityInstance();
  36.         if (!($entity instanceof User)) {
  37.             return;
  38.         }
  39.         $this->setPassword($entity);
  40.     }
  41.     /**
  42.      * @param User $entity
  43.      */
  44.     public function setPassword(User $entity): void
  45.     {
  46.         $plainPassword $entity->getPlainPassword();
  47.         if(!empty($plainPassword)) {
  48.             $entity->setPassword($this->passwordEncoder->hashPassword($entity$plainPassword));
  49.             $this->entityManager->persist($entity);
  50.             $this->entityManager->flush();
  51.         }
  52.     }
  53. }