/** * Handles the given query. * * @param UserOfRememberPasswordTokenQuery $aQuery The query * * @throws UserDoesNotExistException when the user does not exist * @throws UserTokenExpiredException when the token is expired * * @return mixed */ public function __invoke(UserOfRememberPasswordTokenQuery $aQuery) { $user = $this->repository->userOfRememberPasswordToken(new UserToken($aQuery->rememberPasswordToken())); if (null === $user) { throw new UserDoesNotExistException(); } if ($user->isRememberPasswordTokenExpired()) { throw new UserTokenExpiredException(); } $this->dataTransformer->write($user); return $this->dataTransformer->read(); }
/** * Handles the given command. * * @param ByRequestRememberPasswordChangeUserPasswordCommand $aCommand The command * * @throws UserTokenNotFoundException when the user does not exist * @throws UserTokenExpiredException when the token is expired */ public function __invoke(ByRequestRememberPasswordChangeUserPasswordCommand $aCommand) { $user = $this->repository->userOfRememberPasswordToken(new UserToken($aCommand->rememberPasswordToken())); if (null === $user) { throw new UserTokenNotFoundException(); } if ($user->isRememberPasswordTokenExpired()) { throw new UserTokenExpiredException(); } $user->changePassword(UserPassword::fromPlain($aCommand->newPlainPassword(), $this->encoder)); $this->repository->persist($user); }
function it_does_not_change_password_because_the_token_is_expired(ByRequestRememberPasswordChangeUserPasswordCommand $command, UserRepository $repository, User $user) { $command->rememberPasswordToken()->shouldBeCalled()->willReturn('non-exist-remember-password-token'); $repository->userOfRememberPasswordToken(new UserToken('non-exist-remember-password-token'))->shouldBeCalled()->willReturn($user); $user->isRememberPasswordTokenExpired()->shouldBeCalled()->willReturn(true); $this->shouldThrow(UserTokenExpiredException::class)->during__invoke($command); }
function it_does_not_get_the_user_because_the_remember_password_token_is_expired(UserRepository $repository, UserOfRememberPasswordTokenQuery $query, User $user) { $query->rememberPasswordToken()->shouldBeCalled()->willReturn('remember-password-token'); $token = new UserToken('remember-password-token'); $repository->userOfRememberPasswordToken($token)->shouldBeCalled()->willReturn($user); $user->isRememberPasswordTokenExpired()->shouldBeCalled()->willReturn(true); $this->shouldThrow(UserTokenExpiredException::class)->during__invoke($query); }