HEX
Server: Apache/2.4.65 (Debian)
System: Linux 88f31f35b0b8 6.1.0-38-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.147-1 (2025-08-02) x86_64
User: www-data (33)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/matomo/app/core/API/CORSHandler.php
<?php

/**
 * Matomo - free/libre analytics platform
 *
 * @link    https://matomo.org
 * @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
 */
namespace Piwik\API;

use Piwik\Common;
use Piwik\Url;
class CORSHandler
{
    /**
     * @var array
     */
    protected $domains;
    public function __construct()
    {
        $this->domains = Url::getCorsHostsFromConfig();
    }
    public function handle()
    {
        if (empty($this->domains)) {
            return;
        }
        Common::sendHeader('Vary: Origin');
        // allow Piwik to serve data to all domains
        if (in_array("*", $this->domains)) {
            Common::sendHeader('Access-Control-Allow-Credentials: true');
            if (!empty($_SERVER['HTTP_ORIGIN'])) {
                Common::sendHeader('Access-Control-Allow-Origin: ' . $_SERVER['HTTP_ORIGIN']);
                return;
            }
            Common::sendHeader('Access-Control-Allow-Origin: *');
            return;
        }
        // specifically allow if it is one of the allowlisted CORS domains
        if (!empty($_SERVER['HTTP_ORIGIN'])) {
            $origin = $_SERVER['HTTP_ORIGIN'];
            if (in_array($origin, $this->domains, \true)) {
                Common::sendHeader('Access-Control-Allow-Credentials: true');
                Common::sendHeader('Access-Control-Allow-Origin: ' . $_SERVER['HTTP_ORIGIN']);
            }
        }
    }
}