|
16 | 16 | use CodeIgniter\Exceptions\ConfigException; |
17 | 17 | use CodeIgniter\HTTP\CLIRequest; |
18 | 18 | use CodeIgniter\HTTP\IncomingRequest; |
| 19 | +use CodeIgniter\HTTP\RedirectResponse; |
19 | 20 | use CodeIgniter\HTTP\RequestInterface; |
20 | 21 | use CodeIgniter\HTTP\ResponseInterface; |
21 | 22 | use CodeIgniter\HTTP\SiteURI; |
@@ -154,6 +155,25 @@ private function handle(RequestInterface $request): ResponseInterface |
154 | 155 | return $response; |
155 | 156 | } |
156 | 157 |
|
| 158 | + private function handleRedirect(RequestInterface $request): ResponseInterface |
| 159 | + { |
| 160 | + $response = $this->cors->before($request); |
| 161 | + if ($response instanceof ResponseInterface) { |
| 162 | + $this->response = $response; |
| 163 | + |
| 164 | + return $response; |
| 165 | + } |
| 166 | + |
| 167 | + $response = service('redirectresponse'); |
| 168 | + |
| 169 | + $response = $this->cors->after($request, $response); |
| 170 | + $response ??= service('redirectresponse'); |
| 171 | + |
| 172 | + $this->response = $response; |
| 173 | + |
| 174 | + return $response; |
| 175 | + } |
| 176 | + |
157 | 177 | public function testItDoesModifyOnARequestWithSameOrigin(): void |
158 | 178 | { |
159 | 179 | $this->cors = $this->createCors(['allowedOrigins' => ['*']]); |
@@ -461,4 +481,29 @@ public function testItAddsVaryAccessControlRequestMethodHeaderEvenIfItIsNormalOp |
461 | 481 | // Always adds `Vary: Access-Control-Request-Method` header. |
462 | 482 | $this->assertHeader('Vary', 'Access-Control-Request-Method'); |
463 | 483 | } |
| 484 | + |
| 485 | + public function testItReturnsAllowOriginHeaderOnValidActualRequestWithRedirect(): void |
| 486 | + { |
| 487 | + $this->cors = $this->createCors(); |
| 488 | + $request = $this->createValidActualRequest(); |
| 489 | + |
| 490 | + $response = $this->handleRedirect($request); |
| 491 | + |
| 492 | + $this->assertInstanceOf(RedirectResponse::class, $response); |
| 493 | + $this->assertTrue($response->hasHeader('Access-Control-Allow-Origin')); |
| 494 | + $this->assertHeader('Access-Control-Allow-Origin', 'http://localhost'); |
| 495 | + } |
| 496 | + |
| 497 | + public function testItReturnsAllowOriginHeaderOnAllowAllOriginRequestWithRedirect(): void |
| 498 | + { |
| 499 | + $this->cors = $this->createCors(['allowedOrigins' => ['*']]); |
| 500 | + $request = $this->createRequest(); |
| 501 | + $request->setHeader('Origin', 'http://localhost'); |
| 502 | + |
| 503 | + $response = $this->handleRedirect($request); |
| 504 | + |
| 505 | + $this->assertInstanceOf(RedirectResponse::class, $response); |
| 506 | + $this->assertTrue($response->hasHeader('Access-Control-Allow-Origin')); |
| 507 | + $this->assertHeader('Access-Control-Allow-Origin', '*'); |
| 508 | + } |
464 | 509 | } |
0 commit comments