Completed
Pull Request — develop (#50)
by Abdelrahman
01:55
created

ReauthenticationController::processPassword()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 20
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 11
c 1
b 0
f 0
nc 2
nop 1
dl 0
loc 20
rs 9.4285
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Cortex\Fort\Http\Controllers\Frontarea;
6
7
use Illuminate\Http\Request;
8
use Illuminate\Support\Facades\Hash;
9
use Cortex\Fort\Traits\TwoFactorAuthenticatesUsers;
10
use Cortex\Foundation\Http\Controllers\AuthenticatedController;
11
12
class ReauthenticationController extends AuthenticatedController
13
{
14
    use TwoFactorAuthenticatesUsers;
15
16
    /**
17
     * @param Request $request
18
     *
19
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
20
     */
21
    public function processPassword(Request $request)
22
    {
23
        $redirect_url = session('cortex.fort.reauthentication.intended');
24
        $session_name = session('cortex.fort.reauthentication.session_name');
25
26
        if (Hash::check($request->input('password'), request()->user()->password)) {
27
            $this->setSession($session_name);
28
29
            return intend([
30
                'intended' => url($redirect_url),
31
            ]);
32
        }
33
34
        return intend([
35
            'intended' => url($redirect_url),
36
            'withErrors' => [
37
                'password' => trans('cortex/fort::messages.auth.failed'),
38
            ],
39
        ]);
40
    }
41
42
    /**
43
     * @param Request $request
44
     *
45
     * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\RedirectResponse
46
     */
47
    public function processTwofactor(Request $request)
48
    {
49
        $redirect_url = session('cortex.fort.reauthentication.intended');
50
        $session_name = session('cortex.fort.reauthentication.session_name');
51
52
        $guard = $this->getGuard();
53
        $user = $request->user($guard);
54
        $token = (int) $request->input('token');
55
56
        if ($this->attemptTwoFactor($user, $token)) {
57
            $this->setSession($session_name);
58
59
            return intend([
60
                'intended' => url($redirect_url),
61
            ]);
62
        }
63
64
        return intend([
65
            'intended' => url($redirect_url),
66
            'withErrors' => ['token' => trans('cortex/fort::messages.verification.twofactor.invalid_token')],
67
        ]);
68
    }
69
70
    /**
71
     * @param $session_name
72
     */
73
    protected function setSession($session_name)
0 ignored issues
show
Coding Style Naming introduced by
The parameter $session_name is not named in camelCase.

This check marks parameter names that have not been written in camelCase.

In camelCase names are written without any punctuation, the start of each new word being marked by a capital letter. Thus the name database connection string becomes databaseConnectionString.

Loading history...
74
    {
75
        session()->put($session_name, time());
76
        session()->forget('cortex.fort.reauthentication.intended');
77
        session()->forget('cortex.fort.reauthentication.session_name');
78
    }
79
}
80