Passed
Push — main ( e725c0...cb140d )
by PRATIK
12:30
created

BouncerController::verification()   A

Complexity

Conditions 5
Paths 7

Size

Total Lines 15
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 5
eloc 12
c 1
b 0
f 1
nc 7
nop 1
dl 0
loc 15
rs 9.5555
1
<?php
2
3
namespace Pratiksh\Adminetic\Http\Controllers\Auth;
4
5
use Illuminate\Http\Request;
6
use Illuminate\Routing\Controller;
7
8
class BouncerController extends Controller
9
{
10
    /**
11
     *
12
     * Bouncer verfication page
13
     *
14
     */
15
    public function verification_page()
16
    {
17
        return view('adminetic::admin.auth.verification_page');
18
    }
19
20
    /**
21
     *
22
     * Bouncer Verfication
23
     *
24
     */
25
    public function verification(Request $request)
26
    {
27
        $request->validate([
28
            'verfication_code' => 'required',
29
        ]);
30
        if ($request->has('verfication_code')) {
31
            $credential = (session()->has('destination_password') ? session()->get('destination_password') : config('adminetic.default_bouncer_credential', 'adminetic'));
32
            if ($request->verfication_code == $credential) {
33
                $verified_routes = session()->get('verified_routes') ?? array();
34
                $destination_route = session()->has('destination_route') ? session()->get('destination_route') : url()->previous();
35
                array_push($verified_routes, $destination_route);
36
                session()->put('verified_routes', array_unique($verified_routes));
37
                return redirect()->to($destination_route)->withSuccess('Verified Successfully');
38
            } else {
39
                return redirect()->back()->withFail('Invalid Verfication Code');
40
            }
41
        }
42
    }
43
}
44