Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php declare(strict_types=1); /** * This file is part of CodeIgniter 4 framework. * ..

Decoded Output download

<?php

declare(strict_types=1);

/**
 * This file is part of CodeIgniter 4 framework.
 *
 * (c) CodeIgniter Foundation <[email protected]>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

namespace CodeIgniter\HTTP;

use CodeIgniter\Test\CIUnitTestCase;
use Config\Services;
use PHPUnit\Framework\Attributes\Group;

/**
 * @internal
 */
#[Group('Others')]
final class CorsTest extends CIUnitTestCase
{
    /**
     * @param array{
     *      allowedOrigins?: list<string>,
     *      allowedOriginsPatterns?: list<string>,
     *      supportsCredentials?: bool,
     *      allowedHeaders?: list<string>,
     *      exposedHeaders?: list<string>,
     *      allowedMethods?: list<string>,
     *      maxAge?: int,
     *  } $config
     */
    private function createCors(array $config = []): Cors
    {
        return new Cors($config);
    }

    private function createRequest(): IncomingRequest
    {
        return Services::incomingrequest(null, false);
    }

    /**
     * @return array<string, mixed>
     */
    private function getDefaultConfig(): array
    {
        return [
            'allowedOrigins'         => [],
            'allowedOriginsPatterns' => [],
            'supportsCredentials'    => false,
            'allowedHeaders'         => ['X-API-KEY', 'X-Requested-With', 'Content-Type', 'Accept'],
            'allowedMethods'         => ['PUT'],
            'maxAge'                 => 3600,
        ];
    }

    private function assertHeader(ResponseInterface $response, string $name, string $value): void
    {
        $this->assertSame($value, $response->getHeaderLine($name));
    }

    public function testInstantiate(): void
    {
        $cors = $this->createCors();

        $this->assertInstanceOf(Cors::class, $cors);
    }

    public function testIsPreflightRequestTrue(): void
    {
        $cors = $this->createCors();

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT');

        $this->assertTrue($cors->isPreflightRequest($request));
    }

    public function testIsPreflightRequestFalse(): void
    {
        $cors = $this->createCors();

        $request = $this->createRequest()
            ->withMethod('OPTIONS');

        $this->assertFalse($cors->isPreflightRequest($request));
    }

