migrants-nt-sec/app/Http/Middleware/Cors.php

39 lines
1.3 KiB
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
class Cors
{
public function handle(Request $request, Closure $next)
{
$allowedOrigins = [
'http://localhost:5173', // React dev server URL
'http://127.0.0.1:5173', // Alternative localhost
// Add your production domain when ready
// 'https://yourdomain.com'
];
$origin = $request->headers->get('Origin');
// Handle preflight OPTIONS requests
if ($request->getMethod() === 'OPTIONS') {
$response = response('', 200);
} else {
$response = $next($request);
}
// Set CORS headers
if (in_array($origin, $allowedOrigins)) {
$response->headers->set('Access-Control-Allow-Origin', $origin);
}
$response->headers->set('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS, PATCH');
$response->headers->set('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, Accept, Origin');
$response->headers->set('Access-Control-Allow-Credentials', 'true');
$response->headers->set('Access-Control-Max-Age', '86400'); // Cache preflight for 24 hours
return $response;
}
}