Passed
Push — dependabot/npm_and_yarn/dev/st... ( 790070...2dbd00 )
by
unknown
17:44 queued 12:22
created

InitializeUser::handle()   C

Complexity

Conditions 13
Paths 55

Size

Total Lines 48
Code Lines 30

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 30
dl 0
loc 48
rs 6.6166
c 0
b 0
f 0
cc 13
nc 55
nop 2

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
namespace App\Http\Middleware;
4
5
use Closure;
6
use App\Models\Applicant;
7
use App\Models\HrAdvisor;
8
use App\Models\Manager;
9
use Illuminate\Support\Facades\Auth;
10
use Illuminate\Support\Facades\App;
11
use Illuminate\Support\Facades\Config;
12
13
class InitializeUser
14
{
15
    /**
16
     * Ensure that a logged in user is initialized correctly according to its UserRole
17
     * (ie has an associated Applicant or Manager profile)
18
     *
19
     * @param  \Illuminate\Http\Request  $request
20
     * @param  \Closure  $next
21
     * @return mixed
22
     */
23
    public function handle($request, Closure $next)
24
    {
25
        if (Auth::check()) {
26
            $user = Auth::user();
27
28
            // If running in a local environment, and FORCE_ADMIN is true,
29
            // automatically set any logged in user to (temporarilly) be an admin
30
            if (App::environment() == 'local' && Config::get('app.force_admin')) {
31
                $user->setRole('admin');
32
                $user->save();
33
            }
34
35
            // Ensure the user has a proper profile associated with it
36
            // If no profile exists yet create one.
37
            // Admins should be given an applicant and manager profile
38
            if ($user->isApplicant() ||
39
                    $user->isAdmin()) {
40
                $applicantProfile = $user->applicant;
41
                if ($applicantProfile === null) {
42
                    $applicantProfile = new Applicant();
43
                    $applicantProfile->user_id = $user->id;
44
                    $applicantProfile->save();
45
                    $user->refresh();
46
                }
47
            }
48
            if ($user->isManager() ||
49
                    $user->isAdmin()) {
50
                $managerProfile = $user->manager;
51
                if ($managerProfile === null) {
52
                    $managerProfile = new Manager();
53
                    $managerProfile->user_id = $user->id;
54
                    $managerProfile->save();
55
                    $user->refresh();
56
                }
57
            }
58
            if ($user->isHrAdvisor() ||
59
                    $user->isAdmin()) {
60
                $hrAdvisorProfile = $user->hr_advisor;
61
                if ($hrAdvisorProfile === null) {
62
                    $hrAdvisorProfile = new HrAdvisor();
63
                    $hrAdvisorProfile->user_id = $user->id;
64
                    $hrAdvisorProfile->save();
65
                    $user->refresh();
66
                }
67
            }
68
        }
69
70
        return $next($request);
71
    }
72
}
73