Completed
Pull Request — master (#64)
by Rafael
02:06
created

PasswordValidator   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 38
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Importance

Changes 0
Metric Value
wmc 7
lcom 1
cbo 1
dl 0
loc 38
rs 10
c 0
b 0
f 0

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A validate() 0 4 1
A validatePassword() 0 7 5
1
<?php
2
3
namespace WeDevBr\Bankly\Validators\Card;
4
5
use WeDevBr\Bankly\Types\Card\Password;
6
7
/**
8
 * PasswordValidator class
9
 *
10
 * PHP version 7.3|7.4|8.0
11
 *
12
 * @author    WeDev Brasil Team <[email protected]>
13
 * @author    Yan de Paula <[email protected]>
14
 * @copyright 2020 We Dev Tecnologia Ltda
15
 * @link      https://github.com/wedevBr/bankly-laravel/
16
 */
17
class PasswordValidator
18
{
19
    /**
20
     * @var Password
21
     */
22
    private $password;
23
24
    /**
25
     * PasswordValidator constructor.
26
     * @param Password $password
27
     */
28
    public function __construct(Password $password)
29
    {
30
        $this->password = $password;
31
    }
32
33
    /**
34
     * This validate the password
35
     */
36
    public function validate(): void
37
    {
38
        $this->validatePassword();
39
    }
40
41
    /**
42
     * This validate a card password
43
     *
44
     * @return void
45
     * @throws InvalidArgumentException
46
     */
47
    private function validatePassword()
48
    {
49
        $password = $this->password->password;
50
        if (empty($password) || !is_string($password) || !is_numeric($password) || strlen($password) != 4) {
51
            throw new \InvalidArgumentException('password should be a numeric string');
52
        }
53
    }
54
}
55