src/EventSubscriber/UserEventSubscriber.php line 34

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\EventSubscriber;
  4. use App\Entity\User;
  5. use Doctrine\ORM\EntityManagerInterface;
  6. use EasyCorp\Bundle\EasyAdminBundle\Event\BeforeEntityPersistedEvent;
  7. use EasyCorp\Bundle\EasyAdminBundle\Event\BeforeEntityUpdatedEvent;
  8. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  9. //use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
  10. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  11. class UserEventSubscriber implements EventSubscriberInterface
  12. {
  13.     private EntityManagerInterface $entityManager;
  14. //    private UserPasswordEncoderInterface $passwordEncoder;
  15.     private UserPasswordHasherInterface $UserPasswordHasherInterface;
  16.     public function __construct(EntityManagerInterface $entityManagerUserPasswordHasherInterface $userPasswordHasherInterface)
  17.     {
  18.         $this->entityManager $entityManager;
  19.         $this->userPasswordHasherInterface $userPasswordHasherInterface;
  20.     }
  21.     public static function getSubscribedEvents(): array
  22.     {
  23.         return [
  24.             BeforeEntityPersistedEvent::class => ['persistUser'],
  25.             BeforeEntityUpdatedEvent::class => ['updateUser'],
  26.         ];
  27.     }
  28.     public function persistUser(BeforeEntityPersistedEvent $event): void
  29.     {
  30.         $user $event->getEntityInstance();
  31.         if (!$user instanceof User) {
  32.             return;
  33.         }
  34.         $plainPassword $user->getPlainPassword();
  35.         if ('' !== $plainPassword) {
  36.             $this->encodePassword($user);
  37.         }    }
  38.     public function updateUser(BeforeEntityUpdatedEvent $event): void
  39.     {
  40.         $user $event->getEntityInstance();
  41.         if (!$user instanceof User) {
  42.             return;
  43.         }
  44.         $plainPassword $user->getPlainPassword();
  45.         if ('' !== $plainPassword) {
  46.             $this->encodePassword($user);
  47.         }
  48.     }
  49.     private function encodePassword(User $user)
  50.     {
  51.         $plainPassword $user->getPlainPassword();
  52.         $user->setPassword(
  53.             $this->userPasswordHasherInterface->hashPassword(
  54.                 $user,
  55.                 $plainPassword
  56.             )
  57.         );
  58.         $this->entityManager->persist($user);
  59.         $this->entityManager->flush();
  60.     }
  61. }