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

36 lines
1.0 KiB
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class Cors
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle(Request $request, Closure $next): Response
{
$response = $next($request);
// Add CORS headers to the response
$response->headers->set('Access-Control-Allow-Origin', '*');
$response->headers->set('Access-Control-Allow-Methods', 'GET, POST, PUT, PATCH, DELETE, OPTIONS');
$response->headers->set('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, Accept, X-CSRF-TOKEN');
$response->headers->set('Access-Control-Max-Age', '86400'); // 24 hours
// Handle preflight OPTIONS requests
if ($request->isMethod('OPTIONS')) {
return response()->json('', 200);
}
return $response;
}
}