    public function testHandlePreflightRequestSingleAllowedOrigin(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Credentials')
        );
    }

    public function testHandlePreflightRequestMultipleAllowedOriginsAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Origin'
        );
    }

    public function testHandlePreflightRequestMultipleAllowedOriginsAllowedAlreadyVary(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false)
            ->setHeader('Vary', 'Accept-Language');

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Accept-Language, Origin'
        );
    }

    public function testHandlePreflightRequestMultipleAllowedOriginsNotAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://bad.site.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Origin')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }

    public function testHandlePreflightRequestAllowedOriginsPatternsAllowed(): void
    {
        $config                           = $this->getDefaultConfig();
        $config['allowedOriginsPatterns'] = ['https://\w+\.example\.com'];
        $cors                             = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Origin'
        );
    }

    public function testHandlePreflightRequestAllowedOriginsPatternsNotAllowed(): void
    {
        $config                           = $this->getDefaultConfig();
        $config['allowedOriginsPatterns'] = ['https://\w+\.example\.com'];
        $cors                             = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://bad.site.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Origin')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }

    public function testHandlePreflightRequestSingleAllowedOriginWithCredentials(): void
    {
        $config                        = $this->getDefaultConfig();
        $config['allowedOrigins']      = ['http://localhost:8080'];
        $config['supportsCredentials'] = true;
        $cors                          = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Credentials',
            'true'
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginSimpleRequest(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $config['allowedMethods'] = ['GET', 'POST', 'PUT'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('GET')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Credentials')
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginRealRequest(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $config['allowedMethods'] = ['GET', 'POST', 'PUT'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('POST')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginWithCredentials(): void
    {
        $config                        = $this->getDefaultConfig();
        $config['allowedOrigins']      = ['http://localhost:8080'];
        $config['supportsCredentials'] = true;
        $config['allowedMethods']      = ['GET'];
        $cors                          = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('GET')
            ->setHeader('Cookie', 'pageAccess=2')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Credentials',
            'true'
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginWithExposeHeaders(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $config['allowedMethods'] = ['GET'];
        $config['exposedHeaders'] = ['Content-Length', 'X-Kuma-Revision'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('GET')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Expose-Headers',
            'Content-Length, X-Kuma-Revision'
        );
    }

    public function testAddResponseHeadersMultipleAllowedOriginsAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Origin'
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }

    public function testAddResponseHeadersMultipleAllowedOriginsAllowedAlreadyVary(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false)
            ->setHeader('Vary', 'Accept-Language');

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Accept-Language, Origin'
        );
    }

    public function testAddResponseHeadersMultipleAllowedOriginsNotAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('PUT')
            ->setHeader('Origin', 'https://bad.site.com');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Origin')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

declare(strict_types=1);

/**
 * This file is part of CodeIgniter 4 framework.
 *
 * (c) CodeIgniter Foundation <[email protected]>
 *
 * For the full copyright and license information, please view
 * the LICENSE file that was distributed with this source code.
 */

namespace CodeIgniter\HTTP;

use CodeIgniter\Test\CIUnitTestCase;
use Config\Services;
use PHPUnit\Framework\Attributes\Group;

/**
 * @internal
 */
#[Group('Others')]
final class CorsTest extends CIUnitTestCase
{
    /**
     * @param array{
     *      allowedOrigins?: list<string>,
     *      allowedOriginsPatterns?: list<string>,
     *      supportsCredentials?: bool,
     *      allowedHeaders?: list<string>,
     *      exposedHeaders?: list<string>,
     *      allowedMethods?: list<string>,
     *      maxAge?: int,
     *  } $config
     */
    private function createCors(array $config = []): Cors
    {
        return new Cors($config);
    }

    private function createRequest(): IncomingRequest
    {
        return Services::incomingrequest(null, false);
    }

    /**
     * @return array<string, mixed>
     */
    private function getDefaultConfig(): array
    {
        return [
            'allowedOrigins'         => [],
            'allowedOriginsPatterns' => [],
            'supportsCredentials'    => false,
            'allowedHeaders'         => ['X-API-KEY', 'X-Requested-With', 'Content-Type', 'Accept'],
            'allowedMethods'         => ['PUT'],
            'maxAge'                 => 3600,
        ];
    }

    private function assertHeader(ResponseInterface $response, string $name, string $value): void
    {
        $this->assertSame($value, $response->getHeaderLine($name));
    }

    public function testInstantiate(): void
    {
        $cors = $this->createCors();

        $this->assertInstanceOf(Cors::class, $cors);
    }

    public function testIsPreflightRequestTrue(): void
    {
        $cors = $this->createCors();

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT');

        $this->assertTrue($cors->isPreflightRequest($request));
    }

    public function testIsPreflightRequestFalse(): void
    {
        $cors = $this->createCors();

        $request = $this->createRequest()
            ->withMethod('OPTIONS');

        $this->assertFalse($cors->isPreflightRequest($request));
    }

    public function testHandlePreflightRequestSingleAllowedOrigin(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Credentials')
        );
    }

    public function testHandlePreflightRequestMultipleAllowedOriginsAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Origin'
        );
    }

    public function testHandlePreflightRequestMultipleAllowedOriginsAllowedAlreadyVary(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false)
            ->setHeader('Vary', 'Accept-Language');

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Accept-Language, Origin'
        );
    }

    public function testHandlePreflightRequestMultipleAllowedOriginsNotAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://bad.site.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Origin')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }

    public function testHandlePreflightRequestAllowedOriginsPatternsAllowed(): void
    {
        $config                           = $this->getDefaultConfig();
        $config['allowedOriginsPatterns'] = ['https://\w+\.example\.com'];
        $cors                             = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Origin'
        );
    }

    public function testHandlePreflightRequestAllowedOriginsPatternsNotAllowed(): void
    {
        $config                           = $this->getDefaultConfig();
        $config['allowedOriginsPatterns'] = ['https://\w+\.example\.com'];
        $cors                             = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'https://bad.site.com');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Origin')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }

    public function testHandlePreflightRequestSingleAllowedOriginWithCredentials(): void
    {
        $config                        = $this->getDefaultConfig();
        $config['allowedOrigins']      = ['http://localhost:8080'];
        $config['supportsCredentials'] = true;
        $cors                          = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('OPTIONS')
            ->setHeader('Access-Control-Request-Method', 'PUT')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->handlePreflightRequest($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Headers',
            'X-API-KEY, X-Requested-With, Content-Type, Accept'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Methods',
            'PUT'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Credentials',
            'true'
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginSimpleRequest(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $config['allowedMethods'] = ['GET', 'POST', 'PUT'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('GET')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Credentials')
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginRealRequest(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $config['allowedMethods'] = ['GET', 'POST', 'PUT'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('POST')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginWithCredentials(): void
    {
        $config                        = $this->getDefaultConfig();
        $config['allowedOrigins']      = ['http://localhost:8080'];
        $config['supportsCredentials'] = true;
        $config['allowedMethods']      = ['GET'];
        $cors                          = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('GET')
            ->setHeader('Cookie', 'pageAccess=2')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Allow-Credentials',
            'true'
        );
    }

    public function testAddResponseHeadersSingleAllowedOriginWithExposeHeaders(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['http://localhost:8080'];
        $config['allowedMethods'] = ['GET'];
        $config['exposedHeaders'] = ['Content-Length', 'X-Kuma-Revision'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('GET')
            ->setHeader('Origin', 'http://localhost:8080');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'http://localhost:8080'
        );
        $this->assertHeader(
            $response,
            'Access-Control-Expose-Headers',
            'Content-Length, X-Kuma-Revision'
        );
    }

    public function testAddResponseHeadersMultipleAllowedOriginsAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Origin'
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }

    public function testAddResponseHeadersMultipleAllowedOriginsAllowedAlreadyVary(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('PUT')
            ->setHeader('Origin', 'https://api.example.com');

        $response = Services::response(null, false)
            ->setHeader('Vary', 'Accept-Language');

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertHeader(
            $response,
            'Access-Control-Allow-Origin',
            'https://api.example.com'
        );
        $this->assertHeader(
            $response,
            'Vary',
            'Accept-Language, Origin'
        );
    }

    public function testAddResponseHeadersMultipleAllowedOriginsNotAllowed(): void
    {
        $config                   = $this->getDefaultConfig();
        $config['allowedOrigins'] = ['https://example.com', 'https://api.example.com'];
        $cors                     = $this->createCors($config);

        $request = $this->createRequest()
            ->withMethod('PUT')
            ->setHeader('Origin', 'https://bad.site.com');

        $response = Services::response(null, false);

        $response = $cors->addResponseHeaders($request, $response);

        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Origin')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Headers')
        );
        $this->assertFalse(
            $response->hasHeader('Access-Control-Allow-Methods')
        );
    }
}

Function Calls

None

Variables

None

Stats

MD5 21ab90c49dd5fb9a3e018230d20bee85
Eval Count 0
Decode Time 120 ms