1234567891011121314151617181920212223242526272829 |
- <?php
- namespace App\Http\Middleware;
- use Closure;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Route;
- use Spatie\Permission\Exceptions\UnauthorizedException;
- use Symfony\Component\HttpFoundation\Response;
- class CheckPermission
- {
- /**
- * Handle an incoming request.
- *
- * @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
- */
- public function handle(Request $request, Closure $next): Response
- {
- $permission = Route::currentRouteName();
- if (Auth::user()->hasPermissionTo($permission)) {
- return $next($request);
- }
- throw UnauthorizedException::forPermissions([$permission]);
- }
- }
|