| @@ 13-43 (lines=31) @@ | ||
| 10 | use Sylius\ShopApiPlugin\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\ShopApiPlugin\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 | ||