EscolaLMS/API

View on GitHub
app/Http/Middleware/CheckRole.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

namespace App\Http\Middleware;

use Closure;
use Auth;
use Request;

class CheckRole
{
    /**
     * Handle an incoming request.
     *
     * @param \Illuminate\Http\Request $request
     * @param \Closure $next
     * @return mixed
     */
    public function handle($request, Closure $next, ...$roles)
    {
        $user = Auth::user();

        foreach ($roles as $role) {
            // Check if user has the role This check will depend on how your roles are set up
            if ($user->hasRole($role)) {
                return $next($request);
            }
        }

        if (Request::isMethod('get')) {
            abort(401);
        } elseif (Request::isMethod('post')) {
            return redirect('/');
        }
    }
}