Passed
Push — main ( ce37db...b14ddb )
by Tan
03:04
created

SimpleCorsMiddleware::handle()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 24
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 2
eloc 14
c 1
b 0
f 1
nc 2
nop 2
dl 0
loc 24
rs 9.7998
1
<?php
2
3
namespace CSlant\Blog\Api\Http\Middlewares;
4
5
use Closure;
6
use Illuminate\Http\Request;
7
use Symfony\Component\HttpFoundation\Response;
8
9
class SimpleCorsMiddleware
10
{
11
    /**
12
     * Handle an incoming request.
13
     */
14
    public function handle(Request $request, Closure $next): Response
15
    {
16
        // Simple: allow all origins
17
        $origin = $request->headers->get('Origin', '*');
18
19
        // Handle preflight OPTIONS request
20
        if ($request->getMethod() === 'OPTIONS') {
21
            return response('', 200)
22
                ->header('Access-Control-Allow-Origin', $origin)
23
                ->header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS, PATCH')
24
                ->header('Access-Control-Allow-Headers', 'Accept, Authorization, Content-Type, X-Requested-With, X-CSRF-TOKEN, X-XSRF-TOKEN, Origin')
25
                ->header('Access-Control-Allow-Credentials', 'true')
26
                ->header('Access-Control-Max-Age', '86400');
27
        }
28
29
        $response = $next($request);
30
31
        // Add CORS headers to response
32
        $response->headers->set('Access-Control-Allow-Origin', $origin);
33
        $response->headers->set('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS, PATCH');
34
        $response->headers->set('Access-Control-Allow-Headers', 'Accept, Authorization, Content-Type, X-Requested-With, X-CSRF-TOKEN, X-XSRF-TOKEN, Origin');
35
        $response->headers->set('Access-Control-Allow-Credentials', 'true');
36
37
        return $response;
38
    }
39
}
40