Completed
Pull Request — master (#12)
by
unknown
03:54
created

ResetPasswordHandler::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 4
rs 10
cc 1
eloc 2
nc 1
nop 1
1
<?php
2
3
namespace SumoCoders\FrameworkMultiUserBundle\Command;
4
5
use SumoCoders\FrameworkMultiUserBundle\Exception\InvalidPasswordConfirmationException;
6
use SumoCoders\FrameworkMultiUserBundle\User\UserRepositoryCollection;
7
8
class ResetPasswordHandler
9
{
10
    /**
11
     * @var UserRepositoryCollection
12
     */
13
    private $userRepositoryCollection;
14
15
    /**
16
     * PasswordResetHandler constructor.
17
     *
18
     * @param UserRepositoryCollection $userRepositoryCollection
19
     */
20
    public function __construct(UserRepositoryCollection $userRepositoryCollection)
21
    {
22
        $this->userRepositoryCollection = $userRepositoryCollection;
23
    }
24
25
    /**
26
     * @param ResetPassword $command
27
     *
28
     * @throws InvalidPasswordConfirmationException
29
     */
30
    public function handle(ResetPassword $command)
31
    {
32
        if (!$command->passwordConfirmationIsValid()) {
33
            throw new InvalidPasswordConfirmationException('The password confirmation isn\'t valid');
34
        }
35
        
36
        $user = $command->getUser();
37
        $user->setPassword($command->getPassword());
38
        $user->clearPasswordResetToken();
39
        $repository = $this->userRepositoryCollection->findRepositoryByClassName(get_class($user));
40
        $repository->update($user, $user);
41
42
        return;
43
    }
44
}
45