2023-11-17 14:44:01 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
|
|
2023-12-04 20:40:49 +08:00
|
|
|
use App\Exceptions\ApiException;
|
2025-01-21 14:57:54 +08:00
|
|
|
use Illuminate\Support\Facades\Auth;
|
2023-11-17 14:44:01 +08:00
|
|
|
use Closure;
|
2025-05-07 19:48:19 +08:00
|
|
|
use App\Models\User;
|
2023-11-17 14:44:01 +08:00
|
|
|
|
|
|
|
|
class Admin
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* Handle an incoming request.
|
|
|
|
|
*
|
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
|
* @param \Closure $next
|
|
|
|
|
* @return mixed
|
|
|
|
|
*/
|
|
|
|
|
public function handle($request, Closure $next)
|
|
|
|
|
{
|
2025-05-07 19:48:19 +08:00
|
|
|
/** @var User|null $user */
|
2025-01-21 14:57:54 +08:00
|
|
|
$user = Auth::guard('sanctum')->user();
|
2025-05-07 19:48:19 +08:00
|
|
|
|
|
|
|
|
if (!$user || !$user->is_admin) {
|
|
|
|
|
return response()->json(['message' => 'Unauthorized'], 403);
|
2025-01-21 14:57:54 +08:00
|
|
|
}
|
2025-05-07 19:48:19 +08:00
|
|
|
|
2023-11-17 14:44:01 +08:00
|
|
|
return $next($request);
|
|
|
|
|
}
|
|
|
|
|
}
|