Passed
Push — master ( 507209...913857 )
by Simon
02:03
created

BootstrapMFAAuthenticator::validateBackupCode()   B

Complexity

Conditions 4
Paths 4

Size

Total Lines 22
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 22
rs 8.9197
c 0
b 0
f 0
cc 4
eloc 12
nc 4
nop 3
1
<?php
2
3
namespace Firesphere\BootstrapMFA\Authenticators;
4
5
use Firesphere\BootstrapMFA\Models\BackupCode;
6
use SilverStripe\ORM\ValidationResult;
7
use SilverStripe\Security\Member;
8
use SilverStripe\Security\MemberAuthenticator\MemberAuthenticator;
9
10
class BootstrapMFAAuthenticator extends MemberAuthenticator
11
{
12
13
    /**
14
     * @param Member $member
15
     * @param string $token
16
     * @param ValidationResult|null $result
17
     * @return bool|Member
18
     */
19
    public function validateBackupCode($member, $token, &$result = null)
20
    {
21
        if (!$result) {
22
            $result = new ValidationResult();
23
        }
24
        $token = $member->encryptWithUserSettings($token);
25
26
        /** @var BackupCode $backupCode */
27
        $backupCode = BackupCode::getValidTokensForMember($member)
28
            ->filter(['Code' => $token])
29
            ->first();
30
31
        if ($backupCode && $backupCode->exists()) {
32
            $backupCode->expire();
33
34
            return $member;
35
        }
36
37
        $member->registerFailedLogin();
38
        $result->addError('Invalid token');
39
40
        return false;
41
    }
42
}
43