Files
ChatbotAI/app/Http/Middleware/EnsureUserRole.php
2026-05-18 08:56:23 +08:00

30 lines
699 B
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
/**
* EnsureUserRole Middleware
*
* Periksa sama ada user mempunyai role yang diperlukan.
* Guna: ->middleware('role:admin') atau ->middleware('role:admin,staff')
*/
class EnsureUserRole
{
public function handle(Request $request, Closure $next, string ...$roles): Response
{
if (!$request->user()) {
return redirect()->route('login');
}
if (!in_array($request->user()->role, $roles)) {
abort(403, 'Anda tidak mempunyai kebenaran untuk akses halaman ini.');
}
return $next($request);
}
}