| @@ 13-43 (lines=31) @@ | ||
| 10 | use Sylius\SyliusShopApiPlugin\Command\GenerateResetPasswordToken; | |
| 11 | use Webmozart\Assert\Assert; | |
| 12 | ||
| 13 | final class GenerateResetPasswordTokenHandler | |
| 14 | { | |
| 15 | /** | |
| 16 | * @var UserRepositoryInterface | |
| 17 | */ | |
| 18 | private $userRepository; | |
| 19 | ||
| 20 | /** | |
| 21 | * @var GeneratorInterface | |
| 22 | */ | |
| 23 | private $tokenGenerator; | |
| 24 | ||
| 25 | public function __construct(UserRepositoryInterface $userRepository, GeneratorInterface $tokenGenerator) | |
| 26 |     { | |
| 27 | $this->userRepository = $userRepository; | |
| 28 | $this->tokenGenerator = $tokenGenerator; | |
| 29 | } | |
| 30 | ||
| 31 | public function handle(GenerateResetPasswordToken $generateResetPasswordToken) | |
| 32 |     { | |
| 33 | $email = $generateResetPasswordToken->email(); | |
| 34 | ||
| 35 | /** @var ShopUserInterface $user */ | |
| 36 | $user = $this->userRepository->findOneByEmail($email); | |
| 37 | ||
| 38 |         Assert::notNull($user, sprintf('User with %s email has not been found.', $email)); | |
| 39 | ||
| 40 | $user->setPasswordResetToken($this->tokenGenerator->generate()); | |
| 41 | $user->setPasswordRequestedAt(new \DateTime()); | |
| 42 | } | |
| 43 | } | |
| 44 | ||
| @@ 13-42 (lines=30) @@ | ||
| 10 | use Sylius\SyliusShopApiPlugin\Command\GenerateVerificationToken; | |
| 11 | use Webmozart\Assert\Assert; | |
| 12 | ||
| 13 | final class GenerateVerificationTokenHandler | |
| 14 | { | |
| 15 | /** | |
| 16 | * @var UserRepositoryInterface | |
| 17 | */ | |
| 18 | private $userRepository; | |
| 19 | ||
| 20 | /** | |
| 21 | * @var GeneratorInterface | |
| 22 | */ | |
| 23 | private $tokenGenerator; | |
| 24 | ||
| 25 | public function __construct(UserRepositoryInterface $userRepository, GeneratorInterface $tokenGenerator) | |
| 26 |     { | |
| 27 | $this->userRepository = $userRepository; | |
| 28 | $this->tokenGenerator = $tokenGenerator; | |
| 29 | } | |
| 30 | ||
| 31 | public function handle(GenerateVerificationToken $generateVerificationToken) | |
| 32 |     { | |
| 33 | $email = $generateVerificationToken->email(); | |
| 34 | ||
| 35 | /** @var ShopUserInterface $user */ | |
| 36 | $user = $this->userRepository->findOneByEmail($email); | |
| 37 | ||
| 38 |         Assert::notNull($user, sprintf('User with %s email has not been found.', $email)); | |
| 39 | ||
| 40 | $user->setEmailVerificationToken($this->tokenGenerator->generate()); | |
| 41 | } | |
| 42 | } | |
| 43 | ||