Passed
Push — master ( 6298f9...affa16 )
by Jianhua
04:35
created

Authorization::handle()   B

Complexity

Conditions 9
Paths 9

Size

Total Lines 32
Code Lines 20

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 9
eloc 20
c 1
b 0
f 0
nc 9
nop 3
dl 0
loc 32
rs 8.0555
1
<?php
2
3
namespace App\Http\Middleware\Admin;
4
5
use App\Model\Admin\Menu;
6
use Closure;
7
use Illuminate\Support\Facades\Auth;
8
use Illuminate\Support\Facades\Route;
9
10
class Authorization
11
{
12
    /**
13
     * Handle an incoming request.
14
     *
15
     * @param  \Illuminate\Http\Request  $request
16
     * @param  \Closure  $next
17
     * @param   string
18
     * @return mixed
19
     */
20
    public function handle($request, Closure $next, $guard)
21
    {
22
        $user = Auth::guard($guard)->user();
23
        if (in_array($user->id, config('light.superAdmin'))) {
24
            return $next($request);
25
        }
26
27
        $route = Route::current();
28
        $routeName = $route->getName();
29
        $permission = Menu::where('route', $routeName)->where('route_params', '')->first();
30
        if ($permission && $user->can($permission->name)) {
31
            return $next($request);
32
        }
33
34
        $routeParams = $route->parameters();
35
        if (empty($routeParams)) {
36
            return $next($request);
37
        }
38
        foreach ($routeParams as $k => $v) {
39
            $val = "{$k}:{$v}";
40
            break;
41
        }
42
43
        $permission = Menu::where('route', $routeName)->where('route_params', $val)->first();
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $val does not seem to be defined for all execution paths leading up to this point.
Loading history...
44
        if ($permission && $user->can($permission->name)) {
45
            return $next($request);
46
        }
47
48
        if ($request->expectsJson()) {
49
            return response()->json(['code' => 401, 'msg' => "未授权操作(路由别名:{$routeName})"], 401);
50
        }
51
        abort(401, "未授权操作(路由别名:{$routeName})");
52
    }
53
}
54