first commit

This commit is contained in:
2026-03-05 13:07:40 +01:00
commit 64ba0721ee
25709 changed files with 4691006 additions and 0 deletions

View File

@@ -0,0 +1,25 @@
<?php
// autoload.php @generated by Composer
if (PHP_VERSION_ID < 50600) {
if (!headers_sent()) {
header('HTTP/1.1 500 Internal Server Error');
}
$err = 'Composer 2.3.0 dropped support for autoloading on PHP <5.6 and you are running '.PHP_VERSION.', please upgrade PHP or use Composer 2.2 LTS via "composer self-update --2.2". Aborting.'.PHP_EOL;
if (!ini_get('display_errors')) {
if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
fwrite(STDERR, $err);
} elseif (!headers_sent()) {
echo $err;
}
}
trigger_error(
$err,
E_USER_ERROR
);
}
require_once __DIR__ . '/composer/autoload_real.php';
return ComposerAutoloaderInitbe41e7eddc7451a6aef49b964b1115c0::getLoader();

View File

@@ -0,0 +1,585 @@
<?php
/*
* This file is part of Composer.
*
* (c) Nils Adermann <naderman@naderman.de>
* Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Composer\Autoload;
/**
* ClassLoader implements a PSR-0, PSR-4 and classmap class loader.
*
* $loader = new \Composer\Autoload\ClassLoader();
*
* // register classes with namespaces
* $loader->add('Symfony\Component', __DIR__.'/component');
* $loader->add('Symfony', __DIR__.'/framework');
*
* // activate the autoloader
* $loader->register();
*
* // to enable searching the include path (eg. for PEAR packages)
* $loader->setUseIncludePath(true);
*
* In this example, if you try to use a class in the Symfony\Component
* namespace or one of its children (Symfony\Component\Console for instance),
* the autoloader will first look for the class under the component/
* directory, and it will then fallback to the framework/ directory if not
* found before giving up.
*
* This class is loosely based on the Symfony UniversalClassLoader.
*
* @author Fabien Potencier <fabien@symfony.com>
* @author Jordi Boggiano <j.boggiano@seld.be>
* @see https://www.php-fig.org/psr/psr-0/
* @see https://www.php-fig.org/psr/psr-4/
*/
class ClassLoader
{
/** @var \Closure(string):void */
private static $includeFile;
/** @var ?string */
private $vendorDir;
// PSR-4
/**
* @var array[]
* @psalm-var array<string, array<string, int>>
*/
private $prefixLengthsPsr4 = array();
/**
* @var array[]
* @psalm-var array<string, array<int, string>>
*/
private $prefixDirsPsr4 = array();
/**
* @var array[]
* @psalm-var array<string, string>
*/
private $fallbackDirsPsr4 = array();
// PSR-0
/**
* @var array[]
* @psalm-var array<string, array<string, string[]>>
*/
private $prefixesPsr0 = array();
/**
* @var array[]
* @psalm-var array<string, string>
*/
private $fallbackDirsPsr0 = array();
/** @var bool */
private $useIncludePath = false;
/**
* @var string[]
* @psalm-var array<string, string>
*/
private $classMap = array();
/** @var bool */
private $classMapAuthoritative = false;
/**
* @var bool[]
* @psalm-var array<string, bool>
*/
private $missingClasses = array();
/** @var ?string */
private $apcuPrefix;
/**
* @var self[]
*/
private static $registeredLoaders = array();
/**
* @param ?string $vendorDir
*/
public function __construct($vendorDir = null)
{
$this->vendorDir = $vendorDir;
self::initializeIncludeClosure();
}
/**
* @return string[]
*/
public function getPrefixes()
{
if (!empty($this->prefixesPsr0)) {
return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
}
return array();
}
/**
* @return array[]
* @psalm-return array<string, array<int, string>>
*/
public function getPrefixesPsr4()
{
return $this->prefixDirsPsr4;
}
/**
* @return array[]
* @psalm-return array<string, string>
*/
public function getFallbackDirs()
{
return $this->fallbackDirsPsr0;
}
/**
* @return array[]
* @psalm-return array<string, string>
*/
public function getFallbackDirsPsr4()
{
return $this->fallbackDirsPsr4;
}
/**
* @return string[] Array of classname => path
* @psalm-return array<string, string>
*/
public function getClassMap()
{
return $this->classMap;
}
/**
* @param string[] $classMap Class to filename map
* @psalm-param array<string, string> $classMap
*
* @return void
*/
public function addClassMap(array $classMap)
{
if ($this->classMap) {
$this->classMap = array_merge($this->classMap, $classMap);
} else {
$this->classMap = $classMap;
}
}
/**
* Registers a set of PSR-0 directories for a given prefix, either
* appending or prepending to the ones previously set for this prefix.
*
* @param string $prefix The prefix
* @param string[]|string $paths The PSR-0 root directories
* @param bool $prepend Whether to prepend the directories
*
* @return void
*/
public function add($prefix, $paths, $prepend = false)
{
if (!$prefix) {
if ($prepend) {
$this->fallbackDirsPsr0 = array_merge(
(array) $paths,
$this->fallbackDirsPsr0
);
} else {
$this->fallbackDirsPsr0 = array_merge(
$this->fallbackDirsPsr0,
(array) $paths
);
}
return;
}
$first = $prefix[0];
if (!isset($this->prefixesPsr0[$first][$prefix])) {
$this->prefixesPsr0[$first][$prefix] = (array) $paths;
return;
}
if ($prepend) {
$this->prefixesPsr0[$first][$prefix] = array_merge(
(array) $paths,
$this->prefixesPsr0[$first][$prefix]
);
} else {
$this->prefixesPsr0[$first][$prefix] = array_merge(
$this->prefixesPsr0[$first][$prefix],
(array) $paths
);
}
}
/**
* Registers a set of PSR-4 directories for a given namespace, either
* appending or prepending to the ones previously set for this namespace.
*
* @param string $prefix The prefix/namespace, with trailing '\\'
* @param string[]|string $paths The PSR-4 base directories
* @param bool $prepend Whether to prepend the directories
*
* @throws \InvalidArgumentException
*
* @return void
*/
public function addPsr4($prefix, $paths, $prepend = false)
{
if (!$prefix) {
// Register directories for the root namespace.
if ($prepend) {
$this->fallbackDirsPsr4 = array_merge(
(array) $paths,
$this->fallbackDirsPsr4
);
} else {
$this->fallbackDirsPsr4 = array_merge(
$this->fallbackDirsPsr4,
(array) $paths
);
}
} elseif (!isset($this->prefixDirsPsr4[$prefix])) {
// Register directories for a new namespace.
$length = strlen($prefix);
if ('\\' !== $prefix[$length - 1]) {
throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
}
$this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
$this->prefixDirsPsr4[$prefix] = (array) $paths;
} elseif ($prepend) {
// Prepend directories for an already registered namespace.
$this->prefixDirsPsr4[$prefix] = array_merge(
(array) $paths,
$this->prefixDirsPsr4[$prefix]
);
} else {
// Append directories for an already registered namespace.
$this->prefixDirsPsr4[$prefix] = array_merge(
$this->prefixDirsPsr4[$prefix],
(array) $paths
);
}
}
/**
* Registers a set of PSR-0 directories for a given prefix,
* replacing any others previously set for this prefix.
*
* @param string $prefix The prefix
* @param string[]|string $paths The PSR-0 base directories
*
* @return void
*/
public function set($prefix, $paths)
{
if (!$prefix) {
$this->fallbackDirsPsr0 = (array) $paths;
} else {
$this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths;
}
}
/**
* Registers a set of PSR-4 directories for a given namespace,
* replacing any others previously set for this namespace.
*
* @param string $prefix The prefix/namespace, with trailing '\\'
* @param string[]|string $paths The PSR-4 base directories
*
* @throws \InvalidArgumentException
*
* @return void
*/
public function setPsr4($prefix, $paths)
{
if (!$prefix) {
$this->fallbackDirsPsr4 = (array) $paths;
} else {
$length = strlen($prefix);
if ('\\' !== $prefix[$length - 1]) {
throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
}
$this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
$this->prefixDirsPsr4[$prefix] = (array) $paths;
}
}
/**
* Turns on searching the include path for class files.
*
* @param bool $useIncludePath
*
* @return void
*/
public function setUseIncludePath($useIncludePath)
{
$this->useIncludePath = $useIncludePath;
}
/**
* Can be used to check if the autoloader uses the include path to check
* for classes.
*
* @return bool
*/
public function getUseIncludePath()
{
return $this->useIncludePath;
}
/**
* Turns off searching the prefix and fallback directories for classes
* that have not been registered with the class map.
*
* @param bool $classMapAuthoritative
*
* @return void
*/
public function setClassMapAuthoritative($classMapAuthoritative)
{
$this->classMapAuthoritative = $classMapAuthoritative;
}
/**
* Should class lookup fail if not found in the current class map?
*
* @return bool
*/
public function isClassMapAuthoritative()
{
return $this->classMapAuthoritative;
}
/**
* APCu prefix to use to cache found/not-found classes, if the extension is enabled.
*
* @param string|null $apcuPrefix
*
* @return void
*/
public function setApcuPrefix($apcuPrefix)
{
$this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null;
}
/**
* The APCu prefix in use, or null if APCu caching is not enabled.
*
* @return string|null
*/
public function getApcuPrefix()
{
return $this->apcuPrefix;
}
/**
* Registers this instance as an autoloader.
*
* @param bool $prepend Whether to prepend the autoloader or not
*
* @return void
*/
public function register($prepend = false)
{
spl_autoload_register(array($this, 'loadClass'), true, $prepend);
if (null === $this->vendorDir) {
return;
}
if ($prepend) {
self::$registeredLoaders = array($this->vendorDir => $this) + self::$registeredLoaders;
} else {
unset(self::$registeredLoaders[$this->vendorDir]);
self::$registeredLoaders[$this->vendorDir] = $this;
}
}
/**
* Unregisters this instance as an autoloader.
*
* @return void
*/
public function unregister()
{
spl_autoload_unregister(array($this, 'loadClass'));
if (null !== $this->vendorDir) {
unset(self::$registeredLoaders[$this->vendorDir]);
}
}
/**
* Loads the given class or interface.
*
* @param string $class The name of the class
* @return true|null True if loaded, null otherwise
*/
public function loadClass($class)
{
if ($file = $this->findFile($class)) {
$includeFile = self::$includeFile;
$includeFile($file);
return true;
}
return null;
}
/**
* Finds the path to the file where the class is defined.
*
* @param string $class The name of the class
*
* @return string|false The path if found, false otherwise
*/
public function findFile($class)
{
// class map lookup
if (isset($this->classMap[$class])) {
return $this->classMap[$class];
}
if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
return false;
}
if (null !== $this->apcuPrefix) {
$file = apcu_fetch($this->apcuPrefix.$class, $hit);
if ($hit) {
return $file;
}
}
$file = $this->findFileWithExtension($class, '.php');
// Search for Hack files if we are running on HHVM
if (false === $file && defined('HHVM_VERSION')) {
$file = $this->findFileWithExtension($class, '.hh');
}
if (null !== $this->apcuPrefix) {
apcu_add($this->apcuPrefix.$class, $file);
}
if (false === $file) {
// Remember that this class does not exist.
$this->missingClasses[$class] = true;
}
return $file;
}
/**
* Returns the currently registered loaders indexed by their corresponding vendor directories.
*
* @return self[]
*/
public static function getRegisteredLoaders()
{
return self::$registeredLoaders;
}
/**
* @param string $class
* @param string $ext
* @return string|false
*/
private function findFileWithExtension($class, $ext)
{
// PSR-4 lookup
$logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
$first = $class[0];
if (isset($this->prefixLengthsPsr4[$first])) {
$subPath = $class;
while (false !== $lastPos = strrpos($subPath, '\\')) {
$subPath = substr($subPath, 0, $lastPos);
$search = $subPath . '\\';
if (isset($this->prefixDirsPsr4[$search])) {
$pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
foreach ($this->prefixDirsPsr4[$search] as $dir) {
if (file_exists($file = $dir . $pathEnd)) {
return $file;
}
}
}
}
}
// PSR-4 fallback dirs
foreach ($this->fallbackDirsPsr4 as $dir) {
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
return $file;
}
}
// PSR-0 lookup
if (false !== $pos = strrpos($class, '\\')) {
// namespaced class name
$logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
. strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
} else {
// PEAR-like class name
$logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
}
if (isset($this->prefixesPsr0[$first])) {
foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
if (0 === strpos($class, $prefix)) {
foreach ($dirs as $dir) {
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
return $file;
}
}
}
}
}
// PSR-0 fallback dirs
foreach ($this->fallbackDirsPsr0 as $dir) {
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
return $file;
}
}
// PSR-0 include paths.
if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
return $file;
}
return false;
}
/**
* @return void
*/
private static function initializeIncludeClosure()
{
if (self::$includeFile !== null) {
return;
}
/**
* Scope isolated include.
*
* Prevents access to $this/self from included files.
*
* @param string $file
* @return void
*/
self::$includeFile = \Closure::bind(static function($file) {
include $file;
}, null, null);
}
}

View File

@@ -0,0 +1,359 @@
<?php
/*
* This file is part of Composer.
*
* (c) Nils Adermann <naderman@naderman.de>
* Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Composer;
use Composer\Autoload\ClassLoader;
use Composer\Semver\VersionParser;
/**
* This class is copied in every Composer installed project and available to all
*
* See also https://getcomposer.org/doc/07-runtime.md#installed-versions
*
* To require its presence, you can require `composer-runtime-api ^2.0`
*
* @final
*/
class InstalledVersions
{
/**
* @var mixed[]|null
* @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}|array{}|null
*/
private static $installed;
/**
* @var bool|null
*/
private static $canGetVendors;
/**
* @var array[]
* @psalm-var array<string, array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
*/
private static $installedByVendor = array();
/**
* Returns a list of all package names which are present, either by being installed, replaced or provided
*
* @return string[]
* @psalm-return list<string>
*/
public static function getInstalledPackages()
{
$packages = array();
foreach (self::getInstalled() as $installed) {
$packages[] = array_keys($installed['versions']);
}
if (1 === \count($packages)) {
return $packages[0];
}
return array_keys(array_flip(\call_user_func_array('array_merge', $packages)));
}
/**
* Returns a list of all package names with a specific type e.g. 'library'
*
* @param string $type
* @return string[]
* @psalm-return list<string>
*/
public static function getInstalledPackagesByType($type)
{
$packagesByType = array();
foreach (self::getInstalled() as $installed) {
foreach ($installed['versions'] as $name => $package) {
if (isset($package['type']) && $package['type'] === $type) {
$packagesByType[] = $name;
}
}
}
return $packagesByType;
}
/**
* Checks whether the given package is installed
*
* This also returns true if the package name is provided or replaced by another package
*
* @param string $packageName
* @param bool $includeDevRequirements
* @return bool
*/
public static function isInstalled($packageName, $includeDevRequirements = true)
{
foreach (self::getInstalled() as $installed) {
if (isset($installed['versions'][$packageName])) {
return $includeDevRequirements || !isset($installed['versions'][$packageName]['dev_requirement']) || $installed['versions'][$packageName]['dev_requirement'] === false;
}
}
return false;
}
/**
* Checks whether the given package satisfies a version constraint
*
* e.g. If you want to know whether version 2.3+ of package foo/bar is installed, you would call:
*
* Composer\InstalledVersions::satisfies(new VersionParser, 'foo/bar', '^2.3')
*
* @param VersionParser $parser Install composer/semver to have access to this class and functionality
* @param string $packageName
* @param string|null $constraint A version constraint to check for, if you pass one you have to make sure composer/semver is required by your package
* @return bool
*/
public static function satisfies(VersionParser $parser, $packageName, $constraint)
{
$constraint = $parser->parseConstraints((string) $constraint);
$provided = $parser->parseConstraints(self::getVersionRanges($packageName));
return $provided->matches($constraint);
}
/**
* Returns a version constraint representing all the range(s) which are installed for a given package
*
* It is easier to use this via isInstalled() with the $constraint argument if you need to check
* whether a given version of a package is installed, and not just whether it exists
*
* @param string $packageName
* @return string Version constraint usable with composer/semver
*/
public static function getVersionRanges($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
$ranges = array();
if (isset($installed['versions'][$packageName]['pretty_version'])) {
$ranges[] = $installed['versions'][$packageName]['pretty_version'];
}
if (array_key_exists('aliases', $installed['versions'][$packageName])) {
$ranges = array_merge($ranges, $installed['versions'][$packageName]['aliases']);
}
if (array_key_exists('replaced', $installed['versions'][$packageName])) {
$ranges = array_merge($ranges, $installed['versions'][$packageName]['replaced']);
}
if (array_key_exists('provided', $installed['versions'][$packageName])) {
$ranges = array_merge($ranges, $installed['versions'][$packageName]['provided']);
}
return implode(' || ', $ranges);
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
*/
public static function getVersion($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['version'])) {
return null;
}
return $installed['versions'][$packageName]['version'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
*/
public static function getPrettyVersion($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['pretty_version'])) {
return null;
}
return $installed['versions'][$packageName]['pretty_version'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as reference
*/
public static function getReference($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['reference'])) {
return null;
}
return $installed['versions'][$packageName]['reference'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as install path. Packages of type metapackages also have a null install path.
*/
public static function getInstallPath($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
return isset($installed['versions'][$packageName]['install_path']) ? $installed['versions'][$packageName]['install_path'] : null;
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @return array
* @psalm-return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}
*/
public static function getRootPackage()
{
$installed = self::getInstalled();
return $installed[0]['root'];
}
/**
* Returns the raw installed.php data for custom implementations
*
* @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect.
* @return array[]
* @psalm-return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}
*/
public static function getRawData()
{
@trigger_error('getRawData only returns the first dataset loaded, which may not be what you expect. Use getAllRawData() instead which returns all datasets for all autoloaders present in the process.', E_USER_DEPRECATED);
if (null === self::$installed) {
// only require the installed.php file if this file is loaded from its dumped location,
// and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
if (substr(__DIR__, -8, 1) !== 'C') {
self::$installed = include __DIR__ . '/installed.php';
} else {
self::$installed = array();
}
}
return self::$installed;
}
/**
* Returns the raw data of all installed.php which are currently loaded for custom implementations
*
* @return array[]
* @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
*/
public static function getAllRawData()
{
return self::getInstalled();
}
/**
* Lets you reload the static array from another file
*
* This is only useful for complex integrations in which a project needs to use
* this class but then also needs to execute another project's autoloader in process,
* and wants to ensure both projects have access to their version of installed.php.
*
* A typical case would be PHPUnit, where it would need to make sure it reads all
* the data it needs from this class, then call reload() with
* `require $CWD/vendor/composer/installed.php` (or similar) as input to make sure
* the project in which it runs can then also use this class safely, without
* interference between PHPUnit's dependencies and the project's dependencies.
*
* @param array[] $data A vendor/composer/installed.php data set
* @return void
*
* @psalm-param array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $data
*/
public static function reload($data)
{
self::$installed = $data;
self::$installedByVendor = array();
}
/**
* @return array[]
* @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
*/
private static function getInstalled()
{
if (null === self::$canGetVendors) {
self::$canGetVendors = method_exists('Composer\Autoload\ClassLoader', 'getRegisteredLoaders');
}
$installed = array();
if (self::$canGetVendors) {
foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) {
if (isset(self::$installedByVendor[$vendorDir])) {
$installed[] = self::$installedByVendor[$vendorDir];
} elseif (is_file($vendorDir.'/composer/installed.php')) {
/** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $required */
$required = require $vendorDir.'/composer/installed.php';
$installed[] = self::$installedByVendor[$vendorDir] = $required;
if (null === self::$installed && strtr($vendorDir.'/composer', '\\', '/') === strtr(__DIR__, '\\', '/')) {
self::$installed = $installed[count($installed) - 1];
}
}
}
}
if (null === self::$installed) {
// only require the installed.php file if this file is loaded from its dumped location,
// and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
if (substr(__DIR__, -8, 1) !== 'C') {
/** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $required */
$required = require __DIR__ . '/installed.php';
self::$installed = $required;
} else {
self::$installed = array();
}
}
if (self::$installed !== array()) {
$installed[] = self::$installed;
}
return $installed;
}
}

View File

@@ -0,0 +1,21 @@
Copyright (c) Nils Adermann, Jordi Boggiano
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is furnished
to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

View File

@@ -0,0 +1,162 @@
<?php
// autoload_classmap.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php',
'Ilabs\\BM_Woocommerce\\Controller\\Abstract_Controller' => $baseDir . '/src/Controller/Abstract_Controller.php',
'Ilabs\\BM_Woocommerce\\Controller\\Controller_Interface' => $baseDir . '/src/Controller/Controller_Interface.php',
'Ilabs\\BM_Woocommerce\\Controller\\Model\\Ajax_Response_Value_Object' => $baseDir . '/src/Controller/Model/Ajax_Response_Value_Object.php',
'Ilabs\\BM_Woocommerce\\Controller\\Model\\Payment_Status_Response_Value_Object' => $baseDir . '/src/Controller/Model/Payment_Status_Response_Value_Object.php',
'Ilabs\\BM_Woocommerce\\Controller\\Payment_Status_Controller' => $baseDir . '/src/Controller/Payment_Status_Controller.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Blue_Media\\Client' => $baseDir . '/src/Data/Remote/Blue_Media/Client.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Ga4_Dto_Interface' => $baseDir . '/src/Data/Remote/Ga4/Dto/Ga4_Dto_Interface.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Item_DTO' => $baseDir . '/src/Data/Remote/Ga4/Dto/Item_DTO.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\List_Item_DTO' => $baseDir . '/src/Data/Remote/Ga4/Dto/List_Item_DTO.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Payload_DTO' => $baseDir . '/src/Data/Remote/Ga4/Dto/Payload_DTO.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Payload_DTO_Interface' => $baseDir . '/src/Data/Remote/Ga4/Dto/Payload_DTO_Interface.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4_Service_Client' => $baseDir . '/src/Data/Remote/Ga4_Service_Client.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Config' => $baseDir . '/src/Domain/Model/White_Label/Config.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Expandable_Group' => $baseDir . '/src/Domain/Model/White_Label/Expandable_Group.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Expandable_Group_Interface' => $baseDir . '/src/Domain/Model/White_Label/Expandable_Group_Interface.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Group' => $baseDir . '/src/Domain/Model/White_Label/Group.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Item' => $baseDir . '/src/Domain/Model/White_Label/Item.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Abstract_Ga4_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/Abstract_Ga4_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Add_Product_To_Cart_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/Add_Product_To_Cart_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Click_On_Product_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/Click_On_Product_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Complete_Transation_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/Complete_Transation_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Ga4_Use_Case_Interface' => $baseDir . '/src/Domain/Service/Ga4/Ga4_Use_Case_Interface.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Init_Checkout_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/Init_Checkout_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Remove_Product_From_Cart_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/Remove_Product_From_Cart_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\View_Product_On_List_Use_Case' => $baseDir . '/src/Domain/Service/Ga4/View_Product_On_List_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\White_Label\\Group_Mapper' => $baseDir . '/src/Domain/Service/White_Label/Group_Mapper.php',
'Ilabs\\BM_Woocommerce\\Gateway\\Blue_Media_Gateway' => $baseDir . '/src/Gateway/Blue_Media_Gateway.php',
'Ilabs\\BM_Woocommerce\\Plugin' => $baseDir . '/src/Plugin.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Abstract_Ilabs_Plugin' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Abstract_Ilabs_Plugin.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Alerts' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Alerts.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Common\\Wc_Helpers' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Common/Wc_Helpers.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Environment' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Environment.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Abstracts\\Abstract_Action' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Abstracts/Abstract_Action.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Abstracts\\Abstract_Condition' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Abstracts/Abstract_Condition.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Abstracts\\Abstract_Event' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Abstracts/Abstract_Event.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Action\\Action' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Action/Action.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Action\\Copy' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Action/Copy.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Action\\Output_Template' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Action/Output_Template.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Cache' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Cache.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\Is_Admin' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/Is_Admin.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Frontend' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Frontend.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Not_Ajax' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Not_Ajax.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Product' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Product.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Shop' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Shop.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Request_Key_Exist' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Request_Key_Exist.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Request_Value_Equals' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Request_Value_Equals.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\On' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/On.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Save_Post' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Save_Post.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Save_Wc_Order_Post' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Save_Wc_Order_Post.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Add_To_Cart' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Add_To_Cart.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Checkout_Form' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Checkout_Form.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Settings' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Settings.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Shop_Loop_Item' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Shop_Loop_Item.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Single_Product' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Single_Product.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Checkout_Page' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Checkout_Page.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Checkout_Update_Order_Meta' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Checkout_Update_Order_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Filter_Price_Html' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Filter_Price_Html.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Loaded' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Loaded.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_New_Order' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_New_Order.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Order_Status_Changed' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Order_Status_Changed.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Product_Options_General_Product_Data' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Product_Options_General_Product_Data.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Product_Options_Pricing' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Product_Options_Pricing.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Product_Update' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Product_Update.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Remove_Cart_Item' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Remove_Cart_Item.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Variation_Create' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Variation_Create.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Variation_Update' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Variation_Update.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Admin_Footer' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Admin_Footer.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Admin_Init' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Admin_Init.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Ajax' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Ajax.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Cron_Every_N_Minutes' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Cron_Every_N_Minutes.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Footer' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Footer.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Init' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Init.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event_Chain' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event_Chain.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event_Chain_Item' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event_Chain_Item.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Action_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Action_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Cache_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Cache_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Condition_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Condition_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Event_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Event_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Filterable_String_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Filterable_String_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Group_Interface_Aware_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Group_Interface_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Post_Readable_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Post_Readable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Post_Writable_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Post_Writable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Readable_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Readable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Cart_Aware_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Cart_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Order_Aware_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Order_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Product_Aware_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Product_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Variation_Aware_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Variation_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wp_Post_Id_Aware_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wp_Post_Id_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Writable_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Writable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Readable\\Option' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Readable/Option.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Readable\\Readable_Post_Meta' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Readable/Readable_Post_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Writable\\Option' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Writable/Option.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Writable\\Writable_Post_Meta' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Writable/Writable_Post_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Traits\\Actions' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Traits/Actions.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Traits\\Conditions' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Traits/Conditions.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Traits\\Events' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Traits/Events.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Wc_Session_Cache' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Wc_Session_Cache.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Wp_Options_Based_Cache' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Wp_Options_Based_Cache.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Helper\\Core' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Helper/Core.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Logger_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Logger_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Null_Logger' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Null_Logger.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Wp_Debug_Logger' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Wp_Debug_Logger.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Wp_Options_Logger' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Wp_Options_Logger.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Abstract_Form_Handler' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Abstract_Form_Handler.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Abstract_Group_Walker' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Abstract_Group_Walker.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Abstract_Renderer' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Abstract_Renderer.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Ajax_Request_Group_Extractor' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Ajax_Request_Group_Extractor.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Basic_Ajax_Submit' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Basic_Ajax_Submit.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Checkbox' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Checkbox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Group' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Group.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Number' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Number.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Select' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Select.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Text' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Text.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Text_Area' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Text_Area.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form_Handler_Post_Meta' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form_Handler_Post_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form_Handler_Request' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form_Handler_Request.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form_Handler_Wp_Options' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form_Handler_Wp_Options.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Helpers' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Helpers.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Interfaces' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Interfaces.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Request_Group_Extractor' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Request_Group_Extractor.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form_Chain\\Form_Builder' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form_Chain/Form_Builder.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form_Chain\\Traits\\Fields' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form_Chain/Traits/Fields.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Ajax_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Ajax_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Checkbox_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Checkbox_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Decimal_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Decimal_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Number_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Number_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Select_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Select_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Text_Area_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Text_Area_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Text_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Text_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Form_Handler_Inteface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Form_Handler_Inteface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Group_Ajax' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Group_Ajax.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Group_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Group_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Group_Item_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Group_Item_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Event_Chain\\Actions\\Action_Wc_render_Metabox' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Event_Chain/Actions/Action_Wc_render_Metabox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Event_Chain\\Actions\\Action_Wc_render_Settings_Page' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Event_Chain/Actions/Action_Wc_render_Settings_Page.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Field' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Field.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Renderer_Wc_General_Settings' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Renderer_Wc_General_Settings.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Renderer_Wc_Post_Metabox' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Renderer_Wc_Post_Metabox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Walker_Wc_General_Settings' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Walker_Wc_General_Settings.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Walker_Wc_Post_Metabox' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Walker_Wc_Post_Metabox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Wc_General_Settings_Child' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Wc_General_Settings_Child.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Meta_Box' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Meta_Box.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Request' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Request.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Request_Filter_Interface' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Request_Filter_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Response' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Response.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Security_Request_Filter' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Security_Request_Filter.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Tools' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Tools.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Woocommerce_Logger' => $vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src/Woocommerce_Logger.php',
);

View File

@@ -0,0 +1,9 @@
<?php
// autoload_namespaces.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
);

View File

@@ -0,0 +1,11 @@
<?php
// autoload_psr4.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\' => array($vendorDir . '/isolated-ilabs-plugin/ilabs-plugin/src'),
'Ilabs\\BM_Woocommerce\\' => array($baseDir . '/src'),
);

View File

@@ -0,0 +1,36 @@
<?php
// autoload_real.php @generated by Composer
class ComposerAutoloaderInitbe41e7eddc7451a6aef49b964b1115c0
{
private static $loader;
public static function loadClassLoader($class)
{
if ('Composer\Autoload\ClassLoader' === $class) {
require __DIR__ . '/ClassLoader.php';
}
}
/**
* @return \Composer\Autoload\ClassLoader
*/
public static function getLoader()
{
if (null !== self::$loader) {
return self::$loader;
}
spl_autoload_register(array('ComposerAutoloaderInitbe41e7eddc7451a6aef49b964b1115c0', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__));
spl_autoload_unregister(array('ComposerAutoloaderInitbe41e7eddc7451a6aef49b964b1115c0', 'loadClassLoader'));
require __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInitbe41e7eddc7451a6aef49b964b1115c0::getInitializer($loader));
$loader->register(true);
return $loader;
}
}

View File

@@ -0,0 +1,193 @@
<?php
// autoload_static.php @generated by Composer
namespace Composer\Autoload;
class ComposerStaticInitbe41e7eddc7451a6aef49b964b1115c0
{
public static $prefixLengthsPsr4 = array (
'I' =>
array (
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\' => 38,
'Ilabs\\BM_Woocommerce\\' => 21,
),
);
public static $prefixDirsPsr4 = array (
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\' =>
array (
0 => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src',
),
'Ilabs\\BM_Woocommerce\\' =>
array (
0 => __DIR__ . '/../..' . '/src',
),
);
public static $classMap = array (
'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
'Ilabs\\BM_Woocommerce\\Controller\\Abstract_Controller' => __DIR__ . '/../..' . '/src/Controller/Abstract_Controller.php',
'Ilabs\\BM_Woocommerce\\Controller\\Controller_Interface' => __DIR__ . '/../..' . '/src/Controller/Controller_Interface.php',
'Ilabs\\BM_Woocommerce\\Controller\\Model\\Ajax_Response_Value_Object' => __DIR__ . '/../..' . '/src/Controller/Model/Ajax_Response_Value_Object.php',
'Ilabs\\BM_Woocommerce\\Controller\\Model\\Payment_Status_Response_Value_Object' => __DIR__ . '/../..' . '/src/Controller/Model/Payment_Status_Response_Value_Object.php',
'Ilabs\\BM_Woocommerce\\Controller\\Payment_Status_Controller' => __DIR__ . '/../..' . '/src/Controller/Payment_Status_Controller.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Blue_Media\\Client' => __DIR__ . '/../..' . '/src/Data/Remote/Blue_Media/Client.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Ga4_Dto_Interface' => __DIR__ . '/../..' . '/src/Data/Remote/Ga4/Dto/Ga4_Dto_Interface.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Item_DTO' => __DIR__ . '/../..' . '/src/Data/Remote/Ga4/Dto/Item_DTO.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\List_Item_DTO' => __DIR__ . '/../..' . '/src/Data/Remote/Ga4/Dto/List_Item_DTO.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Payload_DTO' => __DIR__ . '/../..' . '/src/Data/Remote/Ga4/Dto/Payload_DTO.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4\\Dto\\Payload_DTO_Interface' => __DIR__ . '/../..' . '/src/Data/Remote/Ga4/Dto/Payload_DTO_Interface.php',
'Ilabs\\BM_Woocommerce\\Data\\Remote\\Ga4_Service_Client' => __DIR__ . '/../..' . '/src/Data/Remote/Ga4_Service_Client.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Config' => __DIR__ . '/../..' . '/src/Domain/Model/White_Label/Config.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Expandable_Group' => __DIR__ . '/../..' . '/src/Domain/Model/White_Label/Expandable_Group.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Expandable_Group_Interface' => __DIR__ . '/../..' . '/src/Domain/Model/White_Label/Expandable_Group_Interface.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Group' => __DIR__ . '/../..' . '/src/Domain/Model/White_Label/Group.php',
'Ilabs\\BM_Woocommerce\\Domain\\Model\\White_Label\\Item' => __DIR__ . '/../..' . '/src/Domain/Model/White_Label/Item.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Abstract_Ga4_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Abstract_Ga4_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Add_Product_To_Cart_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Add_Product_To_Cart_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Click_On_Product_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Click_On_Product_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Complete_Transation_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Complete_Transation_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Ga4_Use_Case_Interface' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Ga4_Use_Case_Interface.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Init_Checkout_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Init_Checkout_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\Remove_Product_From_Cart_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/Remove_Product_From_Cart_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\Ga4\\View_Product_On_List_Use_Case' => __DIR__ . '/../..' . '/src/Domain/Service/Ga4/View_Product_On_List_Use_Case.php',
'Ilabs\\BM_Woocommerce\\Domain\\Service\\White_Label\\Group_Mapper' => __DIR__ . '/../..' . '/src/Domain/Service/White_Label/Group_Mapper.php',
'Ilabs\\BM_Woocommerce\\Gateway\\Blue_Media_Gateway' => __DIR__ . '/../..' . '/src/Gateway/Blue_Media_Gateway.php',
'Ilabs\\BM_Woocommerce\\Plugin' => __DIR__ . '/../..' . '/src/Plugin.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Abstract_Ilabs_Plugin' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Abstract_Ilabs_Plugin.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Alerts' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Alerts.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Common\\Wc_Helpers' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Common/Wc_Helpers.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Environment' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Environment.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Abstracts\\Abstract_Action' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Abstracts/Abstract_Action.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Abstracts\\Abstract_Condition' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Abstracts/Abstract_Condition.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Abstracts\\Abstract_Event' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Abstracts/Abstract_Event.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Action\\Action' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Action/Action.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Action\\Copy' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Action/Copy.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Action\\Output_Template' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Action/Output_Template.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Cache' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Cache.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\Is_Admin' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/Is_Admin.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Frontend' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Frontend.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Not_Ajax' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Not_Ajax.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Product' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Product.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Is_Shop' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Is_Shop.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Request_Key_Exist' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Request_Key_Exist.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Condition\\When_Request_Value_Equals' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Condition/When_Request_Value_Equals.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\On' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/On.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Save_Post' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Save_Post.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Save_Wc_Order_Post' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Save_Wc_Order_Post.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Add_To_Cart' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Add_To_Cart.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Checkout_Form' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Checkout_Form.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Settings' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Settings.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Shop_Loop_Item' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Shop_Loop_Item.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Before_Single_Product' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Before_Single_Product.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Checkout_Page' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Checkout_Page.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Checkout_Update_Order_Meta' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Checkout_Update_Order_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Filter_Price_Html' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Filter_Price_Html.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Loaded' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Loaded.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_New_Order' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_New_Order.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Order_Status_Changed' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Order_Status_Changed.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Product_Options_General_Product_Data' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Product_Options_General_Product_Data.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Product_Options_Pricing' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Product_Options_Pricing.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Product_Update' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Product_Update.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Remove_Cart_Item' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Remove_Cart_Item.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Variation_Create' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Variation_Create.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wc_Variation_Update' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wc_Variation_Update.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Admin_Footer' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Admin_Footer.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Admin_Init' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Admin_Init.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Ajax' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Ajax.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Cron_Every_N_Minutes' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Cron_Every_N_Minutes.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Footer' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Footer.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event\\Wp_Init' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event/Wp_Init.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event_Chain' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event_Chain.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Event_Chain_Item' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Event_Chain_Item.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Action_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Action_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Cache_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Cache_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Condition_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Condition_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Event_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Event_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Filterable_String_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Filterable_String_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Group_Interface_Aware_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Group_Interface_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Post_Readable_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Post_Readable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Post_Writable_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Post_Writable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Readable_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Readable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Cart_Aware_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Cart_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Order_Aware_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Order_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Product_Aware_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Product_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wc_Variation_Aware_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wc_Variation_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Wp_Post_Id_Aware_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Wp_Post_Id_Aware_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Interfaces\\Writable_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Interfaces/Writable_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Readable\\Option' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Readable/Option.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Readable\\Readable_Post_Meta' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Readable/Readable_Post_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Writable\\Option' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Writable/Option.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Storage\\Writable\\Writable_Post_Meta' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Storage/Writable/Writable_Post_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Traits\\Actions' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Traits/Actions.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Traits\\Conditions' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Traits/Conditions.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Traits\\Events' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Traits/Events.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Wc_Session_Cache' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Wc_Session_Cache.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Event_Chain\\Wp_Options_Based_Cache' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Event_Chain/Wp_Options_Based_Cache.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Helper\\Core' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Helper/Core.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Logger_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Logger_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Null_Logger' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Null_Logger.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Wp_Debug_Logger' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Wp_Debug_Logger.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Logger\\Wp_Options_Logger' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Logger/Wp_Options_Logger.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Abstract_Form_Handler' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Abstract_Form_Handler.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Abstract_Group_Walker' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Abstract_Group_Walker.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Abstract_Renderer' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Abstract_Renderer.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Ajax_Request_Group_Extractor' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Ajax_Request_Group_Extractor.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Basic_Ajax_Submit' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Basic_Ajax_Submit.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Checkbox' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Checkbox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Group' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Group.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Number' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Number.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Select' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Select.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Text' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Text.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Fields\\Text_Area' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Fields/Text_Area.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form_Handler_Post_Meta' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form_Handler_Post_Meta.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form_Handler_Request' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form_Handler_Request.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Form_Handler_Wp_Options' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Form_Handler_Wp_Options.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Helpers' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Helpers.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Interfaces' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Interfaces.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form\\Request_Group_Extractor' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form/Request_Group_Extractor.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form_Chain\\Form_Builder' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form_Chain/Form_Builder.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Form_Chain\\Traits\\Fields' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Form_Chain/Traits/Fields.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Ajax_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Ajax_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Checkbox_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Checkbox_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Decimal_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Decimal_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Number_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Number_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Select_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Select_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Text_Area_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Text_Area_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Field_Text_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Field_Text_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Form_Handler_Inteface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Form_Handler_Inteface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Group_Ajax' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Group_Ajax.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Group_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Group_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Interfaces\\Group_Item_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Interfaces/Group_Item_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Event_Chain\\Actions\\Action_Wc_render_Metabox' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Event_Chain/Actions/Action_Wc_render_Metabox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Event_Chain\\Actions\\Action_Wc_render_Settings_Page' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Event_Chain/Actions/Action_Wc_render_Settings_Page.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Field' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Field.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Renderer_Wc_General_Settings' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Renderer_Wc_General_Settings.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Renderer_Wc_Post_Metabox' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Renderer_Wc_Post_Metabox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Walker_Wc_General_Settings' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Walker_Wc_General_Settings.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Walker_Wc_Post_Metabox' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Walker_Wc_Post_Metabox.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Form_Chain\\Wc_General_Settings_Child' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Form_Chain/Wc_General_Settings_Child.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Presentation\\Woocommerce\\Meta_Box' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Presentation/Woocommerce/Meta_Box.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Request' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Request.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Request_Filter_Interface' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Request_Filter_Interface.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Response' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Response.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Security_Request_Filter' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Security_Request_Filter.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Tools' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Tools.php',
'Isolated\\BlueMedia\\Ilabs\\Ilabs_Plugin\\Woocommerce_Logger' => __DIR__ . '/..' . '/isolated-ilabs-plugin/ilabs-plugin/src/Woocommerce_Logger.php',
);
public static function getInitializer(ClassLoader $loader)
{
return \Closure::bind(function () use ($loader) {
$loader->prefixLengthsPsr4 = ComposerStaticInitbe41e7eddc7451a6aef49b964b1115c0::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInitbe41e7eddc7451a6aef49b964b1115c0::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInitbe41e7eddc7451a6aef49b964b1115c0::$classMap;
}, null, ClassLoader::class);
}
}

View File

@@ -0,0 +1,42 @@
{
"packages": [
{
"name": "isolated-br33f-php-ga4-mp/isolated-php-ga4-mp",
"version": "0.1.2",
"version_normalized": "0.1.2.0",
"dist": {
"type": "zip",
"url": "ilabs/setup/isolated_dependencies/isolated-php-ga4-mp-0.1.2.zip"
},
"type": "library",
"installation-source": "dist",
"install-path": "../isolated-br33f-php-ga4-mp/isolated-php-ga4-mp"
},
{
"name": "isolated-guzzlehttp-guzzle/isolated-guzzle",
"version": "7.5.1",
"version_normalized": "7.5.1.0",
"dist": {
"type": "zip",
"url": "ilabs/setup/isolated_dependencies/isolated-guzzle-7.5.1.zip"
},
"type": "library",
"installation-source": "dist",
"install-path": "../isolated-guzzlehttp-guzzle/isolated-guzzle"
},
{
"name": "isolated-ilabs-plugin/ilabs-plugin",
"version": "1.0.25",
"version_normalized": "1.0.25.0",
"dist": {
"type": "zip",
"url": "ilabs/setup/isolated_dependencies/isolated-ilabs-plugin-1.0.25.zip"
},
"type": "library",
"installation-source": "dist",
"install-path": "../isolated-ilabs-plugin/ilabs-plugin"
}
],
"dev": true,
"dev-package-names": []
}

View File

@@ -0,0 +1,50 @@
<?php return array(
'root' => array(
'name' => 'inspirelabs/bluemedia-woocommerce',
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'reference' => 'cb20002e4e888fa258ad54251d13b5c96219cd1f',
'type' => 'library',
'install_path' => __DIR__ . '/../../',
'aliases' => array(),
'dev' => true,
),
'versions' => array(
'inspirelabs/bluemedia-woocommerce' => array(
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'reference' => 'cb20002e4e888fa258ad54251d13b5c96219cd1f',
'type' => 'library',
'install_path' => __DIR__ . '/../../',
'aliases' => array(),
'dev_requirement' => false,
),
'isolated-br33f-php-ga4-mp/isolated-php-ga4-mp' => array(
'pretty_version' => '0.1.2',
'version' => '0.1.2.0',
'reference' => NULL,
'type' => 'library',
'install_path' => __DIR__ . '/../isolated-br33f-php-ga4-mp/isolated-php-ga4-mp',
'aliases' => array(),
'dev_requirement' => false,
),
'isolated-guzzlehttp-guzzle/isolated-guzzle' => array(
'pretty_version' => '7.5.1',
'version' => '7.5.1.0',
'reference' => NULL,
'type' => 'library',
'install_path' => __DIR__ . '/../isolated-guzzlehttp-guzzle/isolated-guzzle',
'aliases' => array(),
'dev_requirement' => false,
),
'isolated-ilabs-plugin/ilabs-plugin' => array(
'pretty_version' => '1.0.25',
'version' => '1.0.25.0',
'reference' => NULL,
'type' => 'library',
'install_path' => __DIR__ . '/../isolated-ilabs-plugin/ilabs-plugin',
'aliases' => array(),
'dev_requirement' => false,
),
),
);

View File

@@ -0,0 +1,25 @@
<?php
// autoload.php @generated by Composer
if (PHP_VERSION_ID < 50600) {
if (!headers_sent()) {
header('HTTP/1.1 500 Internal Server Error');
}
$err = 'Composer 2.3.0 dropped support for autoloading on PHP <5.6 and you are running '.PHP_VERSION.', please upgrade PHP or use Composer 2.2 LTS via "composer self-update --2.2". Aborting.'.PHP_EOL;
if (!ini_get('display_errors')) {
if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
fwrite(STDERR, $err);
} elseif (!headers_sent()) {
echo $err;
}
}
trigger_error(
$err,
E_USER_ERROR
);
}
require_once __DIR__ . '/composer/autoload_real.php';
return ComposerAutoloaderInit06b362e1a4e56ef1a18a29e98867cfdb::getLoader();

View File

@@ -0,0 +1,68 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 13:51
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event\AbstractEvent;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ValidateInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
use InvalidArgumentException;
class EventCollection implements ExportableInterface, ValidateInterface
{
/**
* @var AbstractEvent[]
*/
protected $eventList = [];
/**
* @param AbstractEvent $event
*/
public function addEvent(AbstractEvent $event)
{
if (\count($this->eventList) >= 25) {
throw new InvalidArgumentException('Event list must not exceed 25 items', ErrorCode::MAX_EVENT_COUNT_EXCEED);
}
$this->eventList[] = $event;
}
/**
* @return array
*/
public function export() : array
{
return \array_map(function ($userProperty) {
return $userProperty->export();
}, $this->getEventList());
}
/**
* @return array
*/
public function getEventList() : array
{
return $this->eventList;
}
/**
* @param array $eventList
*/
public function setEventList(array $eventList)
{
if (\count($eventList) > 25) {
throw new InvalidArgumentException('Event list must not exceed 25 items', ErrorCode::MAX_EVENT_COUNT_EXCEED);
}
$this->eventList = $eventList;
}
/**
* @throws ValidationException
*/
public function validate()
{
if (\count($this->getEventList()) === 0) {
throw new ValidationException('Event list must not be empty', ErrorCode::VALIDATION_EVENTS_MUST_NOT_BE_EMPTY, 'events');
}
return \true;
}
}

View File

@@ -0,0 +1,55 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 12:23
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
class UserProperties implements ExportableInterface
{
/**
* @var UserProperty[]
*/
protected $userPropertiesList;
/**
* UserProperties constructor.
* @param UserProperty[] $userPropertiesList
*/
public function __construct(array $userPropertiesList = null)
{
$this->userPropertiesList = $userPropertiesList ?? [];
}
/**
* @param UserProperty $userProperty
*/
public function addUserProperty(UserProperty $userProperty)
{
$this->userPropertiesList[] = $userProperty;
}
/**
* @return array
*/
public function export() : array
{
return \array_map(function ($userProperty) {
return $userProperty->export();
}, $this->getUserPropertiesList());
}
/**
* @return UserProperty[]
*/
public function getUserPropertiesList() : array
{
return $this->userPropertiesList;
}
/**
* @param UserProperty[] $userPropertiesList
*/
public function setUserPropertiesList(array $userPropertiesList)
{
$this->userPropertiesList = $userPropertiesList;
}
}

View File

@@ -0,0 +1,65 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 12:23
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
class UserProperty implements ExportableInterface
{
/**
* User property name
* @var string
*/
protected $name;
/**
* User property value
* @var mixed
*/
protected $value;
/**
* UserProperty constructor.
* @param string|null $name
* @param mixed $value
*/
public function __construct(?string $name = null, $value = null)
{
$this->name = $name;
$this->value = $value;
}
public function export() : array
{
return [$this->getName() => ['value' => $this->getValue()]];
}
/**
* @return string|null
*/
public function getName() : ?string
{
return $this->name;
}
/**
* @param string|null $name
*/
public function setName(?string $name)
{
$this->name = $name;
}
/**
* @return mixed
*/
public function getValue()
{
return $this->value;
}
/**
* @param mixed $value
*/
public function setValue($value)
{
$this->value = $value;
}
}

View File

@@ -0,0 +1,92 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 12:23
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\HydratableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ValidationCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
class ValidationMessage implements HydratableInterface
{
/**
* The path to the field that was invalid
* @var string|null
*/
protected $fieldPath;
/**
* A description of the error
* @var string|null
*/
protected $description;
/**
* A ValidationCode that corresponds to the error
* @var string|null
* @see ValidationCode
*/
protected $validationCode;
/**
* ValidationMessage constructor.
* @param array|null $blueprint
*/
public function __construct(?array $blueprint = null)
{
if ($blueprint !== null) {
$this->hydrate($blueprint);
}
}
/**
* @param array|ResponseInterface $blueprint
*/
public function hydrate($blueprint)
{
$this->setFieldPath(\array_key_exists('fieldPath', $blueprint) ? $blueprint['fieldPath'] : null);
$this->setDescription(\array_key_exists('description', $blueprint) ? $blueprint['description'] : null);
$this->setValidationCode(\array_key_exists('validationCode', $blueprint) ? $blueprint['validationCode'] : null);
}
/**
* @return string|null
*/
public function getFieldPath() : ?string
{
return $this->fieldPath;
}
/**
* @param string|null $fieldPath
*/
public function setFieldPath(?string $fieldPath)
{
$this->fieldPath = $fieldPath;
}
/**
* @return string|null
*/
public function getDescription() : ?string
{
return $this->description;
}
/**
* @param string|null $description
*/
public function setDescription(?string $description)
{
$this->description = $description;
}
/**
* @return string|null
*/
public function getValidationCode() : ?string
{
return $this->validationCode;
}
/**
* @param string|null $validationCode
*/
public function setValidationCode(?string $validationCode)
{
$this->validationCode = $validationCode;
}
}

View File

@@ -0,0 +1,174 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 14:16
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use BadMethodCallException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\BaseParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ValidateInterface;
use InvalidArgumentException;
abstract class AbstractEvent implements ExportableInterface, ValidateInterface
{
/**
* @var string
*/
protected $name;
/**
* @var AbstractParameter[]
*/
protected $paramList;
/**
* AbstractEvent constructor.
* @param string|null $name
* @param AbstractParameter[] $paramList
*/
public function __construct(?string $name = null, array $paramList = [])
{
$this->name = $name;
$this->paramList = $paramList ?? [];
}
/**
* @param string $methodName
* @param array $methodArguments
* @return mixed|null
*/
public function __call(string $methodName, array $methodArguments)
{
$methodPrefix = \substr($methodName, 0, 3);
$paramName = $this->convertCamelCaseToSnakeCase(\substr($methodName, 3));
if ($methodPrefix === "set") {
if (!isset($methodArguments[0])) {
throw new InvalidArgumentException('First argument is expected to be paramter value, none specified.');
}
return $this->setParamValue($paramName, $methodArguments[0]);
}
if ($methodPrefix === "get") {
return $this->getParamValue($paramName);
}
throw new BadMethodCallException('Method ' . $methodName . ' is not defined.');
}
/**
* @param string $input
* @return string
*/
protected function convertCamelCaseToSnakeCase(string $input)
{
\preg_match_all('!([A-Z][A-Z0-9]*(?=$|[A-Z][a-z0-9])|[A-Za-z][a-z0-9]+)!', $input, $matches);
$ret = $matches[0];
foreach ($ret as &$match) {
$match = $match == \strtoupper($match) ? \strtolower($match) : \lcfirst($match);
}
return \implode('_', $ret);
}
/**
* @param string $paramName
* @param mixed $paramValue
* @return AbstractEvent
*/
public function setParamValue(string $paramName, $paramValue)
{
$this->findOrCreateParameter($paramName)->setValue($paramValue);
return $this;
}
/**
* @param string $paramName
* @return AbstractParameter
*/
public function findOrCreateParameter(string $paramName)
{
$foundParameter = $this->findParameter($paramName);
if ($foundParameter === null) {
$foundParameter = new BaseParameter();
$this->addParam($paramName, $foundParameter);
}
return $foundParameter;
}
/**
* @param string $paramName
* @return AbstractParameter|null
*/
public function findParameter(string $paramName)
{
if (\array_key_exists($paramName, $this->getParamList())) {
return $this->getParamList()[$paramName];
} else {
return null;
}
}
/**
* @return AbstractParameter[]
*/
public function getParamList() : array
{
return $this->paramList;
}
/**
* @param AbstractParameter[] $paramList
*/
public function setParamList(array $paramList)
{
$this->paramList = $paramList;
}
/**
* @param string $parameterName
* @param AbstractParameter $parameter
*/
public function addParam(string $parameterName, AbstractParameter $parameter)
{
$this->paramList[$parameterName] = $parameter;
}
/**
* @param string $paramName
* @return mixed|null
*/
public function getParamValue(string $paramName)
{
return $this->findOrCreateParameter($paramName)->getValue();
}
/**
* @param string $paramName
*/
public function deleteParameter(string $paramName)
{
if (\array_key_exists($paramName, $this->getParamList())) {
unset($this->paramList[$paramName]);
}
}
public function export() : array
{
$preparedParams = [];
foreach ($this->getParamList() as $parameterName => $parameter) {
$parameterExportedValue = $parameter->export();
if (!\is_null($parameterExportedValue)) {
$preparedParams[$parameterName] = $parameterExportedValue;
}
}
return [
'name' => $this->getName(),
// Note that we need to return an \ArrayObject here. As otherwise json_encode will serialize params to `[]`. And
// Google Analytics will error on this, as it expects a map. Whereas new \ArrayObject will export correctly to `{}`.
// See https://github.com/br33f/php-GA4-Measurement-Protocol/issues/10.
'params' => new \ArrayObject($preparedParams),
];
}
/**
* @return string|null
*/
public function getName() : ?string
{
return $this->name;
}
/**
* @param string|null $name
*/
protected function setName(?string $name)
{
$this->name = $name;
}
}

View File

@@ -0,0 +1,46 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class AddPaymentInfoEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method AddPaymentInfoEvent setCurrency(string $currency)
* @method float getValue()
* @method AddPaymentInfoEvent setValue(float $value)
* @method string getCoupon()
* @method AddPaymentInfoEvent setCoupon(string $coupon)
* @method string getPaymentType()
* @method AddPaymentInfoEvent setPaymentType(string $paymentType)
*/
class AddPaymentInfoEvent extends ItemBaseEvent
{
private $eventName = 'add_payment_info';
/**
* AddPaymentInfoEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,46 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class AddShippingInfoEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method AddShippingInfoEvent setCurrency(string $currency)
* @method float getValue()
* @method AddShippingInfoEvent setValue(float $value)
* @method string getCoupon()
* @method AddShippingInfoEvent setCoupon(string $coupon)
* @method string getShippingTier()
* @method AddShippingInfoEvent setShippingTier(string $shippingTier)
*/
class AddShippingInfoEvent extends ItemBaseEvent
{
private $eventName = 'add_shipping_info';
/**
* AddShippingInfoEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,42 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class AddToCartEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method AddToCartEvent setCurrency(string $currency)
* @method float getValue()
* @method AddToCartEvent setValue(float $value)
*/
class AddToCartEvent extends ItemBaseEvent
{
private $eventName = 'add_to_cart';
/**
* AddToCartEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,31 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 13:52
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
class BaseEvent extends AbstractEvent
{
/**
* @param string|null $name
*/
public function setName(?string $name)
{
parent::setName($name);
}
/**
* @return bool
* @throws ValidationException
*/
public function validate()
{
foreach ($this->getParamList() as $parameter) {
$parameter->validate();
}
return \true;
}
}

View File

@@ -0,0 +1,44 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class AddToCartEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method BeginCheckoutEvent setCurrency(string $currency)
* @method float getValue()
* @method BeginCheckoutEvent setValue(float $value)
* @method string getCoupon()
* @method BeginCheckoutEvent setCoupon(string $coupon)
*/
class BeginCheckoutEvent extends ItemBaseEvent
{
private $eventName = 'begin_checkout';
/**
* BeginCheckoutEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,59 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:25
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\ItemCollectionParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\ItemParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class ItemBaseEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
*/
abstract class ItemBaseEvent extends AbstractEvent
{
/**
* @param ItemParameter $item
* @return self
*/
public function addItem(ItemParameter $item)
{
$this->getItems()->addItem($item);
return $this;
}
/**
* @return ItemCollectionParameter
*/
public function getItems()
{
$items = $this->findParameter('items');
if ($items === null) {
$items = new ItemCollectionParameter();
$this->setItems($items);
}
return $items;
}
/**
* @param ItemCollectionParameter|null $items
* @return self
*/
public function setItems(?ItemCollectionParameter $items)
{
$this->deleteParameter('items');
$this->addParam('items', $items);
return $this;
}
/**
* @return bool
* @throws ValidationException
*/
public function validate()
{
$this->getItems()->validate();
return \true;
}
}

View File

@@ -0,0 +1,35 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:52
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
/**
* Class LoginEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getMethod()
* @method LoginEvent setMethod(string $method)
*/
class LoginEvent extends AbstractEvent
{
private $eventName = 'login';
/**
* LoginEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
/**
* @return bool
*/
public function validate()
{
return \true;
}
}

View File

@@ -0,0 +1,55 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class PurchaseEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method PurchaseEvent setCurrency(string $currency)
* @method string getTransactionId()
* @method PurchaseEvent setTransactionId(string $transactionId)
* @method float getValue()
* @method PurchaseEvent setValue(float $value)
* @method string getAffiliation()
* @method PurchaseEvent setAffiliation(string $affiliation)
* @method string getCoupon()
* @method PurchaseEvent setCoupon(string $coupon)
* @method float getShipping()
* @method PurchaseEvent setShipping(float $shipping)
* @method float getTax()
* @method PurchaseEvent setTax(float $tax)
*/
class PurchaseEvent extends ItemBaseEvent
{
private $eventName = 'purchase';
/**
* PurchaseEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (empty($this->getTransactionId())) {
throw new ValidationException('Field "transaction_id" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'curtransaction_idrency');
}
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,55 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class RefundEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method RefundEvent setCurrency(string $currency)
* @method string getTransactionId()
* @method RefundEvent setTransactionId(string $transactionId)
* @method float getValue()
* @method RefundEvent setValue(float $value)
* @method string getAffiliation()
* @method RefundEvent setAffiliation(string $affiliation)
* @method string getCoupon()
* @method RefundEvent setCoupon(string $coupon)
* @method float getShipping()
* @method RefundEvent setShipping(float $shipping)
* @method float getTax()
* @method RefundEvent setTax(float $tax)
*/
class RefundEvent extends ItemBaseEvent
{
private $eventName = 'refund';
/**
* RefundEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (empty($this->getTransactionId())) {
throw new ValidationException('Field "transaction_id" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'curtransaction_idrency');
}
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,42 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class RemoveFromCartEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method RemoveFromCartEvent setCurrency(string $currency)
* @method float getValue()
* @method RemoveFromCartEvent setValue(float $value)
*/
class RemoveFromCartEvent extends ItemBaseEvent
{
private $eventName = 'remove_from_cart';
/**
* AddToCartEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,41 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:52
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class SearchEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getSearchTerm()
* @method SearchEvent setSearchTerm(string $searchTerm)
*/
class SearchEvent extends AbstractEvent
{
private $eventName = 'search';
/**
* SearchEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
/**
* @return bool
* @throws ValidationException
*/
public function validate()
{
if (empty($this->getSearchTerm())) {
throw new ValidationException('Field "search_term" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'search_term');
}
return \true;
}
}

View File

@@ -0,0 +1,30 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
/**
* Class SelectItemEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getItemListId()
* @method SelectItemEvent setItemListId(string $itemListId)
* @method string getItemListName()
* @method SelectItemEvent setItemListName(string $itemListName)
*/
class SelectItemEvent extends ItemBaseEvent
{
private $eventName = 'select_item';
/**
* SelectItemEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
}

View File

@@ -0,0 +1,35 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:52
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
/**
* Class SignUpEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getMethod()
* @method SignUpEvent setMethod(string $method)
*/
class SignUpEvent extends AbstractEvent
{
private $eventName = 'sign_up';
/**
* SignUpEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
/**
* @return bool
*/
public function validate()
{
return \true;
}
}

View File

@@ -0,0 +1,42 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class ViewCartEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method ViewCartEvent setCurrency(string $currency)
* @method float getValue()
* @method ViewCartEvent setValue(float $value)
*/
class ViewCartEvent extends ItemBaseEvent
{
private $eventName = 'view_cart';
/**
* ViewCartEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
public function validate()
{
parent::validate();
if (!empty($this->getValue())) {
if (empty($this->getCurrency())) {
throw new ValidationException('Field "currency" is required if "value" is set', ErrorCode::VALIDATION_FIELD_REQUIRED, 'currency');
}
}
return \true;
}
}

View File

@@ -0,0 +1,30 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 24.06.2021
* Time: 15:22
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
/**
* Class ViewItemEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getCurrency()
* @method ViewItemEvent setCurrency(string $currency)
* @method string getValue()
* @method ViewItemEvent setValue(string $value)
*/
class ViewItemEvent extends ItemBaseEvent
{
private $eventName = 'view_item';
/**
* ViewItemEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
}

View File

@@ -0,0 +1,30 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
/**
* Class ViewItemListEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getItemListId()
* @method ViewItemListEvent setItemListId(string $itemListId)
* @method string getItemListName()
* @method ViewItemListEvent setItemListName(string $itemListName)
*/
class ViewItemListEvent extends ItemBaseEvent
{
private $eventName = 'view_item_list';
/**
* ViewItemListEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
}

View File

@@ -0,0 +1,28 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 25.06.2021
* Time: 13:33
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter\AbstractParameter;
/**
* Class ViewSearchResultsEvent
* @package Br33f\Ga4\MeasurementProtocol\Dto\Event
* @method string getSearchTerm()
* @method ViewSearchResultsEvent setSearchTerm(string $itemListId)
*/
class ViewSearchResultsEvent extends ItemBaseEvent
{
private $eventName = 'view_search_results';
/**
* ViewSearchResultsEvent constructor.
* @param AbstractParameter[] $paramList
*/
public function __construct(array $paramList = [])
{
parent::__construct($this->eventName, $paramList);
}
}

View File

@@ -0,0 +1,17 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:10
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto;
interface ExportableInterface
{
/**
* Method returns prepared data
* @return mixed
*/
public function export();
}

View File

@@ -0,0 +1,20 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 13:42
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\HydrationException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
interface HydratableInterface
{
/**
* Method hydrates DTO with data from blueprint
* @param ResponseInterface|array $blueprint
* @throws HydrationException
*/
public function hydrate($blueprint);
}

View File

@@ -0,0 +1,14 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 13:56
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ValidateInterface;
abstract class AbstractParameter implements ExportableInterface, ValidateInterface
{
}

View File

@@ -0,0 +1,57 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 13:56
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
class BaseParameter extends AbstractParameter
{
/**
* @var mixed
*/
protected $value;
/**
* BaseParameter constructor.
* @param mixed|null $value
*/
public function __construct($value = null)
{
$this->value = $value;
}
/**
* @return mixed
*/
public function export()
{
if ($this->getValue() instanceof ExportableInterface) {
return $this->getValue()->export();
} else {
return $this->getValue();
}
}
/**
* @return mixed
*/
public function getValue()
{
return $this->value;
}
/**
* @param mixed $value
*/
public function setValue($value)
{
$this->value = $value;
}
/**
* @return bool
*/
public function validate()
{
return \true;
}
}

View File

@@ -0,0 +1,76 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 24.06.2021
* Time: 15:40
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class ItemCollectionParameter
* @package Br33f\Ga4\MeasurementProtocol\Dto\Parameter
*/
class ItemCollectionParameter extends AbstractParameter
{
/**
* @var ItemParameter[]
*/
protected $itemList;
/**
* ItemCollectionParameter constructor.
* @param ItemParameter[]|null $itemList
*/
public function __construct(?array $itemList = [])
{
$this->itemList = $itemList;
}
/**
* @param ItemParameter $item
* @return ItemCollectionParameter
*/
public function addItem(ItemParameter $item)
{
$this->itemList[] = $item;
return $this;
}
/**
* @return bool
* @throws ValidationException
*/
public function validate()
{
foreach ($this->getItemList() as $item) {
$item->validate();
}
return \true;
}
/**
* @return ItemParameter[]
*/
public function getItemList() : array
{
return $this->itemList;
}
/**
* @param ItemParameter[] $itemList
* @return ItemCollectionParameter
*/
public function setItemList(array $itemList)
{
$this->itemList = $itemList;
return $this;
}
/**
* @return array
*/
public function export()
{
$exportableObject = [];
foreach ($this->getItemList() as $item) {
$exportableObject[] = $item->export();
}
return $exportableObject;
}
}

View File

@@ -0,0 +1,540 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 24.06.2021
* Time: 15:40
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Parameter;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\HydratableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
/**
* Class ItemParameter
* @package Br33f\Ga4\MeasurementProtocol\Dto\Parameter
*/
class ItemParameter extends AbstractParameter implements HydratableInterface
{
/**
* The ID of the item
* One of itemId or itemName is required.
* @var string|null
*/
protected $itemId;
/**
* The name of the item
* One of itemId or itemName is required.
* @var string|null
*/
protected $itemName;
/**
* A product affiliation to designate a supplying company or brick and mortar store location
* Not required
* @var string|null
*/
protected $affiliation;
/**
* The coupon name/code associated with the item
* Not required
* @var string|null
*/
protected $coupon;
/**
* The currency in 3-lettery ISO 4217 format
* Not required
* @var string|null
*/
protected $currency;
/**
* The monetary discount value associated with the item
* Not required
* @var float|null
*/
protected $discount;
/**
* The index/position of the item in a list
* Not required
* @var float|null
*/
protected $index;
/**
* The brand of the item
* Not required
* @var string|null
*/
protected $itemBrand;
/**
* The category of the item.
* If used as part of a category hierarchy or taxonomy then this will be the first category.
* Not required
* @var string|null
*/
protected $itemCategory;
/**
* The second category of the item.
* If used as part of a category hierarchy or taxonomy then this will be the first category.
* Not required
* @var string|null
*/
protected $itemCategory2;
/**
* The third category of the item.
* If used as part of a category hierarchy or taxonomy then this will be the first category.
* Not required
* @var string|null
*/
protected $itemCategory3;
/**
* The fourth category of the item.
* If used as part of a category hierarchy or taxonomy then this will be the first category.
* Not required
* @var string|null
*/
protected $itemCategory4;
/**
* The fifth category of the item.
* If used as part of a category hierarchy or taxonomy then this will be the first category.
* Not required
* @var string|null
*/
protected $itemCategory5;
/**
* The ID of the list in which the item was presented to the user
* Not required
* @var string|null
*/
protected $itemListId;
/**
* The name of the list in which the item was presented to the user
* Not required
* @var string|null
*/
protected $itemListName;
/**
* The item variant or unique code or description for additional item details/options.
* Not required
* @var string|null
*/
protected $itemVariant;
/**
* The location associated with the item. It's recommended to use the Google Place ID that corresponds to the associated item. A custom location ID can also be used
* Not required
* @var string|null
*/
protected $locationId;
/**
* The monetary price of the item, in units of the specified currency parameter
* Not required
* @var float|null
*/
protected $price;
/**
* Item quantity
* Not required
* @var float|null
*/
protected $quantity;
/**
* ItemParameter constructor.
* @param array|null $blueprint
*/
public function __construct(?array $blueprint = null)
{
if ($blueprint !== null) {
$this->hydrate($blueprint);
}
}
/**
* @param array $blueprint
*/
public function hydrate($blueprint)
{
if (\array_key_exists('item_id', $blueprint)) {
$this->setItemId($blueprint['item_id']);
}
if (\array_key_exists('item_name', $blueprint)) {
$this->setItemName($blueprint['item_name']);
}
if (\array_key_exists('affiliation', $blueprint)) {
$this->setAffiliation($blueprint['affiliation']);
}
if (\array_key_exists('coupon', $blueprint)) {
$this->setCoupon($blueprint['coupon']);
}
if (\array_key_exists('currency', $blueprint)) {
$this->setCurrency($blueprint['currency']);
}
if (\array_key_exists('discount', $blueprint)) {
$this->setDiscount($blueprint['discount']);
}
if (\array_key_exists('index', $blueprint)) {
$this->setIndex($blueprint['index']);
}
if (\array_key_exists('item_brand', $blueprint)) {
$this->setItemBrand($blueprint['item_brand']);
}
if (\array_key_exists('item_category', $blueprint)) {
$this->setItemCategory($blueprint['item_category']);
}
if (\array_key_exists('item_category2', $blueprint)) {
$this->setItemCategory2($blueprint['item_category2']);
}
if (\array_key_exists('item_category3', $blueprint)) {
$this->setItemCategory3($blueprint['item_category3']);
}
if (\array_key_exists('item_category4', $blueprint)) {
$this->setItemCategory4($blueprint['item_category4']);
}
if (\array_key_exists('item_category5', $blueprint)) {
$this->setItemCategory5($blueprint['item_category5']);
}
if (\array_key_exists('item_list_id', $blueprint)) {
$this->setItemListId($blueprint['item_list_id']);
}
if (\array_key_exists('item_list_name', $blueprint)) {
$this->setItemListName($blueprint['item_list_name']);
}
if (\array_key_exists('item_variant', $blueprint)) {
$this->setItemVariant($blueprint['item_variant']);
}
if (\array_key_exists('location_id', $blueprint)) {
$this->setLocationId($blueprint['location_id']);
}
if (\array_key_exists('price', $blueprint)) {
$this->setPrice($blueprint['price']);
}
if (\array_key_exists('quantity', $blueprint)) {
$this->setQuantity($blueprint['quantity']);
}
}
/**
* @return bool
* @throws ValidationException
*/
public function validate()
{
if (empty($this->getItemId()) && empty($this->getItemName())) {
throw new ValidationException("At least one of item_id or item_name is required", ErrorCode::VALIDATION_ITEM_AT_LEAST_ITEM_ID_OR_ITEM_NAME_REQUIRED, 'item_id|item_name');
}
return \true;
}
/**
* @return string|null
*/
public function getItemId() : ?string
{
return $this->itemId;
}
/**
* @param string|null $itemId
* @return ItemParameter
*/
public function setItemId(?string $itemId) : ItemParameter
{
$this->itemId = $itemId;
return $this;
}
/**
* @return string|null
*/
public function getItemName() : ?string
{
return $this->itemName;
}
/**
* @param string|null $itemName
* @return ItemParameter
*/
public function setItemName(?string $itemName) : ItemParameter
{
$this->itemName = $itemName;
return $this;
}
/**
* @return array
*/
public function export()
{
$exportableObject = ['item_id' => $this->getItemId(), 'item_name' => $this->getItemName(), 'affiliation' => $this->getAffiliation(), 'coupon' => $this->getCoupon(), 'currency' => $this->getCurrency(), 'discount' => $this->getDiscount(), 'index' => $this->getIndex(), 'item_brand' => $this->getItemBrand(), 'item_category' => $this->getItemCategory(), 'item_category2' => $this->getItemCategory2(), 'item_category3' => $this->getItemCategory3(), 'item_category4' => $this->getItemCategory4(), 'item_category5' => $this->getItemCategory5(), 'item_list_id' => $this->getItemListId(), 'item_list_name' => $this->getItemListName(), 'item_variant' => $this->getItemVariant(), 'location_id' => $this->getLocationId(), 'price' => $this->getPrice(), 'quantity' => $this->getQuantity()];
$preparedExportableObject = [];
foreach ($exportableObject as $exportableItemName => $exportableItemValue) {
if (!\is_null($exportableItemValue)) {
$preparedExportableObject[$exportableItemName] = $exportableItemValue;
}
}
return $preparedExportableObject;
}
/**
* @return string|null
*/
public function getAffiliation() : ?string
{
return $this->affiliation;
}
/**
* @param string|null $affiliation
* @return ItemParameter
*/
public function setAffiliation(?string $affiliation) : ItemParameter
{
$this->affiliation = $affiliation;
return $this;
}
/**
* @return string|null
*/
public function getCoupon() : ?string
{
return $this->coupon;
}
/**
* @param string|null $coupon
* @return ItemParameter
*/
public function setCoupon(?string $coupon) : ItemParameter
{
$this->coupon = $coupon;
return $this;
}
/**
* @return string|null
*/
public function getCurrency() : ?string
{
return $this->currency;
}
/**
* @param string|null $currency
* @return ItemParameter
*/
public function setCurrency(?string $currency) : ItemParameter
{
$this->currency = $currency;
return $this;
}
/**
* @return float|null
*/
public function getDiscount() : ?float
{
return $this->discount;
}
/**
* @param float|null $discount
* @return ItemParameter
*/
public function setDiscount(?float $discount) : ItemParameter
{
$this->discount = $discount;
return $this;
}
/**
* @return float|null
*/
public function getIndex() : ?float
{
return $this->index;
}
/**
* @param float|null $index
* @return ItemParameter
*/
public function setIndex(?float $index) : ItemParameter
{
$this->index = $index;
return $this;
}
/**
* @return string|null
*/
public function getItemBrand() : ?string
{
return $this->itemBrand;
}
/**
* @param string|null $itemBrand
* @return ItemParameter
*/
public function setItemBrand(?string $itemBrand) : ItemParameter
{
$this->itemBrand = $itemBrand;
return $this;
}
/**
* @return string|null
*/
public function getItemCategory() : ?string
{
return $this->itemCategory;
}
/**
* @param string|null $itemCategory
* @return ItemParameter
*/
public function setItemCategory(?string $itemCategory) : ItemParameter
{
$this->itemCategory = $itemCategory;
return $this;
}
/**
* @return string|null
*/
public function getItemCategory2() : ?string
{
return $this->itemCategory2;
}
/**
* @param string|null $itemCategory2
* @return ItemParameter
*/
public function setItemCategory2(?string $itemCategory2) : ItemParameter
{
$this->itemCategory2 = $itemCategory2;
return $this;
}
/**
* @return string|null
*/
public function getItemCategory3() : ?string
{
return $this->itemCategory3;
}
/**
* @param string|null $itemCategory3
* @return ItemParameter
*/
public function setItemCategory3(?string $itemCategory3) : ItemParameter
{
$this->itemCategory3 = $itemCategory3;
return $this;
}
/**
* @return string|null
*/
public function getItemCategory4() : ?string
{
return $this->itemCategory4;
}
/**
* @param string|null $itemCategory4
* @return ItemParameter
*/
public function setItemCategory4(?string $itemCategory4) : ItemParameter
{
$this->itemCategory4 = $itemCategory4;
return $this;
}
/**
* @return string|null
*/
public function getItemCategory5() : ?string
{
return $this->itemCategory5;
}
/**
* @param string|null $itemCategory5
* @return ItemParameter
*/
public function setItemCategory5(?string $itemCategory5) : ItemParameter
{
$this->itemCategory5 = $itemCategory5;
return $this;
}
/**
* @return string|null
*/
public function getItemListId() : ?string
{
return $this->itemListId;
}
/**
* @param string|null $itemListId
* @return ItemParameter
*/
public function setItemListId(?string $itemListId) : ItemParameter
{
$this->itemListId = $itemListId;
return $this;
}
/**
* @return string|null
*/
public function getItemListName() : ?string
{
return $this->itemListName;
}
/**
* @param string|null $itemListName
* @return ItemParameter
*/
public function setItemListName(?string $itemListName) : ItemParameter
{
$this->itemListName = $itemListName;
return $this;
}
/**
* @return string|null
*/
public function getItemVariant() : ?string
{
return $this->itemVariant;
}
/**
* @param string|null $itemVariant
* @return ItemParameter
*/
public function setItemVariant(?string $itemVariant) : ItemParameter
{
$this->itemVariant = $itemVariant;
return $this;
}
/**
* @return string|null
*/
public function getLocationId() : ?string
{
return $this->locationId;
}
/**
* @param string|null $locationId
* @return ItemParameter
*/
public function setLocationId(?string $locationId) : ItemParameter
{
$this->locationId = $locationId;
return $this;
}
/**
* @return float|null
*/
public function getPrice() : ?float
{
return $this->price;
}
/**
* @param float|null $price
* @return ItemParameter
*/
public function setPrice(?float $price) : ItemParameter
{
$this->price = $price;
return $this;
}
/**
* @return float|null
*/
public function getQuantity() : ?float
{
return $this->quantity;
}
/**
* @param float|null $quantity
* @return ItemParameter
*/
public function setQuantity(?float $quantity) : ItemParameter
{
$this->quantity = $quantity;
return $this;
}
}

View File

@@ -0,0 +1,14 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:10
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Request;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ExportableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\ValidateInterface;
abstract class AbstractRequest implements ExportableInterface, ValidateInterface
{
}

View File

@@ -0,0 +1,221 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:22
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Request;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common\EventCollection;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common\UserProperties;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common\UserProperty;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Event\AbstractEvent;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum\ErrorCode;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
class BaseRequest extends AbstractRequest
{
/**
* Unique identifier of user instance.
* Required
* @var string
*/
protected $clientId;
/**
* Unique identifier for a user.
* Not required
* @var string
*/
protected $userId;
/**
* An unix timestamp (microseconds) for the time to associate with the event.
* Not requied
* @var int
*/
protected $timestampMicros = null;
/**
* The user properties for the measurement.
* Not required
* @var UserProperties
*/
protected $userProperties = null;
/**
* If set true - indicates that events should not be use for personalized ads.
* Default false
* @var bool
*/
protected $nonPersonalizedAds = \false;
/**
* Collection of event items. Maximum 25 events.
* Required
* @var EventCollection
*/
protected $events;
/**
* BaseRequest constructor.
* @param string|null $clientId
* @param AbstractEvent|EventCollection|null $events - Single Event or EventsCollection
*/
public function __construct(?string $clientId = null, $events = null)
{
$this->clientId = $clientId ?? '';
if ($events !== null) {
if ($events instanceof EventCollection) {
$this->events = $events;
} else {
if ($events instanceof AbstractEvent) {
$this->events = new EventCollection();
$this->events->addEvent($events);
}
}
} else {
$this->events = new EventCollection();
}
}
/**
* @param UserProperty $userProperty
* @return BaseRequest
*/
public function addUserProperty(UserProperty $userProperty)
{
if ($this->getUserProperties() === null) {
$this->setUserProperties(new UserProperties());
}
$this->getUserProperties()->addUserProperty($userProperty);
return $this;
}
/**
* @return UserProperties|null
*/
public function getUserProperties() : ?UserProperties
{
return $this->userProperties;
}
/**
* @param UserProperties|null $userProperties
* @return BaseRequest
*/
public function setUserProperties(?UserProperties $userProperties)
{
$this->userProperties = $userProperties;
return $this;
}
/**
* @param AbstractEvent $event
* @return BaseRequest
*/
public function addEvent(AbstractEvent $event)
{
$this->getEvents()->addEvent($event);
return $this;
}
/**
* @return EventCollection
*/
public function getEvents() : EventCollection
{
return $this->events;
}
/**
* @param EventCollection $events
* @return BaseRequest
*/
public function setEvents(EventCollection $events)
{
$this->events = $events;
return $this;
}
/**
* @return array
*/
public function export() : array
{
$exportBaseRequest = ['client_id' => $this->getClientId(), 'non_personalized_ads' => $this->isNonPersonalizedAds(), 'events' => $this->getEvents()->export()];
if ($this->getUserId() !== null) {
$exportBaseRequest['user_id'] = $this->getUserId();
}
if ($this->getTimestampMicros() !== null) {
$exportBaseRequest['timestamp_micros'] = $this->getTimestampMicros();
}
if ($this->getUserProperties() !== null) {
$exportBaseRequest['user_properties'] = $this->getUserProperties()->export();
}
return $exportBaseRequest;
}
/**
* @return string
*/
public function getClientId() : string
{
return $this->clientId;
}
/**
* @param string $clientId
* @return BaseRequest
*/
public function setClientId(string $clientId)
{
$this->clientId = $clientId;
return $this;
}
/**
* @return bool
*/
public function isNonPersonalizedAds() : bool
{
return $this->nonPersonalizedAds;
}
/**
* @param bool $nonPersonalizedAds
* @return BaseRequest
*/
public function setNonPersonalizedAds(bool $nonPersonalizedAds)
{
$this->nonPersonalizedAds = $nonPersonalizedAds;
return $this;
}
/**
* @return string|null
*/
public function getUserId() : ?string
{
return $this->userId;
}
/**
* @param string|null $userId
* @return BaseRequest
*/
public function setUserId(?string $userId)
{
$this->userId = $userId;
return $this;
}
/**
* @return ?int
*/
public function getTimestampMicros() : ?int
{
return $this->timestampMicros;
}
/**
* @param ?int $timestampMicros
* @return BaseRequest
*/
public function setTimestampMicros(?int $timestampMicros)
{
$this->timestampMicros = $timestampMicros;
return $this;
}
/**
* @return bool
* @throws ValidationException
*/
public function validate()
{
if (empty($this->getClientId())) {
throw new ValidationException('Parameter "client_id" is required.', ErrorCode::VALIDATION_CLIENT_ID_REQUIRED, 'client_id');
}
$this->getEvents()->validate();
return \true;
}
}

View File

@@ -0,0 +1,26 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:10
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Response;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\HydratableInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\HydrationException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
abstract class AbstractResponse implements HydratableInterface
{
/**
* AbstractResponse constructor.
* @param ResponseInterface|null $blueprint
* @throws HydrationException
*/
public function __construct(ResponseInterface $blueprint = null)
{
if ($blueprint !== null) {
$this->hydrate($blueprint);
}
}
}

View File

@@ -0,0 +1,69 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:10
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Response;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
class BaseResponse extends AbstractResponse
{
/**
* @var int|null
*/
protected $statusCode;
/**
* @var string
*/
protected $body;
/**
* @return int|null
*/
public function getStatusCode() : ?int
{
return $this->statusCode;
}
/**
* @param int|null $statusCode
* @return BaseResponse
*/
public function setStatusCode(?int $statusCode)
{
$this->statusCode = $statusCode;
return $this;
}
/**
* Get parsed body
* @return array
*/
public function getData()
{
return \json_decode($this->getBody(), \true);
}
/**
* @return string
*/
public function getBody() : string
{
return $this->body;
}
/**
* @param string $body
* @return BaseResponse
*/
public function setBody(string $body)
{
$this->body = $body;
return $this;
}
/**
* @param array|ResponseInterface $blueprint
*/
public function hydrate($blueprint)
{
$this->setStatusCode($blueprint->getStatusCode());
$this->setBody($blueprint->getBody()->getContents());
}
}

View File

@@ -0,0 +1,46 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:10
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Response;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Common\ValidationMessage;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
class DebugResponse extends BaseResponse
{
/**
* @var ValidationMessage[]
*/
protected $validationMessages = [];
/**
* @return ValidationMessage[]
*/
public function getValidationMessages() : array
{
return $this->validationMessages;
}
/**
* @param ValidationMessage[] $validationMessages
* @return DebugResponse
*/
public function setValidationMessages(array $validationMessages)
{
$this->validationMessages = $validationMessages;
return $this;
}
/**
* @param array|ResponseInterface $blueprint
*/
public function hydrate($blueprint)
{
parent::hydrate($blueprint);
$validationMessages = [];
foreach ($this->getData()['validationMessages'] as $validationMessage) {
$validationMessages[] = new ValidationMessage($validationMessage);
}
$this->setValidationMessages($validationMessages);
}
}

View File

@@ -0,0 +1,19 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:10
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception\ValidationException;
interface ValidateInterface
{
/**
* Method validates object. Throws exception if error, returns true if valid.
* @return boolean
* @throws ValidationException
*/
public function validate();
}

View File

@@ -0,0 +1,17 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 15:29
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum;
class ErrorCode
{
const MAX_EVENT_COUNT_EXCEED = 100001;
const VALIDATION_CLIENT_ID_REQUIRED = 1000002;
const VALIDATION_EVENTS_MUST_NOT_BE_EMPTY = 1000003;
const VALIDATION_ITEM_AT_LEAST_ITEM_ID_OR_ITEM_NAME_REQUIRED = 1000004;
const VALIDATION_FIELD_REQUIRED = 1000005;
}

View File

@@ -0,0 +1,19 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 24.06.2021
* Time: 13:49
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Enum;
class ValidationCode
{
const VALUE_INVALID = 'VALUE_INVALID';
const VALUE_REQUIRED = 'VALUE_REQUIRED';
const NAME_INVALID = 'NAME_INVALID';
const NAME_RESERVED = 'NAME_RESERVED';
const VALUE_OUT_OF_BOUNDS = 'VALUE_OUT_OF_BOUNDS';
const EXCEEDED_MAX_ENTITIES = 'EXCEEDED_MAX_ENTITIES';
const NAME_DUPLICATED = 'NAME_DUPLICATED';
}

View File

@@ -0,0 +1,13 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:20
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception;
use Exception;
class HydrationException extends Exception
{
}

View File

@@ -0,0 +1,37 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 11:20
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Exception;
use Exception;
use Throwable;
class ValidationException extends Exception
{
/**
* @var string|null
*/
protected $fieldName = null;
public function __construct($message = "", $code = 0, $fieldName = null, Throwable $previous = null)
{
parent::__construct($message, $code, $previous);
$this->fieldName = $fieldName;
}
/**
* @return string|null
*/
public function getFieldName() : ?string
{
return $this->fieldName;
}
/**
* @param string|null $fieldName
*/
public function setFieldName(?string $fieldName) : void
{
$this->fieldName = $fieldName;
}
}

View File

@@ -0,0 +1,72 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 22.06.2021
* Time: 10:35
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Client;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\BadResponseException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\RequestOptions;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
class HttpClient
{
const DEFAULT_REQUEST_TIMEOUT = 30;
/**
* Guzzle Client
* @var Client
*/
protected $client;
/**
* Sends request to Google Analytics.
*
* @param string $url
* @param array $data
* @param array|null $options
* @return ResponseInterface
*/
public function post(string $url, array $data, ?array $options = [])
{
try {
return $this->getClient()->post($url, $this->getPreparedOptions($options, $data));
} catch (BadResponseException $e) {
return $e->getResponse();
}
}
/**
* Returns guzzle client if set or creates a new instance and returns it
* @return Client
*/
public function getClient() : Client
{
if ($this->client === null) {
$this->client = new Client();
}
return $this->client;
}
/**
* @param Client $client
*/
public function setClient(Client $client)
{
$this->client = $client;
}
/**
* @param $options
* @param $data
* @return array
*/
protected function getPreparedOptions($options, $data)
{
$options[RequestOptions::JSON] = $data;
if (!isset($options['timeout'])) {
$options['timeout'] = self::DEFAULT_REQUEST_TIMEOUT;
}
if (!isset($options['connect_timeout'])) {
$options['connect_timeout'] = self::DEFAULT_REQUEST_TIMEOUT;
}
return $options;
}
}

View File

@@ -0,0 +1,254 @@
<?php
/**
* User: Damian Zamojski (br33f)
* Date: 21.06.2021
* Time: 16:15
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Request\AbstractRequest;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Response\BaseResponse;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Br33f\Ga4\MeasurementProtocol\Dto\Response\DebugResponse;
class Service
{
const SSL_SCHEME = 'https://';
const NOT_SSL_SCHEME = 'http://';
const PREPENDED_WWW = 'www';
/**
* Indicates if connection to endpoint should be made with HTTPS (true) or HTTP (false)
* @var bool
*/
protected $useSsl = \true;
/**
* Indicates if connection to endpoint should be made with prepended WWW
* @var bool
*/
protected $useWww = \false;
/**
* Collect Endpoint
* @var string
*/
protected $collectEndpoint = 'google-analytics.com/mp/collect';
/**
* Collect Debug Endpoint. Used for validating events.
* @var string
*/
protected $collectDebugEndpoint = 'google-analytics.com/debug/mp/collect';
/**
* Http Client
* @var HttpClient
*/
protected $httpClient;
/**
* An API SECRET generated in the Google Analytics UI
* @var string
*/
protected $apiSecret;
/**
* The measurement ID associated with a data stream
* @var string
*/
protected $measurementId;
/**
* The custom ip address of the visitor
* @var string
*/
protected $ipOverride;
/**
* Http Options
* @var array
*/
protected $options;
/**
* Client constructor.
* @param string $apiSecret
* @param string $measurementId
*/
public function __construct(string $apiSecret, string $measurementId)
{
$this->setApiSecret($apiSecret);
$this->setMeasurementId($measurementId);
}
/**
* @param AbstractRequest $request
* @return BaseResponse
* @throws Exception\ValidationException
* @throws Exception\HydrationException
*/
public function send(AbstractRequest $request)
{
$request->validate();
$response = $this->getHttpClient()->post($this->getEndpoint(), $request->export(), $this->getOptions());
return new BaseResponse($response);
}
/**
* Returns Http Client if set or creates a new instance and returns it
* @return HttpClient
*/
public function getHttpClient() : HttpClient
{
if ($this->httpClient === null) {
$this->httpClient = new HttpClient();
}
return $this->httpClient;
}
/**
* @param HttpClient $httpClient
*/
public function setHttpClient(HttpClient $httpClient)
{
$this->httpClient = $httpClient;
}
/**
* Returns prepared endpoint url
* @return string
*/
public function getEndpoint(?bool $isDebug = \false) : string
{
$protocolScheme = $this->isUseSsl() ? self::SSL_SCHEME : self::NOT_SSL_SCHEME;
$collectEndpoint = $isDebug ? $this->getCollectDebugEndpoint() : $this->getCollectEndpoint();
$prependedWww = $this->isUseWww() ? self::PREPENDED_WWW . '.' : '';
return $protocolScheme . $prependedWww . $collectEndpoint . "?" . \http_build_query($this->getQueryParameters());
}
/**
* @return bool
*/
public function isUseSsl() : bool
{
return $this->useSsl;
}
/**
* @param bool $useSsl
*/
public function setUseSsl(bool $useSsl)
{
$this->useSsl = $useSsl;
}
/**
* @return bool
*/
public function isUseWww() : bool
{
return $this->useWww;
}
/**
* @param bool $useWww
*/
public function setUseWww(bool $useWww)
{
$this->useWww = $useWww;
}
/**
* @return string
*/
public function getCollectDebugEndpoint() : string
{
return $this->collectDebugEndpoint;
}
/**
* @param string $collectDebugEndpoint
*/
public function setCollectDebugEndpoint(string $collectDebugEndpoint)
{
$this->collectDebugEndpoint = $collectDebugEndpoint;
}
/**
* @return string
*/
public function getCollectEndpoint() : string
{
return $this->collectEndpoint;
}
/**
* @param string $collectEndpoint
*/
public function setCollectEndpoint(string $collectEndpoint)
{
$this->collectEndpoint = $collectEndpoint;
}
/**
* Returns query parameters
* @return array
*/
public function getQueryParameters() : array
{
$parameters = ['measurement_id' => $this->getMeasurementId(), 'api_secret' => $this->getApiSecret()];
$ip = $this->getIpOverride();
if (!empty($ip)) {
$parameters['uip'] = $ip;
// TODO Remove the following line when the GA4 API will support the IP override
// https://github.com/dataunlocker/save-analytics-from-content-blockers/issues/25#issuecomment-864392422
$parameters['_uip'] = $ip;
}
return $parameters;
}
/**
* @return string
*/
public function getMeasurementId() : string
{
return $this->measurementId;
}
/**
* @param string $measurementId
*/
public function setMeasurementId(string $measurementId)
{
$this->measurementId = $measurementId;
}
/**
* @return string
*/
public function getApiSecret() : string
{
return $this->apiSecret;
}
/**
* @param string $apiSecret
*/
public function setApiSecret(string $apiSecret)
{
$this->apiSecret = $apiSecret;
}
/**
* @return string
*/
public function getIpOverride() : ?string
{
return $this->ipOverride;
}
/**
* @param string $ipOverride
*/
public function setIpOverride(string $ipOverride)
{
$this->ipOverride = $ipOverride;
}
/**
* @return array|null
*/
public function getOptions() : ?array
{
return $this->options;
}
/**
* @param array|null $options
*/
public function setOptions(?array $options)
{
$this->options = $options;
}
/**
* @param AbstractRequest $request
* @return BaseResponse
* @throws Exception\ValidationException
* @throws Exception\HydrationException
*/
public function sendDebug(AbstractRequest $request)
{
$request->validate();
$response = $this->getHttpClient()->post($this->getEndpoint(\true), $request->export(), $this->getOptions());
return new DebugResponse($response);
}
}

View File

@@ -0,0 +1,585 @@
<?php
/*
* This file is part of Composer.
*
* (c) Nils Adermann <naderman@naderman.de>
* Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Composer\Autoload;
/**
* ClassLoader implements a PSR-0, PSR-4 and classmap class loader.
*
* $loader = new \Composer\Autoload\ClassLoader();
*
* // register classes with namespaces
* $loader->add('Symfony\Component', __DIR__.'/component');
* $loader->add('Symfony', __DIR__.'/framework');
*
* // activate the autoloader
* $loader->register();
*
* // to enable searching the include path (eg. for PEAR packages)
* $loader->setUseIncludePath(true);
*
* In this example, if you try to use a class in the Symfony\Component
* namespace or one of its children (Symfony\Component\Console for instance),
* the autoloader will first look for the class under the component/
* directory, and it will then fallback to the framework/ directory if not
* found before giving up.
*
* This class is loosely based on the Symfony UniversalClassLoader.
*
* @author Fabien Potencier <fabien@symfony.com>
* @author Jordi Boggiano <j.boggiano@seld.be>
* @see https://www.php-fig.org/psr/psr-0/
* @see https://www.php-fig.org/psr/psr-4/
*/
class ClassLoader
{
/** @var \Closure(string):void */
private static $includeFile;
/** @var ?string */
private $vendorDir;
// PSR-4
/**
* @var array[]
* @psalm-var array<string, array<string, int>>
*/
private $prefixLengthsPsr4 = array();
/**
* @var array[]
* @psalm-var array<string, array<int, string>>
*/
private $prefixDirsPsr4 = array();
/**
* @var array[]
* @psalm-var array<string, string>
*/
private $fallbackDirsPsr4 = array();
// PSR-0
/**
* @var array[]
* @psalm-var array<string, array<string, string[]>>
*/
private $prefixesPsr0 = array();
/**
* @var array[]
* @psalm-var array<string, string>
*/
private $fallbackDirsPsr0 = array();
/** @var bool */
private $useIncludePath = false;
/**
* @var string[]
* @psalm-var array<string, string>
*/
private $classMap = array();
/** @var bool */
private $classMapAuthoritative = false;
/**
* @var bool[]
* @psalm-var array<string, bool>
*/
private $missingClasses = array();
/** @var ?string */
private $apcuPrefix;
/**
* @var self[]
*/
private static $registeredLoaders = array();
/**
* @param ?string $vendorDir
*/
public function __construct($vendorDir = null)
{
$this->vendorDir = $vendorDir;
self::initializeIncludeClosure();
}
/**
* @return string[]
*/
public function getPrefixes()
{
if (!empty($this->prefixesPsr0)) {
return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
}
return array();
}
/**
* @return array[]
* @psalm-return array<string, array<int, string>>
*/
public function getPrefixesPsr4()
{
return $this->prefixDirsPsr4;
}
/**
* @return array[]
* @psalm-return array<string, string>
*/
public function getFallbackDirs()
{
return $this->fallbackDirsPsr0;
}
/**
* @return array[]
* @psalm-return array<string, string>
*/
public function getFallbackDirsPsr4()
{
return $this->fallbackDirsPsr4;
}
/**
* @return string[] Array of classname => path
* @psalm-return array<string, string>
*/
public function getClassMap()
{
return $this->classMap;
}
/**
* @param string[] $classMap Class to filename map
* @psalm-param array<string, string> $classMap
*
* @return void
*/
public function addClassMap(array $classMap)
{
if ($this->classMap) {
$this->classMap = array_merge($this->classMap, $classMap);
} else {
$this->classMap = $classMap;
}
}
/**
* Registers a set of PSR-0 directories for a given prefix, either
* appending or prepending to the ones previously set for this prefix.
*
* @param string $prefix The prefix
* @param string[]|string $paths The PSR-0 root directories
* @param bool $prepend Whether to prepend the directories
*
* @return void
*/
public function add($prefix, $paths, $prepend = false)
{
if (!$prefix) {
if ($prepend) {
$this->fallbackDirsPsr0 = array_merge(
(array) $paths,
$this->fallbackDirsPsr0
);
} else {
$this->fallbackDirsPsr0 = array_merge(
$this->fallbackDirsPsr0,
(array) $paths
);
}
return;
}
$first = $prefix[0];
if (!isset($this->prefixesPsr0[$first][$prefix])) {
$this->prefixesPsr0[$first][$prefix] = (array) $paths;
return;
}
if ($prepend) {
$this->prefixesPsr0[$first][$prefix] = array_merge(
(array) $paths,
$this->prefixesPsr0[$first][$prefix]
);
} else {
$this->prefixesPsr0[$first][$prefix] = array_merge(
$this->prefixesPsr0[$first][$prefix],
(array) $paths
);
}
}
/**
* Registers a set of PSR-4 directories for a given namespace, either
* appending or prepending to the ones previously set for this namespace.
*
* @param string $prefix The prefix/namespace, with trailing '\\'
* @param string[]|string $paths The PSR-4 base directories
* @param bool $prepend Whether to prepend the directories
*
* @throws \InvalidArgumentException
*
* @return void
*/
public function addPsr4($prefix, $paths, $prepend = false)
{
if (!$prefix) {
// Register directories for the root namespace.
if ($prepend) {
$this->fallbackDirsPsr4 = array_merge(
(array) $paths,
$this->fallbackDirsPsr4
);
} else {
$this->fallbackDirsPsr4 = array_merge(
$this->fallbackDirsPsr4,
(array) $paths
);
}
} elseif (!isset($this->prefixDirsPsr4[$prefix])) {
// Register directories for a new namespace.
$length = strlen($prefix);
if ('\\' !== $prefix[$length - 1]) {
throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
}
$this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
$this->prefixDirsPsr4[$prefix] = (array) $paths;
} elseif ($prepend) {
// Prepend directories for an already registered namespace.
$this->prefixDirsPsr4[$prefix] = array_merge(
(array) $paths,
$this->prefixDirsPsr4[$prefix]
);
} else {
// Append directories for an already registered namespace.
$this->prefixDirsPsr4[$prefix] = array_merge(
$this->prefixDirsPsr4[$prefix],
(array) $paths
);
}
}
/**
* Registers a set of PSR-0 directories for a given prefix,
* replacing any others previously set for this prefix.
*
* @param string $prefix The prefix
* @param string[]|string $paths The PSR-0 base directories
*
* @return void
*/
public function set($prefix, $paths)
{
if (!$prefix) {
$this->fallbackDirsPsr0 = (array) $paths;
} else {
$this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths;
}
}
/**
* Registers a set of PSR-4 directories for a given namespace,
* replacing any others previously set for this namespace.
*
* @param string $prefix The prefix/namespace, with trailing '\\'
* @param string[]|string $paths The PSR-4 base directories
*
* @throws \InvalidArgumentException
*
* @return void
*/
public function setPsr4($prefix, $paths)
{
if (!$prefix) {
$this->fallbackDirsPsr4 = (array) $paths;
} else {
$length = strlen($prefix);
if ('\\' !== $prefix[$length - 1]) {
throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
}
$this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
$this->prefixDirsPsr4[$prefix] = (array) $paths;
}
}
/**
* Turns on searching the include path for class files.
*
* @param bool $useIncludePath
*
* @return void
*/
public function setUseIncludePath($useIncludePath)
{
$this->useIncludePath = $useIncludePath;
}
/**
* Can be used to check if the autoloader uses the include path to check
* for classes.
*
* @return bool
*/
public function getUseIncludePath()
{
return $this->useIncludePath;
}
/**
* Turns off searching the prefix and fallback directories for classes
* that have not been registered with the class map.
*
* @param bool $classMapAuthoritative
*
* @return void
*/
public function setClassMapAuthoritative($classMapAuthoritative)
{
$this->classMapAuthoritative = $classMapAuthoritative;
}
/**
* Should class lookup fail if not found in the current class map?
*
* @return bool
*/
public function isClassMapAuthoritative()
{
return $this->classMapAuthoritative;
}
/**
* APCu prefix to use to cache found/not-found classes, if the extension is enabled.
*
* @param string|null $apcuPrefix
*
* @return void
*/
public function setApcuPrefix($apcuPrefix)
{
$this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null;
}
/**
* The APCu prefix in use, or null if APCu caching is not enabled.
*
* @return string|null
*/
public function getApcuPrefix()
{
return $this->apcuPrefix;
}
/**
* Registers this instance as an autoloader.
*
* @param bool $prepend Whether to prepend the autoloader or not
*
* @return void
*/
public function register($prepend = false)
{
spl_autoload_register(array($this, 'loadClass'), true, $prepend);
if (null === $this->vendorDir) {
return;
}
if ($prepend) {
self::$registeredLoaders = array($this->vendorDir => $this) + self::$registeredLoaders;
} else {
unset(self::$registeredLoaders[$this->vendorDir]);
self::$registeredLoaders[$this->vendorDir] = $this;
}
}
/**
* Unregisters this instance as an autoloader.
*
* @return void
*/
public function unregister()
{
spl_autoload_unregister(array($this, 'loadClass'));
if (null !== $this->vendorDir) {
unset(self::$registeredLoaders[$this->vendorDir]);
}
}
/**
* Loads the given class or interface.
*
* @param string $class The name of the class
* @return true|null True if loaded, null otherwise
*/
public function loadClass($class)
{
if ($file = $this->findFile($class)) {
$includeFile = self::$includeFile;
$includeFile($file);
return true;
}
return null;
}
/**
* Finds the path to the file where the class is defined.
*
* @param string $class The name of the class
*
* @return string|false The path if found, false otherwise
*/
public function findFile($class)
{
// class map lookup
if (isset($this->classMap[$class])) {
return $this->classMap[$class];
}
if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
return false;
}
if (null !== $this->apcuPrefix) {
$file = apcu_fetch($this->apcuPrefix.$class, $hit);
if ($hit) {
return $file;
}
}
$file = $this->findFileWithExtension($class, '.php');
// Search for Hack files if we are running on HHVM
if (false === $file && defined('HHVM_VERSION')) {
$file = $this->findFileWithExtension($class, '.hh');
}
if (null !== $this->apcuPrefix) {
apcu_add($this->apcuPrefix.$class, $file);
}
if (false === $file) {
// Remember that this class does not exist.
$this->missingClasses[$class] = true;
}
return $file;
}
/**
* Returns the currently registered loaders indexed by their corresponding vendor directories.
*
* @return self[]
*/
public static function getRegisteredLoaders()
{
return self::$registeredLoaders;
}
/**
* @param string $class
* @param string $ext
* @return string|false
*/
private function findFileWithExtension($class, $ext)
{
// PSR-4 lookup
$logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
$first = $class[0];
if (isset($this->prefixLengthsPsr4[$first])) {
$subPath = $class;
while (false !== $lastPos = strrpos($subPath, '\\')) {
$subPath = substr($subPath, 0, $lastPos);
$search = $subPath . '\\';
if (isset($this->prefixDirsPsr4[$search])) {
$pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
foreach ($this->prefixDirsPsr4[$search] as $dir) {
if (file_exists($file = $dir . $pathEnd)) {
return $file;
}
}
}
}
}
// PSR-4 fallback dirs
foreach ($this->fallbackDirsPsr4 as $dir) {
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
return $file;
}
}
// PSR-0 lookup
if (false !== $pos = strrpos($class, '\\')) {
// namespaced class name
$logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
. strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
} else {
// PEAR-like class name
$logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
}
if (isset($this->prefixesPsr0[$first])) {
foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
if (0 === strpos($class, $prefix)) {
foreach ($dirs as $dir) {
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
return $file;
}
}
}
}
}
// PSR-0 fallback dirs
foreach ($this->fallbackDirsPsr0 as $dir) {
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
return $file;
}
}
// PSR-0 include paths.
if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
return $file;
}
return false;
}
/**
* @return void
*/
private static function initializeIncludeClosure()
{
if (self::$includeFile !== null) {
return;
}
/**
* Scope isolated include.
*
* Prevents access to $this/self from included files.
*
* @param string $file
* @return void
*/
self::$includeFile = \Closure::bind(static function($file) {
include $file;
}, null, null);
}
}

View File

@@ -0,0 +1,313 @@
<?php
/*
* This file is part of Composer.
*
* (c) Nils Adermann <naderman@naderman.de>
* Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\Composer;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Composer\Autoload\ClassLoader;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Composer\Semver\VersionParser;
/**
* This class is copied in every Composer installed project and available to all
*
* See also https://getcomposer.org/doc/07-runtime.md#installed-versions
*
* To require its presence, you can require `composer-runtime-api ^2.0`
*
* @final
*/
class InstalledVersions
{
/**
* @var mixed[]|null
* @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}|array{}|null
*/
private static $installed;
/**
* @var bool|null
*/
private static $canGetVendors;
/**
* @var array[]
* @psalm-var array<string, array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
*/
private static $installedByVendor = array();
/**
* Returns a list of all package names which are present, either by being installed, replaced or provided
*
* @return string[]
* @psalm-return list<string>
*/
public static function getInstalledPackages()
{
$packages = array();
foreach (self::getInstalled() as $installed) {
$packages[] = \array_keys($installed['versions']);
}
if (1 === \count($packages)) {
return $packages[0];
}
return \array_keys(\array_flip(\call_user_func_array('array_merge', $packages)));
}
/**
* Returns a list of all package names with a specific type e.g. 'library'
*
* @param string $type
* @return string[]
* @psalm-return list<string>
*/
public static function getInstalledPackagesByType($type)
{
$packagesByType = array();
foreach (self::getInstalled() as $installed) {
foreach ($installed['versions'] as $name => $package) {
if (isset($package['type']) && $package['type'] === $type) {
$packagesByType[] = $name;
}
}
}
return $packagesByType;
}
/**
* Checks whether the given package is installed
*
* This also returns true if the package name is provided or replaced by another package
*
* @param string $packageName
* @param bool $includeDevRequirements
* @return bool
*/
public static function isInstalled($packageName, $includeDevRequirements = \true)
{
foreach (self::getInstalled() as $installed) {
if (isset($installed['versions'][$packageName])) {
return $includeDevRequirements || !isset($installed['versions'][$packageName]['dev_requirement']) || $installed['versions'][$packageName]['dev_requirement'] === \false;
}
}
return \false;
}
/**
* Checks whether the given package satisfies a version constraint
*
* e.g. If you want to know whether version 2.3+ of package foo/bar is installed, you would call:
*
* Composer\InstalledVersions::satisfies(new VersionParser, 'foo/bar', '^2.3')
*
* @param VersionParser $parser Install composer/semver to have access to this class and functionality
* @param string $packageName
* @param string|null $constraint A version constraint to check for, if you pass one you have to make sure composer/semver is required by your package
* @return bool
*/
public static function satisfies(VersionParser $parser, $packageName, $constraint)
{
$constraint = $parser->parseConstraints((string) $constraint);
$provided = $parser->parseConstraints(self::getVersionRanges($packageName));
return $provided->matches($constraint);
}
/**
* Returns a version constraint representing all the range(s) which are installed for a given package
*
* It is easier to use this via isInstalled() with the $constraint argument if you need to check
* whether a given version of a package is installed, and not just whether it exists
*
* @param string $packageName
* @return string Version constraint usable with composer/semver
*/
public static function getVersionRanges($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
$ranges = array();
if (isset($installed['versions'][$packageName]['pretty_version'])) {
$ranges[] = $installed['versions'][$packageName]['pretty_version'];
}
if (\array_key_exists('aliases', $installed['versions'][$packageName])) {
$ranges = \array_merge($ranges, $installed['versions'][$packageName]['aliases']);
}
if (\array_key_exists('replaced', $installed['versions'][$packageName])) {
$ranges = \array_merge($ranges, $installed['versions'][$packageName]['replaced']);
}
if (\array_key_exists('provided', $installed['versions'][$packageName])) {
$ranges = \array_merge($ranges, $installed['versions'][$packageName]['provided']);
}
return \implode(' || ', $ranges);
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
*/
public static function getVersion($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['version'])) {
return null;
}
return $installed['versions'][$packageName]['version'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
*/
public static function getPrettyVersion($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['pretty_version'])) {
return null;
}
return $installed['versions'][$packageName]['pretty_version'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as reference
*/
public static function getReference($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['reference'])) {
return null;
}
return $installed['versions'][$packageName]['reference'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as install path. Packages of type metapackages also have a null install path.
*/
public static function getInstallPath($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
return isset($installed['versions'][$packageName]['install_path']) ? $installed['versions'][$packageName]['install_path'] : null;
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @return array
* @psalm-return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}
*/
public static function getRootPackage()
{
$installed = self::getInstalled();
return $installed[0]['root'];
}
/**
* Returns the raw installed.php data for custom implementations
*
* @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect.
* @return array[]
* @psalm-return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}
*/
public static function getRawData()
{
@\trigger_error('getRawData only returns the first dataset loaded, which may not be what you expect. Use getAllRawData() instead which returns all datasets for all autoloaders present in the process.', \E_USER_DEPRECATED);
if (null === self::$installed) {
// only require the installed.php file if this file is loaded from its dumped location,
// and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
if (\substr(__DIR__, -8, 1) !== 'C') {
self::$installed = (include __DIR__ . '/installed.php');
} else {
self::$installed = array();
}
}
return self::$installed;
}
/**
* Returns the raw data of all installed.php which are currently loaded for custom implementations
*
* @return array[]
* @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
*/
public static function getAllRawData()
{
return self::getInstalled();
}
/**
* Lets you reload the static array from another file
*
* This is only useful for complex integrations in which a project needs to use
* this class but then also needs to execute another project's autoloader in process,
* and wants to ensure both projects have access to their version of installed.php.
*
* A typical case would be PHPUnit, where it would need to make sure it reads all
* the data it needs from this class, then call reload() with
* `require $CWD/vendor/composer/installed.php` (or similar) as input to make sure
* the project in which it runs can then also use this class safely, without
* interference between PHPUnit's dependencies and the project's dependencies.
*
* @param array[] $data A vendor/composer/installed.php data set
* @return void
*
* @psalm-param array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $data
*/
public static function reload($data)
{
self::$installed = $data;
self::$installedByVendor = array();
}
/**
* @return array[]
* @psalm-return list<array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>}>
*/
private static function getInstalled()
{
if (null === self::$canGetVendors) {
self::$canGetVendors = \method_exists('Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Composer\\Autoload\\ClassLoader', 'getRegisteredLoaders');
}
$installed = array();
if (self::$canGetVendors) {
foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) {
if (isset(self::$installedByVendor[$vendorDir])) {
$installed[] = self::$installedByVendor[$vendorDir];
} elseif (\is_file($vendorDir . '/composer/installed.php')) {
/** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $required */
$required = (require $vendorDir . '/composer/installed.php');
$installed[] = self::$installedByVendor[$vendorDir] = $required;
if (null === self::$installed && \strtr($vendorDir . '/composer', '\\', '/') === \strtr(__DIR__, '\\', '/')) {
self::$installed = $installed[\count($installed) - 1];
}
}
}
}
if (null === self::$installed) {
// only require the installed.php file if this file is loaded from its dumped location,
// and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
if (\substr(__DIR__, -8, 1) !== 'C') {
/** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array<string, array{pretty_version?: string, version?: string, reference?: string|null, type?: string, install_path?: string, aliases?: string[], dev_requirement: bool, replaced?: string[], provided?: string[]}>} $required */
$required = (require __DIR__ . '/installed.php');
self::$installed = $required;
} else {
self::$installed = array();
}
}
if (self::$installed !== array()) {
$installed[] = self::$installed;
}
return $installed;
}
}

View File

@@ -0,0 +1,21 @@
Copyright (c) Nils Adermann, Jordi Boggiano
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is furnished
to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

View File

@@ -0,0 +1,153 @@
<?php
// autoload_classmap.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\EventCollection' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Common/EventCollection.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\UserProperties' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Common/UserProperties.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\UserProperty' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Common/UserProperty.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\ValidationMessage' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Common/ValidationMessage.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AbstractEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/AbstractEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AddPaymentInfoEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/AddPaymentInfoEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AddShippingInfoEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/AddShippingInfoEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AddToCartEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/AddToCartEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\BaseEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/BaseEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\BeginCheckoutEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/BeginCheckoutEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ItemBaseEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/ItemBaseEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\LoginEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/LoginEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\PurchaseEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/PurchaseEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\RefundEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/RefundEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\RemoveFromCartEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/RemoveFromCartEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\SearchEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/SearchEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\SelectItemEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/SelectItemEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\SignUpEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/SignUpEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewCartEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/ViewCartEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewItemEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/ViewItemEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewItemListEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/ViewItemListEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewSearchResultsEvent' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Event/ViewSearchResultsEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\ExportableInterface' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/ExportableInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\HydratableInterface' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/HydratableInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\AbstractParameter' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Parameter/AbstractParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\BaseParameter' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Parameter/BaseParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\ItemCollectionParameter' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Parameter/ItemCollectionParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\ItemParameter' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Parameter/ItemParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Request\\AbstractRequest' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Request/AbstractRequest.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Request\\BaseRequest' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Request/BaseRequest.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Response\\AbstractResponse' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Response/AbstractResponse.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Response\\BaseResponse' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Response/BaseResponse.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Response\\DebugResponse' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/Response/DebugResponse.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\ValidateInterface' => $vendorDir . '/br33f/php-ga4-mp/src/Dto/ValidateInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Enum\\ErrorCode' => $vendorDir . '/br33f/php-ga4-mp/src/Enum/ErrorCode.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Enum\\ValidationCode' => $vendorDir . '/br33f/php-ga4-mp/src/Enum/ValidationCode.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Exception\\HydrationException' => $vendorDir . '/br33f/php-ga4-mp/src/Exception/HydrationException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Exception\\ValidationException' => $vendorDir . '/br33f/php-ga4-mp/src/Exception/ValidationException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\HttpClient' => $vendorDir . '/br33f/php-ga4-mp/src/HttpClient.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Service' => $vendorDir . '/br33f/php-ga4-mp/src/Service.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\BodySummarizer' => $vendorDir . '/guzzlehttp/guzzle/src/BodySummarizer.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\BodySummarizerInterface' => $vendorDir . '/guzzlehttp/guzzle/src/BodySummarizerInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Client' => $vendorDir . '/guzzlehttp/guzzle/src/Client.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\ClientInterface' => $vendorDir . '/guzzlehttp/guzzle/src/ClientInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\ClientTrait' => $vendorDir . '/guzzlehttp/guzzle/src/ClientTrait.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\CookieJar' => $vendorDir . '/guzzlehttp/guzzle/src/Cookie/CookieJar.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\CookieJarInterface' => $vendorDir . '/guzzlehttp/guzzle/src/Cookie/CookieJarInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\FileCookieJar' => $vendorDir . '/guzzlehttp/guzzle/src/Cookie/FileCookieJar.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\SessionCookieJar' => $vendorDir . '/guzzlehttp/guzzle/src/Cookie/SessionCookieJar.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\SetCookie' => $vendorDir . '/guzzlehttp/guzzle/src/Cookie/SetCookie.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\BadResponseException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/BadResponseException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\ClientException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/ClientException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\ConnectException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/ConnectException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\GuzzleException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/GuzzleException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\InvalidArgumentException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/InvalidArgumentException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\RequestException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/RequestException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\ServerException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/ServerException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\TooManyRedirectsException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/TooManyRedirectsException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\TransferException' => $vendorDir . '/guzzlehttp/guzzle/src/Exception/TransferException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\HandlerStack' => $vendorDir . '/guzzlehttp/guzzle/src/HandlerStack.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlFactory' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/CurlFactory.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlFactoryInterface' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/CurlFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlHandler' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/CurlHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlMultiHandler' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/CurlMultiHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\EasyHandle' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/EasyHandle.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\HeaderProcessor' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/HeaderProcessor.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\MockHandler' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/MockHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\Proxy' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/Proxy.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\StreamHandler' => $vendorDir . '/guzzlehttp/guzzle/src/Handler/StreamHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\MessageFormatter' => $vendorDir . '/guzzlehttp/guzzle/src/MessageFormatter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\MessageFormatterInterface' => $vendorDir . '/guzzlehttp/guzzle/src/MessageFormatterInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Middleware' => $vendorDir . '/guzzlehttp/guzzle/src/Middleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Pool' => $vendorDir . '/guzzlehttp/guzzle/src/Pool.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\PrepareBodyMiddleware' => $vendorDir . '/guzzlehttp/guzzle/src/PrepareBodyMiddleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\AggregateException' => $vendorDir . '/guzzlehttp/promises/src/AggregateException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\CancellationException' => $vendorDir . '/guzzlehttp/promises/src/CancellationException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Coroutine' => $vendorDir . '/guzzlehttp/promises/src/Coroutine.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Create' => $vendorDir . '/guzzlehttp/promises/src/Create.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Each' => $vendorDir . '/guzzlehttp/promises/src/Each.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\EachPromise' => $vendorDir . '/guzzlehttp/promises/src/EachPromise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\FulfilledPromise' => $vendorDir . '/guzzlehttp/promises/src/FulfilledPromise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Is' => $vendorDir . '/guzzlehttp/promises/src/Is.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Promise' => $vendorDir . '/guzzlehttp/promises/src/Promise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\PromiseInterface' => $vendorDir . '/guzzlehttp/promises/src/PromiseInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\PromisorInterface' => $vendorDir . '/guzzlehttp/promises/src/PromisorInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\RejectedPromise' => $vendorDir . '/guzzlehttp/promises/src/RejectedPromise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\RejectionException' => $vendorDir . '/guzzlehttp/promises/src/RejectionException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\TaskQueue' => $vendorDir . '/guzzlehttp/promises/src/TaskQueue.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\TaskQueueInterface' => $vendorDir . '/guzzlehttp/promises/src/TaskQueueInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Utils' => $vendorDir . '/guzzlehttp/promises/src/Utils.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\AppendStream' => $vendorDir . '/guzzlehttp/psr7/src/AppendStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\BufferStream' => $vendorDir . '/guzzlehttp/psr7/src/BufferStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\CachingStream' => $vendorDir . '/guzzlehttp/psr7/src/CachingStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\DroppingStream' => $vendorDir . '/guzzlehttp/psr7/src/DroppingStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Exception\\MalformedUriException' => $vendorDir . '/guzzlehttp/psr7/src/Exception/MalformedUriException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\FnStream' => $vendorDir . '/guzzlehttp/psr7/src/FnStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Header' => $vendorDir . '/guzzlehttp/psr7/src/Header.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\HttpFactory' => $vendorDir . '/guzzlehttp/psr7/src/HttpFactory.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\InflateStream' => $vendorDir . '/guzzlehttp/psr7/src/InflateStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\LazyOpenStream' => $vendorDir . '/guzzlehttp/psr7/src/LazyOpenStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\LimitStream' => $vendorDir . '/guzzlehttp/psr7/src/LimitStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Message' => $vendorDir . '/guzzlehttp/psr7/src/Message.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\MessageTrait' => $vendorDir . '/guzzlehttp/psr7/src/MessageTrait.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\MimeType' => $vendorDir . '/guzzlehttp/psr7/src/MimeType.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\MultipartStream' => $vendorDir . '/guzzlehttp/psr7/src/MultipartStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\NoSeekStream' => $vendorDir . '/guzzlehttp/psr7/src/NoSeekStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\PumpStream' => $vendorDir . '/guzzlehttp/psr7/src/PumpStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Query' => $vendorDir . '/guzzlehttp/psr7/src/Query.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Request' => $vendorDir . '/guzzlehttp/psr7/src/Request.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Response' => $vendorDir . '/guzzlehttp/psr7/src/Response.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Rfc7230' => $vendorDir . '/guzzlehttp/psr7/src/Rfc7230.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\ServerRequest' => $vendorDir . '/guzzlehttp/psr7/src/ServerRequest.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Stream' => $vendorDir . '/guzzlehttp/psr7/src/Stream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\StreamDecoratorTrait' => $vendorDir . '/guzzlehttp/psr7/src/StreamDecoratorTrait.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\StreamWrapper' => $vendorDir . '/guzzlehttp/psr7/src/StreamWrapper.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UploadedFile' => $vendorDir . '/guzzlehttp/psr7/src/UploadedFile.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Uri' => $vendorDir . '/guzzlehttp/psr7/src/Uri.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UriComparator' => $vendorDir . '/guzzlehttp/psr7/src/UriComparator.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UriNormalizer' => $vendorDir . '/guzzlehttp/psr7/src/UriNormalizer.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UriResolver' => $vendorDir . '/guzzlehttp/psr7/src/UriResolver.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Utils' => $vendorDir . '/guzzlehttp/psr7/src/Utils.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\RedirectMiddleware' => $vendorDir . '/guzzlehttp/guzzle/src/RedirectMiddleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\RequestOptions' => $vendorDir . '/guzzlehttp/guzzle/src/RequestOptions.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\RetryMiddleware' => $vendorDir . '/guzzlehttp/guzzle/src/RetryMiddleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\TransferStats' => $vendorDir . '/guzzlehttp/guzzle/src/TransferStats.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Utils' => $vendorDir . '/guzzlehttp/guzzle/src/Utils.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\ClientExceptionInterface' => $vendorDir . '/psr/http-client/src/ClientExceptionInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\ClientInterface' => $vendorDir . '/psr/http-client/src/ClientInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\NetworkExceptionInterface' => $vendorDir . '/psr/http-client/src/NetworkExceptionInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\RequestExceptionInterface' => $vendorDir . '/psr/http-client/src/RequestExceptionInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\MessageInterface' => $vendorDir . '/psr/http-message/src/MessageInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\RequestFactoryInterface' => $vendorDir . '/psr/http-factory/src/RequestFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\RequestInterface' => $vendorDir . '/psr/http-message/src/RequestInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ResponseFactoryInterface' => $vendorDir . '/psr/http-factory/src/ResponseFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ResponseInterface' => $vendorDir . '/psr/http-message/src/ResponseInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ServerRequestFactoryInterface' => $vendorDir . '/psr/http-factory/src/ServerRequestFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ServerRequestInterface' => $vendorDir . '/psr/http-message/src/ServerRequestInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\StreamFactoryInterface' => $vendorDir . '/psr/http-factory/src/StreamFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\StreamInterface' => $vendorDir . '/psr/http-message/src/StreamInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UploadedFileFactoryInterface' => $vendorDir . '/psr/http-factory/src/UploadedFileFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UploadedFileInterface' => $vendorDir . '/psr/http-message/src/UploadedFileInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UriFactoryInterface' => $vendorDir . '/psr/http-factory/src/UriFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UriInterface' => $vendorDir . '/psr/http-message/src/UriInterface.php',
);

View File

@@ -0,0 +1,12 @@
<?php
// autoload_files.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
'7b11c4dc42b3b3023073cb14e519683c' => $vendorDir . '/ralouphie/getallheaders/src/getallheaders.php',
'6e3fae29631ef280660b3cdad06f25a8' => $vendorDir . '/symfony/deprecation-contracts/function.php',
'37a3dc5111fe8f707ab4c132ef1dbc62' => $vendorDir . '/guzzlehttp/guzzle/src/functions_include.php',
);

View File

@@ -0,0 +1,9 @@
<?php
// autoload_namespaces.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
);

View File

@@ -0,0 +1,15 @@
<?php
// autoload_psr4.php @generated by Composer
$vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir);
return array(
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\' => array($vendorDir . '/psr/http-factory/src', $vendorDir . '/psr/http-message/src'),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\' => array($vendorDir . '/psr/http-client/src'),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\' => array($vendorDir . '/guzzlehttp/psr7/src'),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\' => array($vendorDir . '/guzzlehttp/promises/src'),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\' => array($vendorDir . '/guzzlehttp/guzzle/src'),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\' => array($vendorDir . '/br33f/php-ga4-mp/src'),
);

View File

@@ -0,0 +1,50 @@
<?php
// autoload_real.php @generated by Composer
class ComposerAutoloaderInit06b362e1a4e56ef1a18a29e98867cfdb
{
private static $loader;
public static function loadClassLoader($class)
{
if ('Composer\Autoload\ClassLoader' === $class) {
require __DIR__ . '/ClassLoader.php';
}
}
/**
* @return \Composer\Autoload\ClassLoader
*/
public static function getLoader()
{
if (null !== self::$loader) {
return self::$loader;
}
require __DIR__ . '/platform_check.php';
spl_autoload_register(array('ComposerAutoloaderInit06b362e1a4e56ef1a18a29e98867cfdb', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(__DIR__));
spl_autoload_unregister(array('ComposerAutoloaderInit06b362e1a4e56ef1a18a29e98867cfdb', 'loadClassLoader'));
require __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInit06b362e1a4e56ef1a18a29e98867cfdb::getInitializer($loader));
$loader->register(true);
$filesToLoad = \Composer\Autoload\ComposerStaticInit06b362e1a4e56ef1a18a29e98867cfdb::$files;
$requireFile = \Closure::bind(static function ($fileIdentifier, $file) {
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
$GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;
require $file;
}
}, null, null);
foreach ($filesToLoad as $fileIdentifier => $file) {
$requireFile($fileIdentifier, $file);
}
return $loader;
}
}

View File

@@ -0,0 +1,211 @@
<?php
// autoload_static.php @generated by Composer
namespace Composer\Autoload;
class ComposerStaticInit06b362e1a4e56ef1a18a29e98867cfdb
{
public static $files = array (
'7b11c4dc42b3b3023073cb14e519683c' => __DIR__ . '/..' . '/ralouphie/getallheaders/src/getallheaders.php',
'6e3fae29631ef280660b3cdad06f25a8' => __DIR__ . '/..' . '/symfony/deprecation-contracts/function.php',
'37a3dc5111fe8f707ab4c132ef1dbc62' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/functions_include.php',
);
public static $prefixLengthsPsr4 = array (
'I' =>
array (
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\' => 57,
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\' => 56,
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\' => 56,
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\' => 59,
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\' => 51,
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\' => 70,
),
);
public static $prefixDirsPsr4 = array (
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\' =>
array (
0 => __DIR__ . '/..' . '/psr/http-factory/src',
1 => __DIR__ . '/..' . '/psr/http-message/src',
),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\' =>
array (
0 => __DIR__ . '/..' . '/psr/http-client/src',
),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\' =>
array (
0 => __DIR__ . '/..' . '/guzzlehttp/psr7/src',
),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\' =>
array (
0 => __DIR__ . '/..' . '/guzzlehttp/promises/src',
),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\' =>
array (
0 => __DIR__ . '/..' . '/guzzlehttp/guzzle/src',
),
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\' =>
array (
0 => __DIR__ . '/..' . '/br33f/php-ga4-mp/src',
),
);
public static $classMap = array (
'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\EventCollection' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Common/EventCollection.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\UserProperties' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Common/UserProperties.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\UserProperty' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Common/UserProperty.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Common\\ValidationMessage' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Common/ValidationMessage.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AbstractEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/AbstractEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AddPaymentInfoEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/AddPaymentInfoEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AddShippingInfoEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/AddShippingInfoEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\AddToCartEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/AddToCartEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\BaseEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/BaseEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\BeginCheckoutEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/BeginCheckoutEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ItemBaseEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/ItemBaseEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\LoginEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/LoginEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\PurchaseEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/PurchaseEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\RefundEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/RefundEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\RemoveFromCartEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/RemoveFromCartEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\SearchEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/SearchEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\SelectItemEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/SelectItemEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\SignUpEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/SignUpEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewCartEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/ViewCartEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewItemEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/ViewItemEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewItemListEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/ViewItemListEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Event\\ViewSearchResultsEvent' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Event/ViewSearchResultsEvent.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\ExportableInterface' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/ExportableInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\HydratableInterface' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/HydratableInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\AbstractParameter' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Parameter/AbstractParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\BaseParameter' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Parameter/BaseParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\ItemCollectionParameter' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Parameter/ItemCollectionParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Parameter\\ItemParameter' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Parameter/ItemParameter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Request\\AbstractRequest' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Request/AbstractRequest.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Request\\BaseRequest' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Request/BaseRequest.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Response\\AbstractResponse' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Response/AbstractResponse.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Response\\BaseResponse' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Response/BaseResponse.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\Response\\DebugResponse' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/Response/DebugResponse.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Dto\\ValidateInterface' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Dto/ValidateInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Enum\\ErrorCode' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Enum/ErrorCode.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Enum\\ValidationCode' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Enum/ValidationCode.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Exception\\HydrationException' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Exception/HydrationException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Exception\\ValidationException' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Exception/ValidationException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\HttpClient' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/HttpClient.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\Service' => __DIR__ . '/..' . '/br33f/php-ga4-mp/src/Service.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\BodySummarizer' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/BodySummarizer.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\BodySummarizerInterface' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/BodySummarizerInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Client' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Client.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\ClientInterface' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/ClientInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\ClientTrait' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/ClientTrait.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\CookieJar' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Cookie/CookieJar.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\CookieJarInterface' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Cookie/CookieJarInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\FileCookieJar' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Cookie/FileCookieJar.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\SessionCookieJar' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Cookie/SessionCookieJar.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Cookie\\SetCookie' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Cookie/SetCookie.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\BadResponseException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/BadResponseException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\ClientException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/ClientException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\ConnectException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/ConnectException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\GuzzleException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/GuzzleException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/InvalidArgumentException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\RequestException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/RequestException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\ServerException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/ServerException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\TooManyRedirectsException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/TooManyRedirectsException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Exception\\TransferException' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Exception/TransferException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\HandlerStack' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/HandlerStack.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlFactory' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/CurlFactory.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlFactoryInterface' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/CurlFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlHandler' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/CurlHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\CurlMultiHandler' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/CurlMultiHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\EasyHandle' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/EasyHandle.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\HeaderProcessor' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/HeaderProcessor.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\MockHandler' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/MockHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\Proxy' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/Proxy.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Handler\\StreamHandler' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Handler/StreamHandler.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\MessageFormatter' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/MessageFormatter.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\MessageFormatterInterface' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/MessageFormatterInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Middleware' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Middleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Pool' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Pool.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\PrepareBodyMiddleware' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/PrepareBodyMiddleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\AggregateException' => __DIR__ . '/..' . '/guzzlehttp/promises/src/AggregateException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\CancellationException' => __DIR__ . '/..' . '/guzzlehttp/promises/src/CancellationException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Coroutine' => __DIR__ . '/..' . '/guzzlehttp/promises/src/Coroutine.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Create' => __DIR__ . '/..' . '/guzzlehttp/promises/src/Create.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Each' => __DIR__ . '/..' . '/guzzlehttp/promises/src/Each.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\EachPromise' => __DIR__ . '/..' . '/guzzlehttp/promises/src/EachPromise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\FulfilledPromise' => __DIR__ . '/..' . '/guzzlehttp/promises/src/FulfilledPromise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Is' => __DIR__ . '/..' . '/guzzlehttp/promises/src/Is.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Promise' => __DIR__ . '/..' . '/guzzlehttp/promises/src/Promise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\PromiseInterface' => __DIR__ . '/..' . '/guzzlehttp/promises/src/PromiseInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\PromisorInterface' => __DIR__ . '/..' . '/guzzlehttp/promises/src/PromisorInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\RejectedPromise' => __DIR__ . '/..' . '/guzzlehttp/promises/src/RejectedPromise.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\RejectionException' => __DIR__ . '/..' . '/guzzlehttp/promises/src/RejectionException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\TaskQueue' => __DIR__ . '/..' . '/guzzlehttp/promises/src/TaskQueue.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\TaskQueueInterface' => __DIR__ . '/..' . '/guzzlehttp/promises/src/TaskQueueInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\Utils' => __DIR__ . '/..' . '/guzzlehttp/promises/src/Utils.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\AppendStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/AppendStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\BufferStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/BufferStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\CachingStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/CachingStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\DroppingStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/DroppingStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Exception\\MalformedUriException' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Exception/MalformedUriException.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\FnStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/FnStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Header' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Header.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\HttpFactory' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/HttpFactory.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\InflateStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/InflateStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\LazyOpenStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/LazyOpenStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\LimitStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/LimitStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Message' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Message.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\MessageTrait' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/MessageTrait.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\MimeType' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/MimeType.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\MultipartStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/MultipartStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\NoSeekStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/NoSeekStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\PumpStream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/PumpStream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Query' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Query.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Request' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Request.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Response' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Response.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Rfc7230' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Rfc7230.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\ServerRequest' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/ServerRequest.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Stream' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Stream.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\StreamDecoratorTrait' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/StreamDecoratorTrait.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\StreamWrapper' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/StreamWrapper.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UploadedFile' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/UploadedFile.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Uri' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Uri.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UriComparator' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/UriComparator.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UriNormalizer' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/UriNormalizer.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\UriResolver' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/UriResolver.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\Utils' => __DIR__ . '/..' . '/guzzlehttp/psr7/src/Utils.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\RedirectMiddleware' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/RedirectMiddleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\RequestOptions' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/RequestOptions.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\RetryMiddleware' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/RetryMiddleware.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\TransferStats' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/TransferStats.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Utils' => __DIR__ . '/..' . '/guzzlehttp/guzzle/src/Utils.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\ClientExceptionInterface' => __DIR__ . '/..' . '/psr/http-client/src/ClientExceptionInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\ClientInterface' => __DIR__ . '/..' . '/psr/http-client/src/ClientInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\NetworkExceptionInterface' => __DIR__ . '/..' . '/psr/http-client/src/NetworkExceptionInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\RequestExceptionInterface' => __DIR__ . '/..' . '/psr/http-client/src/RequestExceptionInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\MessageInterface' => __DIR__ . '/..' . '/psr/http-message/src/MessageInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\RequestFactoryInterface' => __DIR__ . '/..' . '/psr/http-factory/src/RequestFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\RequestInterface' => __DIR__ . '/..' . '/psr/http-message/src/RequestInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ResponseFactoryInterface' => __DIR__ . '/..' . '/psr/http-factory/src/ResponseFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ResponseInterface' => __DIR__ . '/..' . '/psr/http-message/src/ResponseInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ServerRequestFactoryInterface' => __DIR__ . '/..' . '/psr/http-factory/src/ServerRequestFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\ServerRequestInterface' => __DIR__ . '/..' . '/psr/http-message/src/ServerRequestInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\StreamFactoryInterface' => __DIR__ . '/..' . '/psr/http-factory/src/StreamFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\StreamInterface' => __DIR__ . '/..' . '/psr/http-message/src/StreamInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UploadedFileFactoryInterface' => __DIR__ . '/..' . '/psr/http-factory/src/UploadedFileFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UploadedFileInterface' => __DIR__ . '/..' . '/psr/http-message/src/UploadedFileInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UriFactoryInterface' => __DIR__ . '/..' . '/psr/http-factory/src/UriFactoryInterface.php',
'Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\UriInterface' => __DIR__ . '/..' . '/psr/http-message/src/UriInterface.php',
);
public static function getInitializer(ClassLoader $loader)
{
return \Closure::bind(function () use ($loader) {
$loader->prefixLengthsPsr4 = ComposerStaticInit06b362e1a4e56ef1a18a29e98867cfdb::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInit06b362e1a4e56ef1a18a29e98867cfdb::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInit06b362e1a4e56ef1a18a29e98867cfdb::$classMap;
}, null, ClassLoader::class);
}
}

View File

@@ -0,0 +1,676 @@
{
"packages": [
{
"name": "br33f\/php-ga4-mp",
"version": "v0.1.2",
"version_normalized": "0.1.2.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/br33f\/php-GA4-Measurement-Protocol.git",
"reference": "e9b95e5b0cf4daf05c3739d989867f1103835acb"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/br33f\/php-GA4-Measurement-Protocol\/zipball\/e9b95e5b0cf4daf05c3739d989867f1103835acb",
"reference": "e9b95e5b0cf4daf05c3739d989867f1103835acb",
"shasum": ""
},
"require": {
"ext-json": "*",
"guzzlehttp\/guzzle": "^6.5.5 || ^7.0.0",
"php": ">=7.1"
},
"require-dev": {
"fakerphp\/faker": "^1.14",
"php-coveralls\/php-coveralls": "^2.4",
"phpunit\/phpunit": "^9.5"
},
"time": "2022-08-25T12:01:16+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Br33f\\Ga4\\MeasurementProtocol\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "Damian Zamojski",
"email": "damian.zamojski1@gmail.com"
}
],
"description": "PHP GoogleAnalytics4 Measurement Protocol Library",
"support": {
"issues": "https:\/\/github.com\/br33f\/php-GA4-Measurement-Protocol\/issues",
"source": "https:\/\/github.com\/br33f\/php-GA4-Measurement-Protocol\/tree\/v0.1.2"
},
"install-path": "..\/br33f\/php-ga4-mp"
},
{
"name": "guzzlehttp\/guzzle",
"version": "7.8.0",
"version_normalized": "7.8.0.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/guzzle\/guzzle.git",
"reference": "1110f66a6530a40fe7aea0378fe608ee2b2248f9"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/guzzle\/guzzle\/zipball\/1110f66a6530a40fe7aea0378fe608ee2b2248f9",
"reference": "1110f66a6530a40fe7aea0378fe608ee2b2248f9",
"shasum": ""
},
"require": {
"ext-json": "*",
"guzzlehttp\/promises": "^1.5.3 || ^2.0.1",
"guzzlehttp\/psr7": "^1.9.1 || ^2.5.1",
"php": "^7.2.5 || ^8.0",
"psr\/http-client": "^1.0",
"symfony\/deprecation-contracts": "^2.2 || ^3.0"
},
"provide": {
"psr\/http-client-implementation": "1.0"
},
"require-dev": {
"bamarni\/composer-bin-plugin": "^1.8.1",
"ext-curl": "*",
"php-http\/client-integration-tests": "dev-master#2c025848417c1135031fdf9c728ee53d0a7ceaee as 3.0.999",
"php-http\/message-factory": "^1.1",
"phpunit\/phpunit": "^8.5.29 || ^9.5.23",
"psr\/log": "^1.1 || ^2.0 || ^3.0"
},
"suggest": {
"ext-curl": "Required for CURL handler support",
"ext-intl": "Required for Internationalized Domain Name (IDN) support",
"psr\/log": "Required for using the Log middleware"
},
"time": "2023-08-27T10:20:53+00:00",
"type": "library",
"extra": {
"bamarni-bin": {
"bin-links": true,
"forward-command": false
}
},
"installation-source": "dist",
"autoload": {
"files": [
"src\/functions_include.php"
],
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "Graham Campbell",
"email": "hello@gjcampbell.co.uk",
"homepage": "https:\/\/github.com\/GrahamCampbell"
},
{
"name": "Michael Dowling",
"email": "mtdowling@gmail.com",
"homepage": "https:\/\/github.com\/mtdowling"
},
{
"name": "Jeremy Lindblom",
"email": "jeremeamia@gmail.com",
"homepage": "https:\/\/github.com\/jeremeamia"
},
{
"name": "George Mponos",
"email": "gmponos@gmail.com",
"homepage": "https:\/\/github.com\/gmponos"
},
{
"name": "Tobias Nyholm",
"email": "tobias.nyholm@gmail.com",
"homepage": "https:\/\/github.com\/Nyholm"
},
{
"name": "M\u00e1rk S\u00e1gi-Kaz\u00e1r",
"email": "mark.sagikazar@gmail.com",
"homepage": "https:\/\/github.com\/sagikazarmark"
},
{
"name": "Tobias Schultze",
"email": "webmaster@tubo-world.de",
"homepage": "https:\/\/github.com\/Tobion"
}
],
"description": "Guzzle is a PHP HTTP client library",
"keywords": [
"client",
"curl",
"framework",
"http",
"http client",
"psr-18",
"psr-7",
"rest",
"web service"
],
"support": {
"issues": "https:\/\/github.com\/guzzle\/guzzle\/issues",
"source": "https:\/\/github.com\/guzzle\/guzzle\/tree\/7.8.0"
},
"funding": [
{
"url": "https:\/\/github.com\/GrahamCampbell",
"type": "github"
},
{
"url": "https:\/\/github.com\/Nyholm",
"type": "github"
},
{
"url": "https:\/\/tidelift.com\/funding\/github\/packagist\/guzzlehttp\/guzzle",
"type": "tidelift"
}
],
"install-path": "..\/guzzlehttp\/guzzle"
},
{
"name": "guzzlehttp\/promises",
"version": "2.0.1",
"version_normalized": "2.0.1.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/guzzle\/promises.git",
"reference": "111166291a0f8130081195ac4556a5587d7f1b5d"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/guzzle\/promises\/zipball\/111166291a0f8130081195ac4556a5587d7f1b5d",
"reference": "111166291a0f8130081195ac4556a5587d7f1b5d",
"shasum": ""
},
"require": {
"php": "^7.2.5 || ^8.0"
},
"require-dev": {
"bamarni\/composer-bin-plugin": "^1.8.1",
"phpunit\/phpunit": "^8.5.29 || ^9.5.23"
},
"time": "2023-08-03T15:11:55+00:00",
"type": "library",
"extra": {
"bamarni-bin": {
"bin-links": true,
"forward-command": false
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Promise\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "Graham Campbell",
"email": "hello@gjcampbell.co.uk",
"homepage": "https:\/\/github.com\/GrahamCampbell"
},
{
"name": "Michael Dowling",
"email": "mtdowling@gmail.com",
"homepage": "https:\/\/github.com\/mtdowling"
},
{
"name": "Tobias Nyholm",
"email": "tobias.nyholm@gmail.com",
"homepage": "https:\/\/github.com\/Nyholm"
},
{
"name": "Tobias Schultze",
"email": "webmaster@tubo-world.de",
"homepage": "https:\/\/github.com\/Tobion"
}
],
"description": "Guzzle promises library",
"keywords": [
"promise"
],
"support": {
"issues": "https:\/\/github.com\/guzzle\/promises\/issues",
"source": "https:\/\/github.com\/guzzle\/promises\/tree\/2.0.1"
},
"funding": [
{
"url": "https:\/\/github.com\/GrahamCampbell",
"type": "github"
},
{
"url": "https:\/\/github.com\/Nyholm",
"type": "github"
},
{
"url": "https:\/\/tidelift.com\/funding\/github\/packagist\/guzzlehttp\/promises",
"type": "tidelift"
}
],
"install-path": "..\/guzzlehttp\/promises"
},
{
"name": "guzzlehttp\/psr7",
"version": "2.6.1",
"version_normalized": "2.6.1.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/guzzle\/psr7.git",
"reference": "be45764272e8873c72dbe3d2edcfdfcc3bc9f727"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/guzzle\/psr7\/zipball\/be45764272e8873c72dbe3d2edcfdfcc3bc9f727",
"reference": "be45764272e8873c72dbe3d2edcfdfcc3bc9f727",
"shasum": ""
},
"require": {
"php": "^7.2.5 || ^8.0",
"psr\/http-factory": "^1.0",
"psr\/http-message": "^1.1 || ^2.0",
"ralouphie\/getallheaders": "^3.0"
},
"provide": {
"psr\/http-factory-implementation": "1.0",
"psr\/http-message-implementation": "1.0"
},
"require-dev": {
"bamarni\/composer-bin-plugin": "^1.8.1",
"http-interop\/http-factory-tests": "^0.9",
"phpunit\/phpunit": "^8.5.29 || ^9.5.23"
},
"suggest": {
"laminas\/laminas-httphandlerrunner": "Emit PSR-7 responses"
},
"time": "2023-08-27T10:13:57+00:00",
"type": "library",
"extra": {
"bamarni-bin": {
"bin-links": true,
"forward-command": false
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\GuzzleHttp\\Psr7\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "Graham Campbell",
"email": "hello@gjcampbell.co.uk",
"homepage": "https:\/\/github.com\/GrahamCampbell"
},
{
"name": "Michael Dowling",
"email": "mtdowling@gmail.com",
"homepage": "https:\/\/github.com\/mtdowling"
},
{
"name": "George Mponos",
"email": "gmponos@gmail.com",
"homepage": "https:\/\/github.com\/gmponos"
},
{
"name": "Tobias Nyholm",
"email": "tobias.nyholm@gmail.com",
"homepage": "https:\/\/github.com\/Nyholm"
},
{
"name": "M\u00e1rk S\u00e1gi-Kaz\u00e1r",
"email": "mark.sagikazar@gmail.com",
"homepage": "https:\/\/github.com\/sagikazarmark"
},
{
"name": "Tobias Schultze",
"email": "webmaster@tubo-world.de",
"homepage": "https:\/\/github.com\/Tobion"
},
{
"name": "M\u00e1rk S\u00e1gi-Kaz\u00e1r",
"email": "mark.sagikazar@gmail.com",
"homepage": "https:\/\/sagikazarmark.hu"
}
],
"description": "PSR-7 message implementation that also provides common utility methods",
"keywords": [
"http",
"message",
"psr-7",
"request",
"response",
"stream",
"uri",
"url"
],
"support": {
"issues": "https:\/\/github.com\/guzzle\/psr7\/issues",
"source": "https:\/\/github.com\/guzzle\/psr7\/tree\/2.6.1"
},
"funding": [
{
"url": "https:\/\/github.com\/GrahamCampbell",
"type": "github"
},
{
"url": "https:\/\/github.com\/Nyholm",
"type": "github"
},
{
"url": "https:\/\/tidelift.com\/funding\/github\/packagist\/guzzlehttp\/psr7",
"type": "tidelift"
}
],
"install-path": "..\/guzzlehttp\/psr7"
},
{
"name": "psr\/http-client",
"version": "1.0.3",
"version_normalized": "1.0.3.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/php-fig\/http-client.git",
"reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/php-fig\/http-client\/zipball\/bb5906edc1c324c9a05aa0873d40117941e5fa90",
"reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90",
"shasum": ""
},
"require": {
"php": "^7.0 || ^8.0",
"psr\/http-message": "^1.0 || ^2.0"
},
"time": "2023-09-23T14:17:50+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.0.x-dev"
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Client\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "PHP-FIG",
"homepage": "https:\/\/www.php-fig.org\/"
}
],
"description": "Common interface for HTTP clients",
"homepage": "https:\/\/github.com\/php-fig\/http-client",
"keywords": [
"http",
"http-client",
"psr",
"psr-18"
],
"support": {
"source": "https:\/\/github.com\/php-fig\/http-client"
},
"install-path": "..\/psr\/http-client"
},
{
"name": "psr\/http-factory",
"version": "1.0.2",
"version_normalized": "1.0.2.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/php-fig\/http-factory.git",
"reference": "e616d01114759c4c489f93b099585439f795fe35"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/php-fig\/http-factory\/zipball\/e616d01114759c4c489f93b099585439f795fe35",
"reference": "e616d01114759c4c489f93b099585439f795fe35",
"shasum": ""
},
"require": {
"php": ">=7.0.0",
"psr\/http-message": "^1.0 || ^2.0"
},
"time": "2023-04-10T20:10:41+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.0.x-dev"
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "PHP-FIG",
"homepage": "https:\/\/www.php-fig.org\/"
}
],
"description": "Common interfaces for PSR-7 HTTP message factories",
"keywords": [
"factory",
"http",
"message",
"psr",
"psr-17",
"psr-7",
"request",
"response"
],
"support": {
"source": "https:\/\/github.com\/php-fig\/http-factory\/tree\/1.0.2"
},
"install-path": "..\/psr\/http-factory"
},
{
"name": "psr\/http-message",
"version": "2.0",
"version_normalized": "2.0.0.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/php-fig\/http-message.git",
"reference": "402d35bcb92c70c026d1a6a9883f06b2ead23d71"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/php-fig\/http-message\/zipball\/402d35bcb92c70c026d1a6a9883f06b2ead23d71",
"reference": "402d35bcb92c70c026d1a6a9883f06b2ead23d71",
"shasum": ""
},
"require": {
"php": "^7.2 || ^8.0"
},
"time": "2023-04-04T09:54:51+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "2.0.x-dev"
}
},
"installation-source": "dist",
"autoload": {
"psr-4": {
"Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\Psr\\Http\\Message\\": "src\/"
}
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "PHP-FIG",
"homepage": "https:\/\/www.php-fig.org\/"
}
],
"description": "Common interface for HTTP messages",
"homepage": "https:\/\/github.com\/php-fig\/http-message",
"keywords": [
"http",
"http-message",
"psr",
"psr-7",
"request",
"response"
],
"support": {
"source": "https:\/\/github.com\/php-fig\/http-message\/tree\/2.0"
},
"install-path": "..\/psr\/http-message"
},
{
"name": "ralouphie\/getallheaders",
"version": "3.0.3",
"version_normalized": "3.0.3.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/ralouphie\/getallheaders.git",
"reference": "120b605dfeb996808c31b6477290a714d356e822"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/ralouphie\/getallheaders\/zipball\/120b605dfeb996808c31b6477290a714d356e822",
"reference": "120b605dfeb996808c31b6477290a714d356e822",
"shasum": ""
},
"require": {
"php": ">=5.6"
},
"require-dev": {
"php-coveralls\/php-coveralls": "^2.1",
"phpunit\/phpunit": "^5 || ^6.5"
},
"time": "2019-03-08T08:55:37+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"files": [
"src\/getallheaders.php"
]
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "Ralph Khattar",
"email": "ralph.khattar@gmail.com"
}
],
"description": "A polyfill for getallheaders.",
"support": {
"issues": "https:\/\/github.com\/ralouphie\/getallheaders\/issues",
"source": "https:\/\/github.com\/ralouphie\/getallheaders\/tree\/develop"
},
"install-path": "..\/ralouphie\/getallheaders"
},
{
"name": "symfony\/deprecation-contracts",
"version": "v2.5.2",
"version_normalized": "2.5.2.0",
"source": {
"type": "git",
"url": "https:\/\/github.com\/symfony\/deprecation-contracts.git",
"reference": "e8b495ea28c1d97b5e0c121748d6f9b53d075c66"
},
"dist": {
"type": "zip",
"url": "https:\/\/api.github.com\/repos\/symfony\/deprecation-contracts\/zipball\/e8b495ea28c1d97b5e0c121748d6f9b53d075c66",
"reference": "e8b495ea28c1d97b5e0c121748d6f9b53d075c66",
"shasum": ""
},
"require": {
"php": ">=7.1"
},
"time": "2022-01-02T09:53:40+00:00",
"type": "library",
"extra": {
"branch-alias": {
"dev-main": "2.5-dev"
},
"thanks": {
"name": "symfony\/contracts",
"url": "https:\/\/github.com\/symfony\/contracts"
}
},
"installation-source": "dist",
"autoload": {
"files": [
"function.php"
]
},
"notification-url": "https:\/\/packagist.org\/downloads\/",
"license": [
"MIT"
],
"authors": [
{
"name": "Nicolas Grekas",
"email": "p@tchwork.com"
},
{
"name": "Symfony Community",
"homepage": "https:\/\/symfony.com\/contributors"
}
],
"description": "A generic function and convention to trigger deprecation notices",
"homepage": "https:\/\/symfony.com",
"support": {
"source": "https:\/\/github.com\/symfony\/deprecation-contracts\/tree\/v2.5.2"
},
"funding": [
{
"url": "https:\/\/symfony.com\/sponsor",
"type": "custom"
},
{
"url": "https:\/\/github.com\/fabpot",
"type": "github"
},
{
"url": "https:\/\/tidelift.com\/funding\/github\/packagist\/symfony\/symfony",
"type": "tidelift"
}
],
"install-path": "..\/symfony\/deprecation-contracts"
}
],
"dev": true,
"dev-package-names": []
}

View File

@@ -0,0 +1,5 @@
<?php
namespace {
return array('root' => array('name' => '__root__', 'pretty_version' => 'dev-master', 'version' => 'dev-master', 'reference' => '3d9fa6ac01f71728ea3faffb4a5401c39161177d', 'type' => 'library', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), 'dev' => \true), 'versions' => array('__root__' => array('pretty_version' => 'dev-master', 'version' => 'dev-master', 'reference' => '3d9fa6ac01f71728ea3faffb4a5401c39161177d', 'type' => 'library', 'install_path' => __DIR__ . '/../../', 'aliases' => array(), 'dev_requirement' => \false), 'br33f/php-ga4-mp' => array('pretty_version' => 'v0.1.2', 'version' => '0.1.2.0', 'reference' => 'e9b95e5b0cf4daf05c3739d989867f1103835acb', 'type' => 'library', 'install_path' => __DIR__ . '/../br33f/php-ga4-mp', 'aliases' => array(), 'dev_requirement' => \false), 'guzzlehttp/guzzle' => array('pretty_version' => '7.8.0', 'version' => '7.8.0.0', 'reference' => '1110f66a6530a40fe7aea0378fe608ee2b2248f9', 'type' => 'library', 'install_path' => __DIR__ . '/../guzzlehttp/guzzle', 'aliases' => array(), 'dev_requirement' => \false), 'guzzlehttp/promises' => array('pretty_version' => '2.0.1', 'version' => '2.0.1.0', 'reference' => '111166291a0f8130081195ac4556a5587d7f1b5d', 'type' => 'library', 'install_path' => __DIR__ . '/../guzzlehttp/promises', 'aliases' => array(), 'dev_requirement' => \false), 'guzzlehttp/psr7' => array('pretty_version' => '2.6.1', 'version' => '2.6.1.0', 'reference' => 'be45764272e8873c72dbe3d2edcfdfcc3bc9f727', 'type' => 'library', 'install_path' => __DIR__ . '/../guzzlehttp/psr7', 'aliases' => array(), 'dev_requirement' => \false), 'psr/http-client' => array('pretty_version' => '1.0.3', 'version' => '1.0.3.0', 'reference' => 'bb5906edc1c324c9a05aa0873d40117941e5fa90', 'type' => 'library', 'install_path' => __DIR__ . '/../psr/http-client', 'aliases' => array(), 'dev_requirement' => \false), 'psr/http-client-implementation' => array('dev_requirement' => \false, 'provided' => array(0 => '1.0')), 'psr/http-factory' => array('pretty_version' => '1.0.2', 'version' => '1.0.2.0', 'reference' => 'e616d01114759c4c489f93b099585439f795fe35', 'type' => 'library', 'install_path' => __DIR__ . '/../psr/http-factory', 'aliases' => array(), 'dev_requirement' => \false), 'psr/http-factory-implementation' => array('dev_requirement' => \false, 'provided' => array(0 => '1.0')), 'psr/http-message' => array('pretty_version' => '2.0', 'version' => '2.0.0.0', 'reference' => '402d35bcb92c70c026d1a6a9883f06b2ead23d71', 'type' => 'library', 'install_path' => __DIR__ . '/../psr/http-message', 'aliases' => array(), 'dev_requirement' => \false), 'psr/http-message-implementation' => array('dev_requirement' => \false, 'provided' => array(0 => '1.0')), 'ralouphie/getallheaders' => array('pretty_version' => '3.0.3', 'version' => '3.0.3.0', 'reference' => '120b605dfeb996808c31b6477290a714d356e822', 'type' => 'library', 'install_path' => __DIR__ . '/../ralouphie/getallheaders', 'aliases' => array(), 'dev_requirement' => \false), 'symfony/deprecation-contracts' => array('pretty_version' => 'v2.5.2', 'version' => '2.5.2.0', 'reference' => 'e8b495ea28c1d97b5e0c121748d6f9b53d075c66', 'type' => 'library', 'install_path' => __DIR__ . '/../symfony/deprecation-contracts', 'aliases' => array(), 'dev_requirement' => \false)));
}

View File

@@ -0,0 +1,26 @@
<?php
// platform_check.php @generated by Composer
$issues = array();
if (!(PHP_VERSION_ID >= 70205)) {
$issues[] = 'Your Composer dependencies require a PHP version ">= 7.2.5". You are running ' . PHP_VERSION . '.';
}
if ($issues) {
if (!headers_sent()) {
header('HTTP/1.1 500 Internal Server Error');
}
if (!ini_get('display_errors')) {
if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
fwrite(STDERR, 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . implode(PHP_EOL, $issues) . PHP_EOL.PHP_EOL);
} elseif (!headers_sent()) {
echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL;
}
}
trigger_error(
'Composer detected issues in your platform: ' . implode(' ', $issues),
E_USER_ERROR
);
}

View File

@@ -0,0 +1,23 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\MessageInterface;
final class BodySummarizer implements BodySummarizerInterface
{
/**
* @var int|null
*/
private $truncateAt;
public function __construct(int $truncateAt = null)
{
$this->truncateAt = $truncateAt;
}
/**
* Returns a summarized message body.
*/
public function summarize(MessageInterface $message) : ?string
{
return $this->truncateAt === null ? \Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7\Message::bodySummary($message) : \Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7\Message::bodySummary($message, $this->truncateAt);
}
}

View File

@@ -0,0 +1,12 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\MessageInterface;
interface BodySummarizerInterface
{
/**
* Returns a summarized message body.
*/
public function summarize(MessageInterface $message) : ?string;
}

View File

@@ -0,0 +1,402 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie\CookieJar;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\GuzzleException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\InvalidArgumentException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\UriInterface;
/**
* @final
*/
class Client implements ClientInterface, \Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Client\ClientInterface
{
use ClientTrait;
/**
* @var array Default request options
*/
private $config;
/**
* Clients accept an array of constructor parameters.
*
* Here's an example of creating a client using a base_uri and an array of
* default request options to apply to each request:
*
* $client = new Client([
* 'base_uri' => 'http://www.foo.com/1.0/',
* 'timeout' => 0,
* 'allow_redirects' => false,
* 'proxy' => '192.168.16.1:10'
* ]);
*
* Client configuration settings include the following options:
*
* - handler: (callable) Function that transfers HTTP requests over the
* wire. The function is called with a Psr7\Http\Message\RequestInterface
* and array of transfer options, and must return a
* GuzzleHttp\Promise\PromiseInterface that is fulfilled with a
* Psr7\Http\Message\ResponseInterface on success.
* If no handler is provided, a default handler will be created
* that enables all of the request options below by attaching all of the
* default middleware to the handler.
* - base_uri: (string|UriInterface) Base URI of the client that is merged
* into relative URIs. Can be a string or instance of UriInterface.
* - **: any request option
*
* @param array $config Client configuration settings.
*
* @see \GuzzleHttp\RequestOptions for a list of available request options.
*/
public function __construct(array $config = [])
{
if (!isset($config['handler'])) {
$config['handler'] = HandlerStack::create();
} elseif (!\is_callable($config['handler'])) {
throw new InvalidArgumentException('handler must be a callable');
}
// Convert the base_uri to a UriInterface
if (isset($config['base_uri'])) {
$config['base_uri'] = Psr7\Utils::uriFor($config['base_uri']);
}
$this->configureDefaults($config);
}
/**
* @param string $method
* @param array $args
*
* @return PromiseInterface|ResponseInterface
*
* @deprecated Client::__call will be removed in guzzlehttp/guzzle:8.0.
*/
public function __call($method, $args)
{
if (\count($args) < 1) {
throw new InvalidArgumentException('Magic request methods require a URI and optional options array');
}
$uri = $args[0];
$opts = $args[1] ?? [];
return \substr($method, -5) === 'Async' ? $this->requestAsync(\substr($method, 0, -5), $uri, $opts) : $this->request($method, $uri, $opts);
}
/**
* Asynchronously send an HTTP request.
*
* @param array $options Request options to apply to the given
* request and to the transfer. See \GuzzleHttp\RequestOptions.
*/
public function sendAsync(RequestInterface $request, array $options = []) : PromiseInterface
{
// Merge the base URI into the request URI if needed.
$options = $this->prepareDefaults($options);
return $this->transfer($request->withUri($this->buildUri($request->getUri(), $options), $request->hasHeader('Host')), $options);
}
/**
* Send an HTTP request.
*
* @param array $options Request options to apply to the given
* request and to the transfer. See \GuzzleHttp\RequestOptions.
*
* @throws GuzzleException
*/
public function send(RequestInterface $request, array $options = []) : ResponseInterface
{
$options[RequestOptions::SYNCHRONOUS] = \true;
return $this->sendAsync($request, $options)->wait();
}
/**
* The HttpClient PSR (PSR-18) specify this method.
*
* {@inheritDoc}
*/
public function sendRequest(RequestInterface $request) : ResponseInterface
{
$options[RequestOptions::SYNCHRONOUS] = \true;
$options[RequestOptions::ALLOW_REDIRECTS] = \false;
$options[RequestOptions::HTTP_ERRORS] = \false;
return $this->sendAsync($request, $options)->wait();
}
/**
* Create and send an asynchronous HTTP request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string $method HTTP method
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply. See \GuzzleHttp\RequestOptions.
*/
public function requestAsync(string $method, $uri = '', array $options = []) : PromiseInterface
{
$options = $this->prepareDefaults($options);
// Remove request modifying parameter because it can be done up-front.
$headers = $options['headers'] ?? [];
$body = $options['body'] ?? null;
$version = $options['version'] ?? '1.1';
// Merge the URI into the base URI.
$uri = $this->buildUri(Psr7\Utils::uriFor($uri), $options);
if (\is_array($body)) {
throw $this->invalidBody();
}
$request = new Psr7\Request($method, $uri, $headers, $body, $version);
// Remove the option so that they are not doubly-applied.
unset($options['headers'], $options['body'], $options['version']);
return $this->transfer($request, $options);
}
/**
* Create and send an HTTP request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string $method HTTP method.
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply. See \GuzzleHttp\RequestOptions.
*
* @throws GuzzleException
*/
public function request(string $method, $uri = '', array $options = []) : ResponseInterface
{
$options[RequestOptions::SYNCHRONOUS] = \true;
return $this->requestAsync($method, $uri, $options)->wait();
}
/**
* Get a client configuration option.
*
* These options include default request options of the client, a "handler"
* (if utilized by the concrete client), and a "base_uri" if utilized by
* the concrete client.
*
* @param string|null $option The config option to retrieve.
*
* @return mixed
*
* @deprecated Client::getConfig will be removed in guzzlehttp/guzzle:8.0.
*/
public function getConfig(string $option = null)
{
return $option === null ? $this->config : $this->config[$option] ?? null;
}
private function buildUri(UriInterface $uri, array $config) : UriInterface
{
if (isset($config['base_uri'])) {
$uri = Psr7\UriResolver::resolve(Psr7\Utils::uriFor($config['base_uri']), $uri);
}
if (isset($config['idn_conversion']) && $config['idn_conversion'] !== \false) {
$idnOptions = $config['idn_conversion'] === \true ? \IDNA_DEFAULT : $config['idn_conversion'];
$uri = Utils::idnUriConvert($uri, $idnOptions);
}
return $uri->getScheme() === '' && $uri->getHost() !== '' ? $uri->withScheme('http') : $uri;
}
/**
* Configures the default options for a client.
*/
private function configureDefaults(array $config) : void
{
$defaults = ['allow_redirects' => RedirectMiddleware::$defaultSettings, 'http_errors' => \true, 'decode_content' => \true, 'verify' => \true, 'cookies' => \false, 'idn_conversion' => \false];
// Use the standard Linux HTTP_PROXY and HTTPS_PROXY if set.
// We can only trust the HTTP_PROXY environment variable in a CLI
// process due to the fact that PHP has no reliable mechanism to
// get environment variables that start with "HTTP_".
if (\PHP_SAPI === 'cli' && ($proxy = Utils::getenv('HTTP_PROXY'))) {
$defaults['proxy']['http'] = $proxy;
}
if ($proxy = Utils::getenv('HTTPS_PROXY')) {
$defaults['proxy']['https'] = $proxy;
}
if ($noProxy = Utils::getenv('NO_PROXY')) {
$cleanedNoProxy = \str_replace(' ', '', $noProxy);
$defaults['proxy']['no'] = \explode(',', $cleanedNoProxy);
}
$this->config = $config + $defaults;
if (!empty($config['cookies']) && $config['cookies'] === \true) {
$this->config['cookies'] = new CookieJar();
}
// Add the default user-agent header.
if (!isset($this->config['headers'])) {
$this->config['headers'] = ['User-Agent' => Utils::defaultUserAgent()];
} else {
// Add the User-Agent header if one was not already set.
foreach (\array_keys($this->config['headers']) as $name) {
if (\strtolower($name) === 'user-agent') {
return;
}
}
$this->config['headers']['User-Agent'] = Utils::defaultUserAgent();
}
}
/**
* Merges default options into the array.
*
* @param array $options Options to modify by reference
*/
private function prepareDefaults(array $options) : array
{
$defaults = $this->config;
if (!empty($defaults['headers'])) {
// Default headers are only added if they are not present.
$defaults['_conditional'] = $defaults['headers'];
unset($defaults['headers']);
}
// Special handling for headers is required as they are added as
// conditional headers and as headers passed to a request ctor.
if (\array_key_exists('headers', $options)) {
// Allows default headers to be unset.
if ($options['headers'] === null) {
$defaults['_conditional'] = [];
unset($options['headers']);
} elseif (!\is_array($options['headers'])) {
throw new InvalidArgumentException('headers must be an array');
}
}
// Shallow merge defaults underneath options.
$result = $options + $defaults;
// Remove null values.
foreach ($result as $k => $v) {
if ($v === null) {
unset($result[$k]);
}
}
return $result;
}
/**
* Transfers the given request and applies request options.
*
* The URI of the request is not modified and the request options are used
* as-is without merging in default options.
*
* @param array $options See \GuzzleHttp\RequestOptions.
*/
private function transfer(RequestInterface $request, array $options) : PromiseInterface
{
$request = $this->applyOptions($request, $options);
/** @var HandlerStack $handler */
$handler = $options['handler'];
try {
return P\Create::promiseFor($handler($request, $options));
} catch (\Exception $e) {
return P\Create::rejectionFor($e);
}
}
/**
* Applies the array of request options to a request.
*/
private function applyOptions(RequestInterface $request, array &$options) : RequestInterface
{
$modify = ['set_headers' => []];
if (isset($options['headers'])) {
if (\array_keys($options['headers']) === \range(0, \count($options['headers']) - 1)) {
throw new InvalidArgumentException('The headers array must have header name as keys.');
}
$modify['set_headers'] = $options['headers'];
unset($options['headers']);
}
if (isset($options['form_params'])) {
if (isset($options['multipart'])) {
throw new InvalidArgumentException('You cannot use ' . 'form_params and multipart at the same time. Use the ' . 'form_params option if you want to send application/' . 'x-www-form-urlencoded requests, and the multipart ' . 'option to send multipart/form-data requests.');
}
$options['body'] = \http_build_query($options['form_params'], '', '&');
unset($options['form_params']);
// Ensure that we don't have the header in different case and set the new value.
$options['_conditional'] = Psr7\Utils::caselessRemove(['Content-Type'], $options['_conditional']);
$options['_conditional']['Content-Type'] = 'application/x-www-form-urlencoded';
}
if (isset($options['multipart'])) {
$options['body'] = new Psr7\MultipartStream($options['multipart']);
unset($options['multipart']);
}
if (isset($options['json'])) {
$options['body'] = Utils::jsonEncode($options['json']);
unset($options['json']);
// Ensure that we don't have the header in different case and set the new value.
$options['_conditional'] = Psr7\Utils::caselessRemove(['Content-Type'], $options['_conditional']);
$options['_conditional']['Content-Type'] = 'application/json';
}
if (!empty($options['decode_content']) && $options['decode_content'] !== \true) {
// Ensure that we don't have the header in different case and set the new value.
$options['_conditional'] = Psr7\Utils::caselessRemove(['Accept-Encoding'], $options['_conditional']);
$modify['set_headers']['Accept-Encoding'] = $options['decode_content'];
}
if (isset($options['body'])) {
if (\is_array($options['body'])) {
throw $this->invalidBody();
}
$modify['body'] = Psr7\Utils::streamFor($options['body']);
unset($options['body']);
}
if (!empty($options['auth']) && \is_array($options['auth'])) {
$value = $options['auth'];
$type = isset($value[2]) ? \strtolower($value[2]) : 'basic';
switch ($type) {
case 'basic':
// Ensure that we don't have the header in different case and set the new value.
$modify['set_headers'] = Psr7\Utils::caselessRemove(['Authorization'], $modify['set_headers']);
$modify['set_headers']['Authorization'] = 'Basic ' . \base64_encode("{$value[0]}:{$value[1]}");
break;
case 'digest':
// @todo: Do not rely on curl
$options['curl'][\CURLOPT_HTTPAUTH] = \CURLAUTH_DIGEST;
$options['curl'][\CURLOPT_USERPWD] = "{$value[0]}:{$value[1]}";
break;
case 'ntlm':
$options['curl'][\CURLOPT_HTTPAUTH] = \CURLAUTH_NTLM;
$options['curl'][\CURLOPT_USERPWD] = "{$value[0]}:{$value[1]}";
break;
}
}
if (isset($options['query'])) {
$value = $options['query'];
if (\is_array($value)) {
$value = \http_build_query($value, '', '&', \PHP_QUERY_RFC3986);
}
if (!\is_string($value)) {
throw new InvalidArgumentException('query must be a string or array');
}
$modify['query'] = $value;
unset($options['query']);
}
// Ensure that sink is not an invalid value.
if (isset($options['sink'])) {
// TODO: Add more sink validation?
if (\is_bool($options['sink'])) {
throw new InvalidArgumentException('sink must not be a boolean');
}
}
if (isset($options['version'])) {
$modify['version'] = $options['version'];
}
$request = Psr7\Utils::modifyRequest($request, $modify);
if ($request->getBody() instanceof Psr7\MultipartStream) {
// Use a multipart/form-data POST if a Content-Type is not set.
// Ensure that we don't have the header in different case and set the new value.
$options['_conditional'] = Psr7\Utils::caselessRemove(['Content-Type'], $options['_conditional']);
$options['_conditional']['Content-Type'] = 'multipart/form-data; boundary=' . $request->getBody()->getBoundary();
}
// Merge in conditional headers if they are not present.
if (isset($options['_conditional'])) {
// Build up the changes so it's in a single clone of the message.
$modify = [];
foreach ($options['_conditional'] as $k => $v) {
if (!$request->hasHeader($k)) {
$modify['set_headers'][$k] = $v;
}
}
$request = Psr7\Utils::modifyRequest($request, $modify);
// Don't pass this internal value along to middleware/handlers.
unset($options['_conditional']);
}
return $request;
}
/**
* Return an InvalidArgumentException with pre-set message.
*/
private function invalidBody() : InvalidArgumentException
{
return new InvalidArgumentException('Passing in the "body" request ' . 'option as an array to send a request is not supported. ' . 'Please use the "form_params" request option to send a ' . 'application/x-www-form-urlencoded request, or the "multipart" ' . 'request option to send a multipart/form-data request.');
}
}

View File

@@ -0,0 +1,78 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\GuzzleException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\UriInterface;
/**
* Client interface for sending HTTP requests.
*/
interface ClientInterface
{
/**
* The Guzzle major version.
*/
public const MAJOR_VERSION = 7;
/**
* Send an HTTP request.
*
* @param RequestInterface $request Request to send
* @param array $options Request options to apply to the given
* request and to the transfer.
*
* @throws GuzzleException
*/
public function send(RequestInterface $request, array $options = []) : ResponseInterface;
/**
* Asynchronously send an HTTP request.
*
* @param RequestInterface $request Request to send
* @param array $options Request options to apply to the given
* request and to the transfer.
*/
public function sendAsync(RequestInterface $request, array $options = []) : PromiseInterface;
/**
* Create and send an HTTP request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string $method HTTP method.
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function request(string $method, $uri, array $options = []) : ResponseInterface;
/**
* Create and send an asynchronous HTTP request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string $method HTTP method
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function requestAsync(string $method, $uri, array $options = []) : PromiseInterface;
/**
* Get a client configuration option.
*
* These options include default request options of the client, a "handler"
* (if utilized by the concrete client), and a "base_uri" if utilized by
* the concrete client.
*
* @param string|null $option The config option to retrieve.
*
* @return mixed
*
* @deprecated ClientInterface::getConfig will be removed in guzzlehttp/guzzle:8.0.
*/
public function getConfig(string $option = null);
}

View File

@@ -0,0 +1,227 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\GuzzleException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\UriInterface;
/**
* Client interface for sending HTTP requests.
*/
trait ClientTrait
{
/**
* Create and send an HTTP request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string $method HTTP method.
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public abstract function request(string $method, $uri, array $options = []) : ResponseInterface;
/**
* Create and send an HTTP GET request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function get($uri, array $options = []) : ResponseInterface
{
return $this->request('GET', $uri, $options);
}
/**
* Create and send an HTTP HEAD request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function head($uri, array $options = []) : ResponseInterface
{
return $this->request('HEAD', $uri, $options);
}
/**
* Create and send an HTTP PUT request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function put($uri, array $options = []) : ResponseInterface
{
return $this->request('PUT', $uri, $options);
}
/**
* Create and send an HTTP POST request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function post($uri, array $options = []) : ResponseInterface
{
return $this->request('POST', $uri, $options);
}
/**
* Create and send an HTTP PATCH request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function patch($uri, array $options = []) : ResponseInterface
{
return $this->request('PATCH', $uri, $options);
}
/**
* Create and send an HTTP DELETE request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*
* @throws GuzzleException
*/
public function delete($uri, array $options = []) : ResponseInterface
{
return $this->request('DELETE', $uri, $options);
}
/**
* Create and send an asynchronous HTTP request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string $method HTTP method
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public abstract function requestAsync(string $method, $uri, array $options = []) : PromiseInterface;
/**
* Create and send an asynchronous HTTP GET request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function getAsync($uri, array $options = []) : PromiseInterface
{
return $this->requestAsync('GET', $uri, $options);
}
/**
* Create and send an asynchronous HTTP HEAD request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function headAsync($uri, array $options = []) : PromiseInterface
{
return $this->requestAsync('HEAD', $uri, $options);
}
/**
* Create and send an asynchronous HTTP PUT request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function putAsync($uri, array $options = []) : PromiseInterface
{
return $this->requestAsync('PUT', $uri, $options);
}
/**
* Create and send an asynchronous HTTP POST request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function postAsync($uri, array $options = []) : PromiseInterface
{
return $this->requestAsync('POST', $uri, $options);
}
/**
* Create and send an asynchronous HTTP PATCH request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function patchAsync($uri, array $options = []) : PromiseInterface
{
return $this->requestAsync('PATCH', $uri, $options);
}
/**
* Create and send an asynchronous HTTP DELETE request.
*
* Use an absolute path to override the base path of the client, or a
* relative path to append to the base path of the client. The URL can
* contain the query string as well. Use an array to provide a URL
* template and additional variables to use in the URL template expansion.
*
* @param string|UriInterface $uri URI object or string.
* @param array $options Request options to apply.
*/
public function deleteAsync($uri, array $options = []) : PromiseInterface
{
return $this->requestAsync('DELETE', $uri, $options);
}
}

View File

@@ -0,0 +1,240 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
/**
* Cookie jar that stores cookies as an array
*/
class CookieJar implements CookieJarInterface
{
/**
* @var SetCookie[] Loaded cookie data
*/
private $cookies = [];
/**
* @var bool
*/
private $strictMode;
/**
* @param bool $strictMode Set to true to throw exceptions when invalid
* cookies are added to the cookie jar.
* @param array $cookieArray Array of SetCookie objects or a hash of
* arrays that can be used with the SetCookie
* constructor
*/
public function __construct(bool $strictMode = \false, array $cookieArray = [])
{
$this->strictMode = $strictMode;
foreach ($cookieArray as $cookie) {
if (!$cookie instanceof SetCookie) {
$cookie = new SetCookie($cookie);
}
$this->setCookie($cookie);
}
}
/**
* Create a new Cookie jar from an associative array and domain.
*
* @param array $cookies Cookies to create the jar from
* @param string $domain Domain to set the cookies to
*/
public static function fromArray(array $cookies, string $domain) : self
{
$cookieJar = new self();
foreach ($cookies as $name => $value) {
$cookieJar->setCookie(new SetCookie(['Domain' => $domain, 'Name' => $name, 'Value' => $value, 'Discard' => \true]));
}
return $cookieJar;
}
/**
* Evaluate if this cookie should be persisted to storage
* that survives between requests.
*
* @param SetCookie $cookie Being evaluated.
* @param bool $allowSessionCookies If we should persist session cookies
*/
public static function shouldPersist(SetCookie $cookie, bool $allowSessionCookies = \false) : bool
{
if ($cookie->getExpires() || $allowSessionCookies) {
if (!$cookie->getDiscard()) {
return \true;
}
}
return \false;
}
/**
* Finds and returns the cookie based on the name
*
* @param string $name cookie name to search for
*
* @return SetCookie|null cookie that was found or null if not found
*/
public function getCookieByName(string $name) : ?SetCookie
{
foreach ($this->cookies as $cookie) {
if ($cookie->getName() !== null && \strcasecmp($cookie->getName(), $name) === 0) {
return $cookie;
}
}
return null;
}
public function toArray() : array
{
return \array_map(static function (SetCookie $cookie) : array {
return $cookie->toArray();
}, $this->getIterator()->getArrayCopy());
}
public function clear(string $domain = null, string $path = null, string $name = null) : void
{
if (!$domain) {
$this->cookies = [];
return;
} elseif (!$path) {
$this->cookies = \array_filter($this->cookies, static function (SetCookie $cookie) use($domain) : bool {
return !$cookie->matchesDomain($domain);
});
} elseif (!$name) {
$this->cookies = \array_filter($this->cookies, static function (SetCookie $cookie) use($path, $domain) : bool {
return !($cookie->matchesPath($path) && $cookie->matchesDomain($domain));
});
} else {
$this->cookies = \array_filter($this->cookies, static function (SetCookie $cookie) use($path, $domain, $name) {
return !($cookie->getName() == $name && $cookie->matchesPath($path) && $cookie->matchesDomain($domain));
});
}
}
public function clearSessionCookies() : void
{
$this->cookies = \array_filter($this->cookies, static function (SetCookie $cookie) : bool {
return !$cookie->getDiscard() && $cookie->getExpires();
});
}
public function setCookie(SetCookie $cookie) : bool
{
// If the name string is empty (but not 0), ignore the set-cookie
// string entirely.
$name = $cookie->getName();
if (!$name && $name !== '0') {
return \false;
}
// Only allow cookies with set and valid domain, name, value
$result = $cookie->validate();
if ($result !== \true) {
if ($this->strictMode) {
throw new \RuntimeException('Invalid cookie: ' . $result);
}
$this->removeCookieIfEmpty($cookie);
return \false;
}
// Resolve conflicts with previously set cookies
foreach ($this->cookies as $i => $c) {
// Two cookies are identical, when their path, and domain are
// identical.
if ($c->getPath() != $cookie->getPath() || $c->getDomain() != $cookie->getDomain() || $c->getName() != $cookie->getName()) {
continue;
}
// The previously set cookie is a discard cookie and this one is
// not so allow the new cookie to be set
if (!$cookie->getDiscard() && $c->getDiscard()) {
unset($this->cookies[$i]);
continue;
}
// If the new cookie's expiration is further into the future, then
// replace the old cookie
if ($cookie->getExpires() > $c->getExpires()) {
unset($this->cookies[$i]);
continue;
}
// If the value has changed, we better change it
if ($cookie->getValue() !== $c->getValue()) {
unset($this->cookies[$i]);
continue;
}
// The cookie exists, so no need to continue
return \false;
}
$this->cookies[] = $cookie;
return \true;
}
public function count() : int
{
return \count($this->cookies);
}
/**
* @return \ArrayIterator<int, SetCookie>
*/
public function getIterator() : \ArrayIterator
{
return new \ArrayIterator(\array_values($this->cookies));
}
public function extractCookies(RequestInterface $request, ResponseInterface $response) : void
{
if ($cookieHeader = $response->getHeader('Set-Cookie')) {
foreach ($cookieHeader as $cookie) {
$sc = SetCookie::fromString($cookie);
if (!$sc->getDomain()) {
$sc->setDomain($request->getUri()->getHost());
}
if (0 !== \strpos($sc->getPath(), '/')) {
$sc->setPath($this->getCookiePathFromRequest($request));
}
if (!$sc->matchesDomain($request->getUri()->getHost())) {
continue;
}
// Note: At this point `$sc->getDomain()` being a public suffix should
// be rejected, but we don't want to pull in the full PSL dependency.
$this->setCookie($sc);
}
}
}
/**
* Computes cookie path following RFC 6265 section 5.1.4
*
* @see https://tools.ietf.org/html/rfc6265#section-5.1.4
*/
private function getCookiePathFromRequest(RequestInterface $request) : string
{
$uriPath = $request->getUri()->getPath();
if ('' === $uriPath) {
return '/';
}
if (0 !== \strpos($uriPath, '/')) {
return '/';
}
if ('/' === $uriPath) {
return '/';
}
$lastSlashPos = \strrpos($uriPath, '/');
if (0 === $lastSlashPos || \false === $lastSlashPos) {
return '/';
}
return \substr($uriPath, 0, $lastSlashPos);
}
public function withCookieHeader(RequestInterface $request) : RequestInterface
{
$values = [];
$uri = $request->getUri();
$scheme = $uri->getScheme();
$host = $uri->getHost();
$path = $uri->getPath() ?: '/';
foreach ($this->cookies as $cookie) {
if ($cookie->matchesPath($path) && $cookie->matchesDomain($host) && !$cookie->isExpired() && (!$cookie->getSecure() || $scheme === 'https')) {
$values[] = $cookie->getName() . '=' . $cookie->getValue();
}
}
return $values ? $request->withHeader('Cookie', \implode('; ', $values)) : $request;
}
/**
* If a cookie already exists and the server asks to set it again with a
* null value, the cookie must be deleted.
*/
private function removeCookieIfEmpty(SetCookie $cookie) : void
{
$cookieValue = $cookie->getValue();
if ($cookieValue === null || $cookieValue === '') {
$this->clear($cookie->getDomain(), $cookie->getPath(), $cookie->getName());
}
}
}

View File

@@ -0,0 +1,74 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
/**
* Stores HTTP cookies.
*
* It extracts cookies from HTTP requests, and returns them in HTTP responses.
* CookieJarInterface instances automatically expire contained cookies when
* necessary. Subclasses are also responsible for storing and retrieving
* cookies from a file, database, etc.
*
* @see https://docs.python.org/2/library/cookielib.html Inspiration
*
* @extends \IteratorAggregate<SetCookie>
*/
interface CookieJarInterface extends \Countable, \IteratorAggregate
{
/**
* Create a request with added cookie headers.
*
* If no matching cookies are found in the cookie jar, then no Cookie
* header is added to the request and the same request is returned.
*
* @param RequestInterface $request Request object to modify.
*
* @return RequestInterface returns the modified request.
*/
public function withCookieHeader(RequestInterface $request) : RequestInterface;
/**
* Extract cookies from an HTTP response and store them in the CookieJar.
*
* @param RequestInterface $request Request that was sent
* @param ResponseInterface $response Response that was received
*/
public function extractCookies(RequestInterface $request, ResponseInterface $response) : void;
/**
* Sets a cookie in the cookie jar.
*
* @param SetCookie $cookie Cookie to set.
*
* @return bool Returns true on success or false on failure
*/
public function setCookie(SetCookie $cookie) : bool;
/**
* Remove cookies currently held in the cookie jar.
*
* Invoking this method without arguments will empty the whole cookie jar.
* If given a $domain argument only cookies belonging to that domain will
* be removed. If given a $domain and $path argument, cookies belonging to
* the specified path within that domain are removed. If given all three
* arguments, then the cookie with the specified name, path and domain is
* removed.
*
* @param string|null $domain Clears cookies matching a domain
* @param string|null $path Clears cookies matching a domain and path
* @param string|null $name Clears cookies matching a domain, path, and name
*/
public function clear(string $domain = null, string $path = null, string $name = null) : void;
/**
* Discard all sessions cookies.
*
* Removes cookies that don't have an expire field or a have a discard
* field set to true. To be called when the user agent shuts down according
* to RFC 2965.
*/
public function clearSessionCookies() : void;
/**
* Converts the cookie jar to an array.
*/
public function toArray() : array;
}

View File

@@ -0,0 +1,92 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
/**
* Persists non-session cookies using a JSON formatted file
*/
class FileCookieJar extends CookieJar
{
/**
* @var string filename
*/
private $filename;
/**
* @var bool Control whether to persist session cookies or not.
*/
private $storeSessionCookies;
/**
* Create a new FileCookieJar object
*
* @param string $cookieFile File to store the cookie data
* @param bool $storeSessionCookies Set to true to store session cookies
* in the cookie jar.
*
* @throws \RuntimeException if the file cannot be found or created
*/
public function __construct(string $cookieFile, bool $storeSessionCookies = \false)
{
parent::__construct();
$this->filename = $cookieFile;
$this->storeSessionCookies = $storeSessionCookies;
if (\file_exists($cookieFile)) {
$this->load($cookieFile);
}
}
/**
* Saves the file when shutting down
*/
public function __destruct()
{
$this->save($this->filename);
}
/**
* Saves the cookies to a file.
*
* @param string $filename File to save
*
* @throws \RuntimeException if the file cannot be found or created
*/
public function save(string $filename) : void
{
$json = [];
/** @var SetCookie $cookie */
foreach ($this as $cookie) {
if (CookieJar::shouldPersist($cookie, $this->storeSessionCookies)) {
$json[] = $cookie->toArray();
}
}
$jsonStr = Utils::jsonEncode($json);
if (\false === \file_put_contents($filename, $jsonStr, \LOCK_EX)) {
throw new \RuntimeException("Unable to save file {$filename}");
}
}
/**
* Load cookies from a JSON formatted file.
*
* Old cookies are kept unless overwritten by newly loaded ones.
*
* @param string $filename Cookie file to load.
*
* @throws \RuntimeException if the file cannot be loaded.
*/
public function load(string $filename) : void
{
$json = \file_get_contents($filename);
if (\false === $json) {
throw new \RuntimeException("Unable to load file {$filename}");
}
if ($json === '') {
return;
}
$data = Utils::jsonDecode($json, \true);
if (\is_array($data)) {
foreach ($data as $cookie) {
$this->setCookie(new SetCookie($cookie));
}
} elseif (\is_scalar($data) && !empty($data)) {
throw new \RuntimeException("Invalid cookie file: {$filename}");
}
}
}

View File

@@ -0,0 +1,71 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie;
/**
* Persists cookies in the client session
*/
class SessionCookieJar extends CookieJar
{
/**
* @var string session key
*/
private $sessionKey;
/**
* @var bool Control whether to persist session cookies or not.
*/
private $storeSessionCookies;
/**
* Create a new SessionCookieJar object
*
* @param string $sessionKey Session key name to store the cookie
* data in session
* @param bool $storeSessionCookies Set to true to store session cookies
* in the cookie jar.
*/
public function __construct(string $sessionKey, bool $storeSessionCookies = \false)
{
parent::__construct();
$this->sessionKey = $sessionKey;
$this->storeSessionCookies = $storeSessionCookies;
$this->load();
}
/**
* Saves cookies to session when shutting down
*/
public function __destruct()
{
$this->save();
}
/**
* Save cookies to the client session
*/
public function save() : void
{
$json = [];
/** @var SetCookie $cookie */
foreach ($this as $cookie) {
if (CookieJar::shouldPersist($cookie, $this->storeSessionCookies)) {
$json[] = $cookie->toArray();
}
}
$_SESSION[$this->sessionKey] = \json_encode($json);
}
/**
* Load the contents of the client session into the data array
*/
protected function load() : void
{
if (!isset($_SESSION[$this->sessionKey])) {
return;
}
$data = \json_decode($_SESSION[$this->sessionKey], \true);
if (\is_array($data)) {
foreach ($data as $cookie) {
$this->setCookie(new SetCookie($cookie));
}
} elseif (\strlen($data)) {
throw new \RuntimeException('Invalid cookie data');
}
}
}

View File

@@ -0,0 +1,407 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie;
/**
* Set-Cookie object
*/
class SetCookie
{
/**
* @var array
*/
private static $defaults = ['Name' => null, 'Value' => null, 'Domain' => null, 'Path' => '/', 'Max-Age' => null, 'Expires' => null, 'Secure' => \false, 'Discard' => \false, 'HttpOnly' => \false];
/**
* @var array Cookie data
*/
private $data;
/**
* Create a new SetCookie object from a string.
*
* @param string $cookie Set-Cookie header string
*/
public static function fromString(string $cookie) : self
{
// Create the default return array
$data = self::$defaults;
// Explode the cookie string using a series of semicolons
$pieces = \array_filter(\array_map('trim', \explode(';', $cookie)));
// The name of the cookie (first kvp) must exist and include an equal sign.
if (!isset($pieces[0]) || \strpos($pieces[0], '=') === \false) {
return new self($data);
}
// Add the cookie pieces into the parsed data array
foreach ($pieces as $part) {
$cookieParts = \explode('=', $part, 2);
$key = \trim($cookieParts[0]);
$value = isset($cookieParts[1]) ? \trim($cookieParts[1], " \n\r\t\x00\v") : \true;
// Only check for non-cookies when cookies have been found
if (!isset($data['Name'])) {
$data['Name'] = $key;
$data['Value'] = $value;
} else {
foreach (\array_keys(self::$defaults) as $search) {
if (!\strcasecmp($search, $key)) {
if ($search === 'Max-Age') {
if (\is_numeric($value)) {
$data[$search] = (int) $value;
}
} else {
$data[$search] = $value;
}
continue 2;
}
}
$data[$key] = $value;
}
}
return new self($data);
}
/**
* @param array $data Array of cookie data provided by a Cookie parser
*/
public function __construct(array $data = [])
{
$this->data = self::$defaults;
if (isset($data['Name'])) {
$this->setName($data['Name']);
}
if (isset($data['Value'])) {
$this->setValue($data['Value']);
}
if (isset($data['Domain'])) {
$this->setDomain($data['Domain']);
}
if (isset($data['Path'])) {
$this->setPath($data['Path']);
}
if (isset($data['Max-Age'])) {
$this->setMaxAge($data['Max-Age']);
}
if (isset($data['Expires'])) {
$this->setExpires($data['Expires']);
}
if (isset($data['Secure'])) {
$this->setSecure($data['Secure']);
}
if (isset($data['Discard'])) {
$this->setDiscard($data['Discard']);
}
if (isset($data['HttpOnly'])) {
$this->setHttpOnly($data['HttpOnly']);
}
// Set the remaining values that don't have extra validation logic
foreach (\array_diff(\array_keys($data), \array_keys(self::$defaults)) as $key) {
$this->data[$key] = $data[$key];
}
// Extract the Expires value and turn it into a UNIX timestamp if needed
if (!$this->getExpires() && $this->getMaxAge()) {
// Calculate the Expires date
$this->setExpires(\time() + $this->getMaxAge());
} elseif (null !== ($expires = $this->getExpires()) && !\is_numeric($expires)) {
$this->setExpires($expires);
}
}
public function __toString()
{
$str = $this->data['Name'] . '=' . ($this->data['Value'] ?? '') . '; ';
foreach ($this->data as $k => $v) {
if ($k !== 'Name' && $k !== 'Value' && $v !== null && $v !== \false) {
if ($k === 'Expires') {
$str .= 'Expires=' . \gmdate('D, d M Y H:i:s \\G\\M\\T', $v) . '; ';
} else {
$str .= ($v === \true ? $k : "{$k}={$v}") . '; ';
}
}
}
return \rtrim($str, '; ');
}
public function toArray() : array
{
return $this->data;
}
/**
* Get the cookie name.
*
* @return string
*/
public function getName()
{
return $this->data['Name'];
}
/**
* Set the cookie name.
*
* @param string $name Cookie name
*/
public function setName($name) : void
{
if (!\is_string($name)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a string to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Name'] = (string) $name;
}
/**
* Get the cookie value.
*
* @return string|null
*/
public function getValue()
{
return $this->data['Value'];
}
/**
* Set the cookie value.
*
* @param string $value Cookie value
*/
public function setValue($value) : void
{
if (!\is_string($value)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a string to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Value'] = (string) $value;
}
/**
* Get the domain.
*
* @return string|null
*/
public function getDomain()
{
return $this->data['Domain'];
}
/**
* Set the domain of the cookie.
*
* @param string|null $domain
*/
public function setDomain($domain) : void
{
if (!\is_string($domain) && null !== $domain) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a string or null to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Domain'] = null === $domain ? null : (string) $domain;
}
/**
* Get the path.
*
* @return string
*/
public function getPath()
{
return $this->data['Path'];
}
/**
* Set the path of the cookie.
*
* @param string $path Path of the cookie
*/
public function setPath($path) : void
{
if (!\is_string($path)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a string to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Path'] = (string) $path;
}
/**
* Maximum lifetime of the cookie in seconds.
*
* @return int|null
*/
public function getMaxAge()
{
return null === $this->data['Max-Age'] ? null : (int) $this->data['Max-Age'];
}
/**
* Set the max-age of the cookie.
*
* @param int|null $maxAge Max age of the cookie in seconds
*/
public function setMaxAge($maxAge) : void
{
if (!\is_int($maxAge) && null !== $maxAge) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing an int or null to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Max-Age'] = $maxAge === null ? null : (int) $maxAge;
}
/**
* The UNIX timestamp when the cookie Expires.
*
* @return string|int|null
*/
public function getExpires()
{
return $this->data['Expires'];
}
/**
* Set the unix timestamp for which the cookie will expire.
*
* @param int|string|null $timestamp Unix timestamp or any English textual datetime description.
*/
public function setExpires($timestamp) : void
{
if (!\is_int($timestamp) && !\is_string($timestamp) && null !== $timestamp) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing an int, string or null to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Expires'] = null === $timestamp ? null : (\is_numeric($timestamp) ? (int) $timestamp : \strtotime((string) $timestamp));
}
/**
* Get whether or not this is a secure cookie.
*
* @return bool
*/
public function getSecure()
{
return $this->data['Secure'];
}
/**
* Set whether or not the cookie is secure.
*
* @param bool $secure Set to true or false if secure
*/
public function setSecure($secure) : void
{
if (!\is_bool($secure)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a bool to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Secure'] = (bool) $secure;
}
/**
* Get whether or not this is a session cookie.
*
* @return bool|null
*/
public function getDiscard()
{
return $this->data['Discard'];
}
/**
* Set whether or not this is a session cookie.
*
* @param bool $discard Set to true or false if this is a session cookie
*/
public function setDiscard($discard) : void
{
if (!\is_bool($discard)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a bool to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['Discard'] = (bool) $discard;
}
/**
* Get whether or not this is an HTTP only cookie.
*
* @return bool
*/
public function getHttpOnly()
{
return $this->data['HttpOnly'];
}
/**
* Set whether or not this is an HTTP only cookie.
*
* @param bool $httpOnly Set to true or false if this is HTTP only
*/
public function setHttpOnly($httpOnly) : void
{
if (!\is_bool($httpOnly)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a bool to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->data['HttpOnly'] = (bool) $httpOnly;
}
/**
* Check if the cookie matches a path value.
*
* A request-path path-matches a given cookie-path if at least one of
* the following conditions holds:
*
* - The cookie-path and the request-path are identical.
* - The cookie-path is a prefix of the request-path, and the last
* character of the cookie-path is %x2F ("/").
* - The cookie-path is a prefix of the request-path, and the first
* character of the request-path that is not included in the cookie-
* path is a %x2F ("/") character.
*
* @param string $requestPath Path to check against
*/
public function matchesPath(string $requestPath) : bool
{
$cookiePath = $this->getPath();
// Match on exact matches or when path is the default empty "/"
if ($cookiePath === '/' || $cookiePath == $requestPath) {
return \true;
}
// Ensure that the cookie-path is a prefix of the request path.
if (0 !== \strpos($requestPath, $cookiePath)) {
return \false;
}
// Match if the last character of the cookie-path is "/"
if (\substr($cookiePath, -1, 1) === '/') {
return \true;
}
// Match if the first character not included in cookie path is "/"
return \substr($requestPath, \strlen($cookiePath), 1) === '/';
}
/**
* Check if the cookie matches a domain value.
*
* @param string $domain Domain to check against
*/
public function matchesDomain(string $domain) : bool
{
$cookieDomain = $this->getDomain();
if (null === $cookieDomain) {
return \true;
}
// Remove the leading '.' as per spec in RFC 6265.
// https://tools.ietf.org/html/rfc6265#section-5.2.3
$cookieDomain = \ltrim(\strtolower($cookieDomain), '.');
$domain = \strtolower($domain);
// Domain not set or exact match.
if ('' === $cookieDomain || $domain === $cookieDomain) {
return \true;
}
// Matching the subdomain according to RFC 6265.
// https://tools.ietf.org/html/rfc6265#section-5.1.3
if (\filter_var($domain, \FILTER_VALIDATE_IP)) {
return \false;
}
return (bool) \preg_match('/\\.' . \preg_quote($cookieDomain, '/') . '$/', $domain);
}
/**
* Check if the cookie is expired.
*/
public function isExpired() : bool
{
return $this->getExpires() !== null && \time() > $this->getExpires();
}
/**
* Check if the cookie is valid according to RFC 6265.
*
* @return bool|string Returns true if valid or an error message if invalid
*/
public function validate()
{
$name = $this->getName();
if ($name === '') {
return 'The cookie name must not be empty';
}
// Check if any of the invalid characters are present in the cookie name
if (\preg_match('/[\\x00-\\x20\\x22\\x28-\\x29\\x2c\\x2f\\x3a-\\x40\\x5c\\x7b\\x7d\\x7f]/', $name)) {
return 'Cookie name must not contain invalid characters: ASCII ' . 'Control characters (0-31;127), space, tab and the ' . 'following characters: ()<>@,;:\\"/?={}';
}
// Value must not be null. 0 and empty string are valid. Empty strings
// are technically against RFC 6265, but known to happen in the wild.
$value = $this->getValue();
if ($value === null) {
return 'The cookie value must not be empty';
}
// Domains must not be empty, but can be 0. "0" is not a valid internet
// domain, but may be used as server name in a private network.
$domain = $this->getDomain();
if ($domain === null || $domain === '') {
return 'The cookie domain must not be empty';
}
return \true;
}
}

View File

@@ -0,0 +1,31 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
/**
* Exception when an HTTP error occurs (4xx or 5xx error)
*/
class BadResponseException extends RequestException
{
public function __construct(string $message, RequestInterface $request, ResponseInterface $response, \Throwable $previous = null, array $handlerContext = [])
{
parent::__construct($message, $request, $response, $previous, $handlerContext);
}
/**
* Current exception and the ones that extend it will always have a response.
*/
public function hasResponse() : bool
{
return \true;
}
/**
* This function narrows the return type from the parent class and does not allow it to be nullable.
*/
public function getResponse() : ResponseInterface
{
/** @var ResponseInterface */
return parent::getResponse();
}
}

View File

@@ -0,0 +1,10 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
/**
* Exception when a client error is encountered (4xx codes)
*/
class ClientException extends BadResponseException
{
}

View File

@@ -0,0 +1,47 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Client\NetworkExceptionInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* Exception thrown when a connection cannot be established.
*
* Note that no response is present for a ConnectException
*/
class ConnectException extends TransferException implements NetworkExceptionInterface
{
/**
* @var RequestInterface
*/
private $request;
/**
* @var array
*/
private $handlerContext;
public function __construct(string $message, RequestInterface $request, \Throwable $previous = null, array $handlerContext = [])
{
parent::__construct($message, 0, $previous);
$this->request = $request;
$this->handlerContext = $handlerContext;
}
/**
* Get the request that caused the exception
*/
public function getRequest() : RequestInterface
{
return $this->request;
}
/**
* Get contextual information about the error from the underlying handler.
*
* The contents of this array will vary depending on which handler you are
* using. It may also be just an empty array. Relying on this data will
* couple you to a specific handler, but can give more debug information
* when needed.
*/
public function getHandlerContext() : array
{
return $this->handlerContext;
}
}

View File

@@ -0,0 +1,8 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Client\ClientExceptionInterface;
interface GuzzleException extends ClientExceptionInterface
{
}

View File

@@ -0,0 +1,7 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
final class InvalidArgumentException extends \InvalidArgumentException implements GuzzleException
{
}

View File

@@ -0,0 +1,124 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\BodySummarizer;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\BodySummarizerInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Client\RequestExceptionInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\UriInterface;
/**
* HTTP Request exception
*/
class RequestException extends TransferException implements RequestExceptionInterface
{
/**
* @var RequestInterface
*/
private $request;
/**
* @var ResponseInterface|null
*/
private $response;
/**
* @var array
*/
private $handlerContext;
public function __construct(string $message, RequestInterface $request, ResponseInterface $response = null, \Throwable $previous = null, array $handlerContext = [])
{
// Set the code of the exception if the response is set and not future.
$code = $response ? $response->getStatusCode() : 0;
parent::__construct($message, $code, $previous);
$this->request = $request;
$this->response = $response;
$this->handlerContext = $handlerContext;
}
/**
* Wrap non-RequestExceptions with a RequestException
*/
public static function wrapException(RequestInterface $request, \Throwable $e) : RequestException
{
return $e instanceof RequestException ? $e : new RequestException($e->getMessage(), $request, null, $e);
}
/**
* Factory method to create a new exception with a normalized error message
*
* @param RequestInterface $request Request sent
* @param ResponseInterface $response Response received
* @param \Throwable|null $previous Previous exception
* @param array $handlerContext Optional handler context
* @param BodySummarizerInterface|null $bodySummarizer Optional body summarizer
*/
public static function create(RequestInterface $request, ResponseInterface $response = null, \Throwable $previous = null, array $handlerContext = [], BodySummarizerInterface $bodySummarizer = null) : self
{
if (!$response) {
return new self('Error completing request', $request, null, $previous, $handlerContext);
}
$level = (int) \floor($response->getStatusCode() / 100);
if ($level === 4) {
$label = 'Client error';
$className = ClientException::class;
} elseif ($level === 5) {
$label = 'Server error';
$className = ServerException::class;
} else {
$label = 'Unsuccessful request';
$className = __CLASS__;
}
$uri = $request->getUri();
$uri = static::obfuscateUri($uri);
// Client Error: `GET /` resulted in a `404 Not Found` response:
// <html> ... (truncated)
$message = \sprintf('%s: `%s %s` resulted in a `%s %s` response', $label, $request->getMethod(), $uri->__toString(), $response->getStatusCode(), $response->getReasonPhrase());
$summary = ($bodySummarizer ?? new BodySummarizer())->summarize($response);
if ($summary !== null) {
$message .= ":\n{$summary}\n";
}
return new $className($message, $request, $response, $previous, $handlerContext);
}
/**
* Obfuscates URI if there is a username and a password present
*/
private static function obfuscateUri(UriInterface $uri) : UriInterface
{
$userInfo = $uri->getUserInfo();
if (\false !== ($pos = \strpos($userInfo, ':'))) {
return $uri->withUserInfo(\substr($userInfo, 0, $pos), '***');
}
return $uri;
}
/**
* Get the request that caused the exception
*/
public function getRequest() : RequestInterface
{
return $this->request;
}
/**
* Get the associated response
*/
public function getResponse() : ?ResponseInterface
{
return $this->response;
}
/**
* Check if a response was received
*/
public function hasResponse() : bool
{
return $this->response !== null;
}
/**
* Get contextual information about the error from the underlying handler.
*
* The contents of this array will vary depending on which handler you are
* using. It may also be just an empty array. Relying on this data will
* couple you to a specific handler, but can give more debug information
* when needed.
*/
public function getHandlerContext() : array
{
return $this->handlerContext;
}
}

View File

@@ -0,0 +1,10 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
/**
* Exception when a server error is encountered (5xx codes)
*/
class ServerException extends BadResponseException
{
}

View File

@@ -0,0 +1,7 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
class TooManyRedirectsException extends RequestException
{
}

View File

@@ -0,0 +1,7 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception;
class TransferException extends \RuntimeException implements GuzzleException
{
}

View File

@@ -0,0 +1,496 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\ConnectException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\RequestException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\FulfilledPromise;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7\LazyOpenStream;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\TransferStats;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* Creates curl resources from a request
*
* @final
*/
class CurlFactory implements CurlFactoryInterface
{
public const CURL_VERSION_STR = 'curl_version';
/**
* @deprecated
*/
public const LOW_CURL_VERSION_NUMBER = '7.21.2';
/**
* @var resource[]|\CurlHandle[]
*/
private $handles = [];
/**
* @var int Total number of idle handles to keep in cache
*/
private $maxHandles;
/**
* @param int $maxHandles Maximum number of idle handles.
*/
public function __construct(int $maxHandles)
{
$this->maxHandles = $maxHandles;
}
public function create(RequestInterface $request, array $options) : EasyHandle
{
if (isset($options['curl']['body_as_string'])) {
$options['_body_as_string'] = $options['curl']['body_as_string'];
unset($options['curl']['body_as_string']);
}
$easy = new EasyHandle();
$easy->request = $request;
$easy->options = $options;
$conf = $this->getDefaultConf($easy);
$this->applyMethod($easy, $conf);
$this->applyHandlerOptions($easy, $conf);
$this->applyHeaders($easy, $conf);
unset($conf['_headers']);
// Add handler options from the request configuration options
if (isset($options['curl'])) {
$conf = \array_replace($conf, $options['curl']);
}
$conf[\CURLOPT_HEADERFUNCTION] = $this->createHeaderFn($easy);
$easy->handle = $this->handles ? \array_pop($this->handles) : \curl_init();
\curl_setopt_array($easy->handle, $conf);
return $easy;
}
public function release(EasyHandle $easy) : void
{
$resource = $easy->handle;
unset($easy->handle);
if (\count($this->handles) >= $this->maxHandles) {
\curl_close($resource);
} else {
// Remove all callback functions as they can hold onto references
// and are not cleaned up by curl_reset. Using curl_setopt_array
// does not work for some reason, so removing each one
// individually.
\curl_setopt($resource, \CURLOPT_HEADERFUNCTION, null);
\curl_setopt($resource, \CURLOPT_READFUNCTION, null);
\curl_setopt($resource, \CURLOPT_WRITEFUNCTION, null);
\curl_setopt($resource, \CURLOPT_PROGRESSFUNCTION, null);
\curl_reset($resource);
$this->handles[] = $resource;
}
}
/**
* Completes a cURL transaction, either returning a response promise or a
* rejected promise.
*
* @param callable(RequestInterface, array): PromiseInterface $handler
* @param CurlFactoryInterface $factory Dictates how the handle is released
*/
public static function finish(callable $handler, EasyHandle $easy, CurlFactoryInterface $factory) : PromiseInterface
{
if (isset($easy->options['on_stats'])) {
self::invokeStats($easy);
}
if (!$easy->response || $easy->errno) {
return self::finishError($handler, $easy, $factory);
}
// Return the response if it is present and there is no error.
$factory->release($easy);
// Rewind the body of the response if possible.
$body = $easy->response->getBody();
if ($body->isSeekable()) {
$body->rewind();
}
return new FulfilledPromise($easy->response);
}
private static function invokeStats(EasyHandle $easy) : void
{
$curlStats = \curl_getinfo($easy->handle);
$curlStats['appconnect_time'] = \curl_getinfo($easy->handle, \CURLINFO_APPCONNECT_TIME);
$stats = new TransferStats($easy->request, $easy->response, $curlStats['total_time'], $easy->errno, $curlStats);
$easy->options['on_stats']($stats);
}
/**
* @param callable(RequestInterface, array): PromiseInterface $handler
*/
private static function finishError(callable $handler, EasyHandle $easy, CurlFactoryInterface $factory) : PromiseInterface
{
// Get error information and release the handle to the factory.
$ctx = ['errno' => $easy->errno, 'error' => \curl_error($easy->handle), 'appconnect_time' => \curl_getinfo($easy->handle, \CURLINFO_APPCONNECT_TIME)] + \curl_getinfo($easy->handle);
$ctx[self::CURL_VERSION_STR] = \curl_version()['version'];
$factory->release($easy);
// Retry when nothing is present or when curl failed to rewind.
if (empty($easy->options['_err_message']) && (!$easy->errno || $easy->errno == 65)) {
return self::retryFailedRewind($handler, $easy, $ctx);
}
return self::createRejection($easy, $ctx);
}
private static function createRejection(EasyHandle $easy, array $ctx) : PromiseInterface
{
static $connectionErrors = [\CURLE_OPERATION_TIMEOUTED => \true, \CURLE_COULDNT_RESOLVE_HOST => \true, \CURLE_COULDNT_CONNECT => \true, \CURLE_SSL_CONNECT_ERROR => \true, \CURLE_GOT_NOTHING => \true];
if ($easy->createResponseException) {
return P\Create::rejectionFor(new RequestException('An error was encountered while creating the response', $easy->request, $easy->response, $easy->createResponseException, $ctx));
}
// If an exception was encountered during the onHeaders event, then
// return a rejected promise that wraps that exception.
if ($easy->onHeadersException) {
return P\Create::rejectionFor(new RequestException('An error was encountered during the on_headers event', $easy->request, $easy->response, $easy->onHeadersException, $ctx));
}
$message = \sprintf('cURL error %s: %s (%s)', $ctx['errno'], $ctx['error'], 'see https://curl.haxx.se/libcurl/c/libcurl-errors.html');
$uriString = (string) $easy->request->getUri();
if ($uriString !== '' && \false === \strpos($ctx['error'], $uriString)) {
$message .= \sprintf(' for %s', $uriString);
}
// Create a connection exception if it was a specific error code.
$error = isset($connectionErrors[$easy->errno]) ? new ConnectException($message, $easy->request, null, $ctx) : new RequestException($message, $easy->request, $easy->response, null, $ctx);
return P\Create::rejectionFor($error);
}
/**
* @return array<int|string, mixed>
*/
private function getDefaultConf(EasyHandle $easy) : array
{
$conf = ['_headers' => $easy->request->getHeaders(), \CURLOPT_CUSTOMREQUEST => $easy->request->getMethod(), \CURLOPT_URL => (string) $easy->request->getUri()->withFragment(''), \CURLOPT_RETURNTRANSFER => \false, \CURLOPT_HEADER => \false, \CURLOPT_CONNECTTIMEOUT => 300];
if (\defined('CURLOPT_PROTOCOLS')) {
$conf[\CURLOPT_PROTOCOLS] = \CURLPROTO_HTTP | \CURLPROTO_HTTPS;
}
$version = $easy->request->getProtocolVersion();
if ($version == 1.1) {
$conf[\CURLOPT_HTTP_VERSION] = \CURL_HTTP_VERSION_1_1;
} elseif ($version == 2.0) {
$conf[\CURLOPT_HTTP_VERSION] = \CURL_HTTP_VERSION_2_0;
} else {
$conf[\CURLOPT_HTTP_VERSION] = \CURL_HTTP_VERSION_1_0;
}
return $conf;
}
private function applyMethod(EasyHandle $easy, array &$conf) : void
{
$body = $easy->request->getBody();
$size = $body->getSize();
if ($size === null || $size > 0) {
$this->applyBody($easy->request, $easy->options, $conf);
return;
}
$method = $easy->request->getMethod();
if ($method === 'PUT' || $method === 'POST') {
// See https://tools.ietf.org/html/rfc7230#section-3.3.2
if (!$easy->request->hasHeader('Content-Length')) {
$conf[\CURLOPT_HTTPHEADER][] = 'Content-Length: 0';
}
} elseif ($method === 'HEAD') {
$conf[\CURLOPT_NOBODY] = \true;
unset($conf[\CURLOPT_WRITEFUNCTION], $conf[\CURLOPT_READFUNCTION], $conf[\CURLOPT_FILE], $conf[\CURLOPT_INFILE]);
}
}
private function applyBody(RequestInterface $request, array $options, array &$conf) : void
{
$size = $request->hasHeader('Content-Length') ? (int) $request->getHeaderLine('Content-Length') : null;
// Send the body as a string if the size is less than 1MB OR if the
// [curl][body_as_string] request value is set.
if ($size !== null && $size < 1000000 || !empty($options['_body_as_string'])) {
$conf[\CURLOPT_POSTFIELDS] = (string) $request->getBody();
// Don't duplicate the Content-Length header
$this->removeHeader('Content-Length', $conf);
$this->removeHeader('Transfer-Encoding', $conf);
} else {
$conf[\CURLOPT_UPLOAD] = \true;
if ($size !== null) {
$conf[\CURLOPT_INFILESIZE] = $size;
$this->removeHeader('Content-Length', $conf);
}
$body = $request->getBody();
if ($body->isSeekable()) {
$body->rewind();
}
$conf[\CURLOPT_READFUNCTION] = static function ($ch, $fd, $length) use($body) {
return $body->read($length);
};
}
// If the Expect header is not present, prevent curl from adding it
if (!$request->hasHeader('Expect')) {
$conf[\CURLOPT_HTTPHEADER][] = 'Expect:';
}
// cURL sometimes adds a content-type by default. Prevent this.
if (!$request->hasHeader('Content-Type')) {
$conf[\CURLOPT_HTTPHEADER][] = 'Content-Type:';
}
}
private function applyHeaders(EasyHandle $easy, array &$conf) : void
{
foreach ($conf['_headers'] as $name => $values) {
foreach ($values as $value) {
$value = (string) $value;
if ($value === '') {
// cURL requires a special format for empty headers.
// See https://github.com/guzzle/guzzle/issues/1882 for more details.
$conf[\CURLOPT_HTTPHEADER][] = "{$name};";
} else {
$conf[\CURLOPT_HTTPHEADER][] = "{$name}: {$value}";
}
}
}
// Remove the Accept header if one was not set
if (!$easy->request->hasHeader('Accept')) {
$conf[\CURLOPT_HTTPHEADER][] = 'Accept:';
}
}
/**
* Remove a header from the options array.
*
* @param string $name Case-insensitive header to remove
* @param array $options Array of options to modify
*/
private function removeHeader(string $name, array &$options) : void
{
foreach (\array_keys($options['_headers']) as $key) {
if (!\strcasecmp($key, $name)) {
unset($options['_headers'][$key]);
return;
}
}
}
private function applyHandlerOptions(EasyHandle $easy, array &$conf) : void
{
$options = $easy->options;
if (isset($options['verify'])) {
if ($options['verify'] === \false) {
unset($conf[\CURLOPT_CAINFO]);
$conf[\CURLOPT_SSL_VERIFYHOST] = 0;
$conf[\CURLOPT_SSL_VERIFYPEER] = \false;
} else {
$conf[\CURLOPT_SSL_VERIFYHOST] = 2;
$conf[\CURLOPT_SSL_VERIFYPEER] = \true;
if (\is_string($options['verify'])) {
// Throw an error if the file/folder/link path is not valid or doesn't exist.
if (!\file_exists($options['verify'])) {
throw new \InvalidArgumentException("SSL CA bundle not found: {$options['verify']}");
}
// If it's a directory or a link to a directory use CURLOPT_CAPATH.
// If not, it's probably a file, or a link to a file, so use CURLOPT_CAINFO.
if (\is_dir($options['verify']) || \is_link($options['verify']) === \true && ($verifyLink = \readlink($options['verify'])) !== \false && \is_dir($verifyLink)) {
$conf[\CURLOPT_CAPATH] = $options['verify'];
} else {
$conf[\CURLOPT_CAINFO] = $options['verify'];
}
}
}
}
if (!isset($options['curl'][\CURLOPT_ENCODING]) && !empty($options['decode_content'])) {
$accept = $easy->request->getHeaderLine('Accept-Encoding');
if ($accept) {
$conf[\CURLOPT_ENCODING] = $accept;
} else {
// The empty string enables all available decoders and implicitly
// sets a matching 'Accept-Encoding' header.
$conf[\CURLOPT_ENCODING] = '';
// But as the user did not specify any acceptable encodings we need
// to overwrite this implicit header with an empty one.
$conf[\CURLOPT_HTTPHEADER][] = 'Accept-Encoding:';
}
}
if (!isset($options['sink'])) {
// Use a default temp stream if no sink was set.
$options['sink'] = \Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7\Utils::tryFopen('php://temp', 'w+');
}
$sink = $options['sink'];
if (!\is_string($sink)) {
$sink = \Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7\Utils::streamFor($sink);
} elseif (!\is_dir(\dirname($sink))) {
// Ensure that the directory exists before failing in curl.
throw new \RuntimeException(\sprintf('Directory %s does not exist for sink value of %s', \dirname($sink), $sink));
} else {
$sink = new LazyOpenStream($sink, 'w+');
}
$easy->sink = $sink;
$conf[\CURLOPT_WRITEFUNCTION] = static function ($ch, $write) use($sink) : int {
return $sink->write($write);
};
$timeoutRequiresNoSignal = \false;
if (isset($options['timeout'])) {
$timeoutRequiresNoSignal |= $options['timeout'] < 1;
$conf[\CURLOPT_TIMEOUT_MS] = $options['timeout'] * 1000;
}
// CURL default value is CURL_IPRESOLVE_WHATEVER
if (isset($options['force_ip_resolve'])) {
if ('v4' === $options['force_ip_resolve']) {
$conf[\CURLOPT_IPRESOLVE] = \CURL_IPRESOLVE_V4;
} elseif ('v6' === $options['force_ip_resolve']) {
$conf[\CURLOPT_IPRESOLVE] = \CURL_IPRESOLVE_V6;
}
}
if (isset($options['connect_timeout'])) {
$timeoutRequiresNoSignal |= $options['connect_timeout'] < 1;
$conf[\CURLOPT_CONNECTTIMEOUT_MS] = $options['connect_timeout'] * 1000;
}
if ($timeoutRequiresNoSignal && \strtoupper(\substr(\PHP_OS, 0, 3)) !== 'WIN') {
$conf[\CURLOPT_NOSIGNAL] = \true;
}
if (isset($options['proxy'])) {
if (!\is_array($options['proxy'])) {
$conf[\CURLOPT_PROXY] = $options['proxy'];
} else {
$scheme = $easy->request->getUri()->getScheme();
if (isset($options['proxy'][$scheme])) {
$host = $easy->request->getUri()->getHost();
if (isset($options['proxy']['no']) && Utils::isHostInNoProxy($host, $options['proxy']['no'])) {
unset($conf[\CURLOPT_PROXY]);
} else {
$conf[\CURLOPT_PROXY] = $options['proxy'][$scheme];
}
}
}
}
if (isset($options['crypto_method'])) {
if (\STREAM_CRYPTO_METHOD_TLSv1_0_CLIENT === $options['crypto_method']) {
if (!\defined('CURL_SSLVERSION_TLSv1_0')) {
throw new \InvalidArgumentException('Invalid crypto_method request option: TLS 1.0 not supported by your version of cURL');
}
$conf[\CURLOPT_SSLVERSION] = \CURL_SSLVERSION_TLSv1_0;
} elseif (\STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT === $options['crypto_method']) {
if (!\defined('CURL_SSLVERSION_TLSv1_1')) {
throw new \InvalidArgumentException('Invalid crypto_method request option: TLS 1.1 not supported by your version of cURL');
}
$conf[\CURLOPT_SSLVERSION] = \CURL_SSLVERSION_TLSv1_1;
} elseif (\STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT === $options['crypto_method']) {
if (!\defined('CURL_SSLVERSION_TLSv1_2')) {
throw new \InvalidArgumentException('Invalid crypto_method request option: TLS 1.2 not supported by your version of cURL');
}
$conf[\CURLOPT_SSLVERSION] = \CURL_SSLVERSION_TLSv1_2;
} elseif (\defined('STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT') && \STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT === $options['crypto_method']) {
if (!\defined('CURL_SSLVERSION_TLSv1_3')) {
throw new \InvalidArgumentException('Invalid crypto_method request option: TLS 1.3 not supported by your version of cURL');
}
$conf[\CURLOPT_SSLVERSION] = \CURL_SSLVERSION_TLSv1_3;
} else {
throw new \InvalidArgumentException('Invalid crypto_method request option: unknown version provided');
}
}
if (isset($options['cert'])) {
$cert = $options['cert'];
if (\is_array($cert)) {
$conf[\CURLOPT_SSLCERTPASSWD] = $cert[1];
$cert = $cert[0];
}
if (!\file_exists($cert)) {
throw new \InvalidArgumentException("SSL certificate not found: {$cert}");
}
// OpenSSL (versions 0.9.3 and later) also support "P12" for PKCS#12-encoded files.
// see https://curl.se/libcurl/c/CURLOPT_SSLCERTTYPE.html
$ext = \pathinfo($cert, \PATHINFO_EXTENSION);
if (\preg_match('#^(der|p12)$#i', $ext)) {
$conf[\CURLOPT_SSLCERTTYPE] = \strtoupper($ext);
}
$conf[\CURLOPT_SSLCERT] = $cert;
}
if (isset($options['ssl_key'])) {
if (\is_array($options['ssl_key'])) {
if (\count($options['ssl_key']) === 2) {
[$sslKey, $conf[\CURLOPT_SSLKEYPASSWD]] = $options['ssl_key'];
} else {
[$sslKey] = $options['ssl_key'];
}
}
$sslKey = $sslKey ?? $options['ssl_key'];
if (!\file_exists($sslKey)) {
throw new \InvalidArgumentException("SSL private key not found: {$sslKey}");
}
$conf[\CURLOPT_SSLKEY] = $sslKey;
}
if (isset($options['progress'])) {
$progress = $options['progress'];
if (!\is_callable($progress)) {
throw new \InvalidArgumentException('progress client option must be callable');
}
$conf[\CURLOPT_NOPROGRESS] = \false;
$conf[\CURLOPT_PROGRESSFUNCTION] = static function ($resource, int $downloadSize, int $downloaded, int $uploadSize, int $uploaded) use($progress) {
$progress($downloadSize, $downloaded, $uploadSize, $uploaded);
};
}
if (!empty($options['debug'])) {
$conf[\CURLOPT_STDERR] = Utils::debugResource($options['debug']);
$conf[\CURLOPT_VERBOSE] = \true;
}
}
/**
* This function ensures that a response was set on a transaction. If one
* was not set, then the request is retried if possible. This error
* typically means you are sending a payload, curl encountered a
* "Connection died, retrying a fresh connect" error, tried to rewind the
* stream, and then encountered a "necessary data rewind wasn't possible"
* error, causing the request to be sent through curl_multi_info_read()
* without an error status.
*
* @param callable(RequestInterface, array): PromiseInterface $handler
*/
private static function retryFailedRewind(callable $handler, EasyHandle $easy, array $ctx) : PromiseInterface
{
try {
// Only rewind if the body has been read from.
$body = $easy->request->getBody();
if ($body->tell() > 0) {
$body->rewind();
}
} catch (\RuntimeException $e) {
$ctx['error'] = 'The connection unexpectedly failed without ' . 'providing an error. The request would have been retried, ' . 'but attempting to rewind the request body failed. ' . 'Exception: ' . $e;
return self::createRejection($easy, $ctx);
}
// Retry no more than 3 times before giving up.
if (!isset($easy->options['_curl_retries'])) {
$easy->options['_curl_retries'] = 1;
} elseif ($easy->options['_curl_retries'] == 2) {
$ctx['error'] = 'The cURL request was retried 3 times ' . 'and did not succeed. The most likely reason for the failure ' . 'is that cURL was unable to rewind the body of the request ' . 'and subsequent retries resulted in the same error. Turn on ' . 'the debug option to see what went wrong. See ' . 'https://bugs.php.net/bug.php?id=47204 for more information.';
return self::createRejection($easy, $ctx);
} else {
++$easy->options['_curl_retries'];
}
return $handler($easy->request, $easy->options);
}
private function createHeaderFn(EasyHandle $easy) : callable
{
if (isset($easy->options['on_headers'])) {
$onHeaders = $easy->options['on_headers'];
if (!\is_callable($onHeaders)) {
throw new \InvalidArgumentException('on_headers must be callable');
}
} else {
$onHeaders = null;
}
return static function ($ch, $h) use($onHeaders, $easy, &$startingResponse) {
$value = \trim($h);
if ($value === '') {
$startingResponse = \true;
try {
$easy->createResponse();
} catch (\Exception $e) {
$easy->createResponseException = $e;
return -1;
}
if ($onHeaders !== null) {
try {
$onHeaders($easy->response);
} catch (\Exception $e) {
// Associate the exception with the handle and trigger
// a curl header write error by returning 0.
$easy->onHeadersException = $e;
return -1;
}
}
} elseif ($startingResponse) {
$startingResponse = \false;
$easy->headers = [$value];
} else {
$easy->headers[] = $value;
}
return \strlen($h);
};
}
public function __destruct()
{
foreach ($this->handles as $id => $handle) {
\curl_close($handle);
unset($this->handles[$id]);
}
}
}

View File

@@ -0,0 +1,23 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
interface CurlFactoryInterface
{
/**
* Creates a cURL handle resource.
*
* @param RequestInterface $request Request
* @param array $options Transfer options
*
* @throws \RuntimeException when an option cannot be applied
*/
public function create(RequestInterface $request, array $options) : EasyHandle;
/**
* Release an easy handle, allowing it to be reused or closed.
*
* This function must call unset on the easy handle's "handle" property.
*/
public function release(EasyHandle $easy) : void;
}

View File

@@ -0,0 +1,43 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* HTTP handler that uses cURL easy handles as a transport layer.
*
* When using the CurlHandler, custom curl options can be specified as an
* associative array of curl option constants mapping to values in the
* **curl** key of the "client" key of the request.
*
* @final
*/
class CurlHandler
{
/**
* @var CurlFactoryInterface
*/
private $factory;
/**
* Accepts an associative array of options:
*
* - handle_factory: Optional curl factory used to create cURL handles.
*
* @param array{handle_factory?: ?CurlFactoryInterface} $options Array of options to use with the handler
*/
public function __construct(array $options = [])
{
$this->factory = $options['handle_factory'] ?? new CurlFactory(3);
}
public function __invoke(RequestInterface $request, array $options) : PromiseInterface
{
if (isset($options['delay'])) {
\usleep($options['delay'] * 1000);
}
$easy = $this->factory->create($request, $options);
\curl_exec($easy->handle);
$easy->errno = \curl_errno($easy->handle);
return CurlFactory::finish($this, $easy, $this->factory);
}
}

View File

@@ -0,0 +1,220 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\Promise;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* Returns an asynchronous response using curl_multi_* functions.
*
* When using the CurlMultiHandler, custom curl options can be specified as an
* associative array of curl option constants mapping to values in the
* **curl** key of the provided request options.
*
* @final
*/
class CurlMultiHandler
{
/**
* @var CurlFactoryInterface
*/
private $factory;
/**
* @var int
*/
private $selectTimeout;
/**
* @var int Will be higher than 0 when `curl_multi_exec` is still running.
*/
private $active = 0;
/**
* @var array Request entry handles, indexed by handle id in `addRequest`.
*
* @see CurlMultiHandler::addRequest
*/
private $handles = [];
/**
* @var array<int, float> An array of delay times, indexed by handle id in `addRequest`.
*
* @see CurlMultiHandler::addRequest
*/
private $delays = [];
/**
* @var array<mixed> An associative array of CURLMOPT_* options and corresponding values for curl_multi_setopt()
*/
private $options = [];
/** @var resource|\CurlMultiHandle */
private $_mh;
/**
* This handler accepts the following options:
*
* - handle_factory: An optional factory used to create curl handles
* - select_timeout: Optional timeout (in seconds) to block before timing
* out while selecting curl handles. Defaults to 1 second.
* - options: An associative array of CURLMOPT_* options and
* corresponding values for curl_multi_setopt()
*/
public function __construct(array $options = [])
{
$this->factory = $options['handle_factory'] ?? new CurlFactory(50);
if (isset($options['select_timeout'])) {
$this->selectTimeout = $options['select_timeout'];
} elseif ($selectTimeout = Utils::getenv('GUZZLE_CURL_SELECT_TIMEOUT')) {
@\trigger_error('Since guzzlehttp/guzzle 7.2.0: Using environment variable GUZZLE_CURL_SELECT_TIMEOUT is deprecated. Use option "select_timeout" instead.', \E_USER_DEPRECATED);
$this->selectTimeout = (int) $selectTimeout;
} else {
$this->selectTimeout = 1;
}
$this->options = $options['options'] ?? [];
// unsetting the property forces the first access to go through
// __get().
unset($this->_mh);
}
/**
* @param string $name
*
* @return resource|\CurlMultiHandle
*
* @throws \BadMethodCallException when another field as `_mh` will be gotten
* @throws \RuntimeException when curl can not initialize a multi handle
*/
public function __get($name)
{
if ($name !== '_mh') {
throw new \BadMethodCallException("Can not get other property as '_mh'.");
}
$multiHandle = \curl_multi_init();
if (\false === $multiHandle) {
throw new \RuntimeException('Can not initialize curl multi handle.');
}
$this->_mh = $multiHandle;
foreach ($this->options as $option => $value) {
// A warning is raised in case of a wrong option.
\curl_multi_setopt($this->_mh, $option, $value);
}
return $this->_mh;
}
public function __destruct()
{
if (isset($this->_mh)) {
\curl_multi_close($this->_mh);
unset($this->_mh);
}
}
public function __invoke(RequestInterface $request, array $options) : PromiseInterface
{
$easy = $this->factory->create($request, $options);
$id = (int) $easy->handle;
$promise = new Promise([$this, 'execute'], function () use($id) {
return $this->cancel($id);
});
$this->addRequest(['easy' => $easy, 'deferred' => $promise]);
return $promise;
}
/**
* Ticks the curl event loop.
*/
public function tick() : void
{
// Add any delayed handles if needed.
if ($this->delays) {
$currentTime = Utils::currentTime();
foreach ($this->delays as $id => $delay) {
if ($currentTime >= $delay) {
unset($this->delays[$id]);
\curl_multi_add_handle($this->_mh, $this->handles[$id]['easy']->handle);
}
}
}
// Step through the task queue which may add additional requests.
P\Utils::queue()->run();
if ($this->active && \curl_multi_select($this->_mh, $this->selectTimeout) === -1) {
// Perform a usleep if a select returns -1.
// See: https://bugs.php.net/bug.php?id=61141
\usleep(250);
}
while (\curl_multi_exec($this->_mh, $this->active) === \CURLM_CALL_MULTI_PERFORM) {
}
$this->processMessages();
}
/**
* Runs until all outstanding connections have completed.
*/
public function execute() : void
{
$queue = P\Utils::queue();
while ($this->handles || !$queue->isEmpty()) {
// If there are no transfers, then sleep for the next delay
if (!$this->active && $this->delays) {
\usleep($this->timeToNext());
}
$this->tick();
}
}
private function addRequest(array $entry) : void
{
$easy = $entry['easy'];
$id = (int) $easy->handle;
$this->handles[$id] = $entry;
if (empty($easy->options['delay'])) {
\curl_multi_add_handle($this->_mh, $easy->handle);
} else {
$this->delays[$id] = Utils::currentTime() + $easy->options['delay'] / 1000;
}
}
/**
* Cancels a handle from sending and removes references to it.
*
* @param int $id Handle ID to cancel and remove.
*
* @return bool True on success, false on failure.
*/
private function cancel($id) : bool
{
if (!\is_int($id)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing an integer to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
// Cannot cancel if it has been processed.
if (!isset($this->handles[$id])) {
return \false;
}
$handle = $this->handles[$id]['easy']->handle;
unset($this->delays[$id], $this->handles[$id]);
\curl_multi_remove_handle($this->_mh, $handle);
\curl_close($handle);
return \true;
}
private function processMessages() : void
{
while ($done = \curl_multi_info_read($this->_mh)) {
if ($done['msg'] !== \CURLMSG_DONE) {
// if it's not done, then it would be premature to remove the handle. ref https://github.com/guzzle/guzzle/pull/2892#issuecomment-945150216
continue;
}
$id = (int) $done['handle'];
\curl_multi_remove_handle($this->_mh, $done['handle']);
if (!isset($this->handles[$id])) {
// Probably was cancelled.
continue;
}
$entry = $this->handles[$id];
unset($this->handles[$id], $this->delays[$id]);
$entry['easy']->errno = $done['result'];
$entry['deferred']->resolve(CurlFactory::finish($this, $entry['easy'], $this->factory));
}
}
private function timeToNext() : int
{
$currentTime = Utils::currentTime();
$nextTime = \PHP_INT_MAX;
foreach ($this->delays as $time) {
if ($time < $nextTime) {
$nextTime = $time;
}
}
return (int) \max(0, $nextTime - $currentTime) * 1000000;
}
}

View File

@@ -0,0 +1,91 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7\Response;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\StreamInterface;
/**
* Represents a cURL easy handle and the data it populates.
*
* @internal
*/
final class EasyHandle
{
/**
* @var resource|\CurlHandle cURL resource
*/
public $handle;
/**
* @var StreamInterface Where data is being written
*/
public $sink;
/**
* @var array Received HTTP headers so far
*/
public $headers = [];
/**
* @var ResponseInterface|null Received response (if any)
*/
public $response;
/**
* @var RequestInterface Request being sent
*/
public $request;
/**
* @var array Request options
*/
public $options = [];
/**
* @var int cURL error number (if any)
*/
public $errno = 0;
/**
* @var \Throwable|null Exception during on_headers (if any)
*/
public $onHeadersException;
/**
* @var \Exception|null Exception during createResponse (if any)
*/
public $createResponseException;
/**
* Attach a response to the easy handle based on the received headers.
*
* @throws \RuntimeException if no headers have been received or the first
* header line is invalid.
*/
public function createResponse() : void
{
[$ver, $status, $reason, $headers] = HeaderProcessor::parseHeaders($this->headers);
$normalizedKeys = Utils::normalizeHeaderKeys($headers);
if (!empty($this->options['decode_content']) && isset($normalizedKeys['content-encoding'])) {
$headers['x-encoded-content-encoding'] = $headers[$normalizedKeys['content-encoding']];
unset($headers[$normalizedKeys['content-encoding']]);
if (isset($normalizedKeys['content-length'])) {
$headers['x-encoded-content-length'] = $headers[$normalizedKeys['content-length']];
$bodyLength = (int) $this->sink->getSize();
if ($bodyLength) {
$headers[$normalizedKeys['content-length']] = $bodyLength;
} else {
unset($headers[$normalizedKeys['content-length']]);
}
}
}
// Attach a response to the easy handle with the parsed headers.
$this->response = new Response($status, $headers, $this->sink, $ver, $reason);
}
/**
* @param string $name
*
* @return void
*
* @throws \BadMethodCallException
*/
public function __get($name)
{
$msg = $name === 'handle' ? 'The EasyHandle has been released' : 'Invalid property: ' . $name;
throw new \BadMethodCallException($msg);
}
}

View File

@@ -0,0 +1,36 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
/**
* @internal
*/
final class HeaderProcessor
{
/**
* Returns the HTTP version, status code, reason phrase, and headers.
*
* @param string[] $headers
*
* @return array{0:string, 1:int, 2:?string, 3:array}
*
* @throws \RuntimeException
*/
public static function parseHeaders(array $headers) : array
{
if ($headers === []) {
throw new \RuntimeException('Expected a non-empty array of header data');
}
$parts = \explode(' ', \array_shift($headers), 3);
$version = \explode('/', $parts[0])[1] ?? null;
if ($version === null) {
throw new \RuntimeException('HTTP version missing from header data');
}
$status = $parts[1] ?? null;
if ($status === null) {
throw new \RuntimeException('HTTP status code missing from header data');
}
return [$version, (int) $status, $parts[2] ?? null, Utils::headersFromLines($headers)];
}
}

View File

@@ -0,0 +1,174 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\RequestException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\HandlerStack;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\TransferStats;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\StreamInterface;
/**
* Handler that returns responses or throw exceptions from a queue.
*
* @final
*/
class MockHandler implements \Countable
{
/**
* @var array
*/
private $queue = [];
/**
* @var RequestInterface|null
*/
private $lastRequest;
/**
* @var array
*/
private $lastOptions = [];
/**
* @var callable|null
*/
private $onFulfilled;
/**
* @var callable|null
*/
private $onRejected;
/**
* Creates a new MockHandler that uses the default handler stack list of
* middlewares.
*
* @param array|null $queue Array of responses, callables, or exceptions.
* @param callable|null $onFulfilled Callback to invoke when the return value is fulfilled.
* @param callable|null $onRejected Callback to invoke when the return value is rejected.
*/
public static function createWithMiddleware(array $queue = null, callable $onFulfilled = null, callable $onRejected = null) : HandlerStack
{
return HandlerStack::create(new self($queue, $onFulfilled, $onRejected));
}
/**
* The passed in value must be an array of
* {@see \Psr\Http\Message\ResponseInterface} objects, Exceptions,
* callables, or Promises.
*
* @param array<int, mixed>|null $queue The parameters to be passed to the append function, as an indexed array.
* @param callable|null $onFulfilled Callback to invoke when the return value is fulfilled.
* @param callable|null $onRejected Callback to invoke when the return value is rejected.
*/
public function __construct(array $queue = null, callable $onFulfilled = null, callable $onRejected = null)
{
$this->onFulfilled = $onFulfilled;
$this->onRejected = $onRejected;
if ($queue) {
// array_values included for BC
$this->append(...\array_values($queue));
}
}
public function __invoke(RequestInterface $request, array $options) : PromiseInterface
{
if (!$this->queue) {
throw new \OutOfBoundsException('Mock queue is empty');
}
if (isset($options['delay']) && \is_numeric($options['delay'])) {
\usleep((int) $options['delay'] * 1000);
}
$this->lastRequest = $request;
$this->lastOptions = $options;
$response = \array_shift($this->queue);
if (isset($options['on_headers'])) {
if (!\is_callable($options['on_headers'])) {
throw new \InvalidArgumentException('on_headers must be callable');
}
try {
$options['on_headers']($response);
} catch (\Exception $e) {
$msg = 'An error was encountered during the on_headers event';
$response = new RequestException($msg, $request, $response, $e);
}
}
if (\is_callable($response)) {
$response = $response($request, $options);
}
$response = $response instanceof \Throwable ? P\Create::rejectionFor($response) : P\Create::promiseFor($response);
return $response->then(function (?ResponseInterface $value) use($request, $options) {
$this->invokeStats($request, $options, $value);
if ($this->onFulfilled) {
($this->onFulfilled)($value);
}
if ($value !== null && isset($options['sink'])) {
$contents = (string) $value->getBody();
$sink = $options['sink'];
if (\is_resource($sink)) {
\fwrite($sink, $contents);
} elseif (\is_string($sink)) {
\file_put_contents($sink, $contents);
} elseif ($sink instanceof StreamInterface) {
$sink->write($contents);
}
}
return $value;
}, function ($reason) use($request, $options) {
$this->invokeStats($request, $options, null, $reason);
if ($this->onRejected) {
($this->onRejected)($reason);
}
return P\Create::rejectionFor($reason);
});
}
/**
* Adds one or more variadic requests, exceptions, callables, or promises
* to the queue.
*
* @param mixed ...$values
*/
public function append(...$values) : void
{
foreach ($values as $value) {
if ($value instanceof ResponseInterface || $value instanceof \Throwable || $value instanceof PromiseInterface || \is_callable($value)) {
$this->queue[] = $value;
} else {
throw new \TypeError('Expected a Response, Promise, Throwable or callable. Found ' . Utils::describeType($value));
}
}
}
/**
* Get the last received request.
*/
public function getLastRequest() : ?RequestInterface
{
return $this->lastRequest;
}
/**
* Get the last received request options.
*/
public function getLastOptions() : array
{
return $this->lastOptions;
}
/**
* Returns the number of remaining items in the queue.
*/
public function count() : int
{
return \count($this->queue);
}
public function reset() : void
{
$this->queue = [];
}
/**
* @param mixed $reason Promise or reason.
*/
private function invokeStats(RequestInterface $request, array $options, ResponseInterface $response = null, $reason = null) : void
{
if (isset($options['on_stats'])) {
$transferTime = $options['transfer_time'] ?? 0;
$stats = new TransferStats($request, $response, $transferTime, $reason);
$options['on_stats']($stats);
}
}
}

View File

@@ -0,0 +1,49 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\RequestOptions;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* Provides basic proxies for handlers.
*
* @final
*/
class Proxy
{
/**
* Sends synchronous requests to a specific handler while sending all other
* requests to another handler.
*
* @param callable(\Psr\Http\Message\RequestInterface, array): \GuzzleHttp\Promise\PromiseInterface $default Handler used for normal responses
* @param callable(\Psr\Http\Message\RequestInterface, array): \GuzzleHttp\Promise\PromiseInterface $sync Handler used for synchronous responses.
*
* @return callable(\Psr\Http\Message\RequestInterface, array): \GuzzleHttp\Promise\PromiseInterface Returns the composed handler.
*/
public static function wrapSync(callable $default, callable $sync) : callable
{
return static function (RequestInterface $request, array $options) use($default, $sync) : PromiseInterface {
return empty($options[RequestOptions::SYNCHRONOUS]) ? $default($request, $options) : $sync($request, $options);
};
}
/**
* Sends streaming requests to a streaming compatible handler while sending
* all other requests to a default handler.
*
* This, for example, could be useful for taking advantage of the
* performance benefits of curl while still supporting true streaming
* through the StreamHandler.
*
* @param callable(\Psr\Http\Message\RequestInterface, array): \GuzzleHttp\Promise\PromiseInterface $default Handler used for non-streaming responses
* @param callable(\Psr\Http\Message\RequestInterface, array): \GuzzleHttp\Promise\PromiseInterface $streaming Handler used for streaming responses
*
* @return callable(\Psr\Http\Message\RequestInterface, array): \GuzzleHttp\Promise\PromiseInterface Returns the composed handler.
*/
public static function wrapStreaming(callable $default, callable $streaming) : callable
{
return static function (RequestInterface $request, array $options) use($default, $streaming) : PromiseInterface {
return empty($options['stream']) ? $default($request, $options) : $streaming($request, $options);
};
}
}

View File

@@ -0,0 +1,455 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Handler;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\ConnectException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\RequestException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\FulfilledPromise;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Psr7;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\TransferStats;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Utils;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\StreamInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\UriInterface;
/**
* HTTP handler that uses PHP's HTTP stream wrapper.
*
* @final
*/
class StreamHandler
{
/**
* @var array
*/
private $lastHeaders = [];
/**
* Sends an HTTP request.
*
* @param RequestInterface $request Request to send.
* @param array $options Request transfer options.
*/
public function __invoke(RequestInterface $request, array $options) : PromiseInterface
{
// Sleep if there is a delay specified.
if (isset($options['delay'])) {
\usleep($options['delay'] * 1000);
}
$startTime = isset($options['on_stats']) ? Utils::currentTime() : null;
try {
// Does not support the expect header.
$request = $request->withoutHeader('Expect');
// Append a content-length header if body size is zero to match
// cURL's behavior.
if (0 === $request->getBody()->getSize()) {
$request = $request->withHeader('Content-Length', '0');
}
return $this->createResponse($request, $options, $this->createStream($request, $options), $startTime);
} catch (\InvalidArgumentException $e) {
throw $e;
} catch (\Exception $e) {
// Determine if the error was a networking error.
$message = $e->getMessage();
// This list can probably get more comprehensive.
if (\false !== \strpos($message, 'getaddrinfo') || \false !== \strpos($message, 'Connection refused') || \false !== \strpos($message, "couldn't connect to host") || \false !== \strpos($message, 'connection attempt failed')) {
$e = new ConnectException($e->getMessage(), $request, $e);
} else {
$e = RequestException::wrapException($request, $e);
}
$this->invokeStats($options, $request, $startTime, null, $e);
return P\Create::rejectionFor($e);
}
}
private function invokeStats(array $options, RequestInterface $request, ?float $startTime, ResponseInterface $response = null, \Throwable $error = null) : void
{
if (isset($options['on_stats'])) {
$stats = new TransferStats($request, $response, Utils::currentTime() - $startTime, $error, []);
$options['on_stats']($stats);
}
}
/**
* @param resource $stream
*/
private function createResponse(RequestInterface $request, array $options, $stream, ?float $startTime) : PromiseInterface
{
$hdrs = $this->lastHeaders;
$this->lastHeaders = [];
try {
[$ver, $status, $reason, $headers] = HeaderProcessor::parseHeaders($hdrs);
} catch (\Exception $e) {
return P\Create::rejectionFor(new RequestException('An error was encountered while creating the response', $request, null, $e));
}
[$stream, $headers] = $this->checkDecode($options, $headers, $stream);
$stream = Psr7\Utils::streamFor($stream);
$sink = $stream;
if (\strcasecmp('HEAD', $request->getMethod())) {
$sink = $this->createSink($stream, $options);
}
try {
$response = new Psr7\Response($status, $headers, $sink, $ver, $reason);
} catch (\Exception $e) {
return P\Create::rejectionFor(new RequestException('An error was encountered while creating the response', $request, null, $e));
}
if (isset($options['on_headers'])) {
try {
$options['on_headers']($response);
} catch (\Exception $e) {
return P\Create::rejectionFor(new RequestException('An error was encountered during the on_headers event', $request, $response, $e));
}
}
// Do not drain when the request is a HEAD request because they have
// no body.
if ($sink !== $stream) {
$this->drain($stream, $sink, $response->getHeaderLine('Content-Length'));
}
$this->invokeStats($options, $request, $startTime, $response, null);
return new FulfilledPromise($response);
}
private function createSink(StreamInterface $stream, array $options) : StreamInterface
{
if (!empty($options['stream'])) {
return $stream;
}
$sink = $options['sink'] ?? Psr7\Utils::tryFopen('php://temp', 'r+');
return \is_string($sink) ? new Psr7\LazyOpenStream($sink, 'w+') : Psr7\Utils::streamFor($sink);
}
/**
* @param resource $stream
*/
private function checkDecode(array $options, array $headers, $stream) : array
{
// Automatically decode responses when instructed.
if (!empty($options['decode_content'])) {
$normalizedKeys = Utils::normalizeHeaderKeys($headers);
if (isset($normalizedKeys['content-encoding'])) {
$encoding = $headers[$normalizedKeys['content-encoding']];
if ($encoding[0] === 'gzip' || $encoding[0] === 'deflate') {
$stream = new Psr7\InflateStream(Psr7\Utils::streamFor($stream));
$headers['x-encoded-content-encoding'] = $headers[$normalizedKeys['content-encoding']];
// Remove content-encoding header
unset($headers[$normalizedKeys['content-encoding']]);
// Fix content-length header
if (isset($normalizedKeys['content-length'])) {
$headers['x-encoded-content-length'] = $headers[$normalizedKeys['content-length']];
$length = (int) $stream->getSize();
if ($length === 0) {
unset($headers[$normalizedKeys['content-length']]);
} else {
$headers[$normalizedKeys['content-length']] = [$length];
}
}
}
}
}
return [$stream, $headers];
}
/**
* Drains the source stream into the "sink" client option.
*
* @param string $contentLength Header specifying the amount of
* data to read.
*
* @throws \RuntimeException when the sink option is invalid.
*/
private function drain(StreamInterface $source, StreamInterface $sink, string $contentLength) : StreamInterface
{
// If a content-length header is provided, then stop reading once
// that number of bytes has been read. This can prevent infinitely
// reading from a stream when dealing with servers that do not honor
// Connection: Close headers.
Psr7\Utils::copyToStream($source, $sink, \strlen($contentLength) > 0 && (int) $contentLength > 0 ? (int) $contentLength : -1);
$sink->seek(0);
$source->close();
return $sink;
}
/**
* Create a resource and check to ensure it was created successfully
*
* @param callable $callback Callable that returns stream resource
*
* @return resource
*
* @throws \RuntimeException on error
*/
private function createResource(callable $callback)
{
$errors = [];
\set_error_handler(static function ($_, $msg, $file, $line) use(&$errors) : bool {
$errors[] = ['message' => $msg, 'file' => $file, 'line' => $line];
return \true;
});
try {
$resource = $callback();
} finally {
\restore_error_handler();
}
if (!$resource) {
$message = 'Error creating resource: ';
foreach ($errors as $err) {
foreach ($err as $key => $value) {
$message .= "[{$key}] {$value}" . \PHP_EOL;
}
}
throw new \RuntimeException(\trim($message));
}
return $resource;
}
/**
* @return resource
*/
private function createStream(RequestInterface $request, array $options)
{
static $methods;
if (!$methods) {
$methods = \array_flip(\get_class_methods(__CLASS__));
}
if (!\in_array($request->getUri()->getScheme(), ['http', 'https'])) {
throw new RequestException(\sprintf("The scheme '%s' is not supported.", $request->getUri()->getScheme()), $request);
}
// HTTP/1.1 streams using the PHP stream wrapper require a
// Connection: close header
if ($request->getProtocolVersion() == '1.1' && !$request->hasHeader('Connection')) {
$request = $request->withHeader('Connection', 'close');
}
// Ensure SSL is verified by default
if (!isset($options['verify'])) {
$options['verify'] = \true;
}
$params = [];
$context = $this->getDefaultContext($request);
if (isset($options['on_headers']) && !\is_callable($options['on_headers'])) {
throw new \InvalidArgumentException('on_headers must be callable');
}
if (!empty($options)) {
foreach ($options as $key => $value) {
$method = "add_{$key}";
if (isset($methods[$method])) {
$this->{$method}($request, $context, $value, $params);
}
}
}
if (isset($options['stream_context'])) {
if (!\is_array($options['stream_context'])) {
throw new \InvalidArgumentException('stream_context must be an array');
}
$context = \array_replace_recursive($context, $options['stream_context']);
}
// Microsoft NTLM authentication only supported with curl handler
if (isset($options['auth'][2]) && 'ntlm' === $options['auth'][2]) {
throw new \InvalidArgumentException('Microsoft NTLM authentication only supported with curl handler');
}
$uri = $this->resolveHost($request, $options);
$contextResource = $this->createResource(static function () use($context, $params) {
return \stream_context_create($context, $params);
});
return $this->createResource(function () use($uri, &$http_response_header, $contextResource, $context, $options, $request) {
$resource = @\fopen((string) $uri, 'r', \false, $contextResource);
$this->lastHeaders = $http_response_header ?? [];
if (\false === $resource) {
throw new ConnectException(\sprintf('Connection refused for URI %s', $uri), $request, null, $context);
}
if (isset($options['read_timeout'])) {
$readTimeout = $options['read_timeout'];
$sec = (int) $readTimeout;
$usec = ($readTimeout - $sec) * 100000;
\stream_set_timeout($resource, $sec, $usec);
}
return $resource;
});
}
private function resolveHost(RequestInterface $request, array $options) : UriInterface
{
$uri = $request->getUri();
if (isset($options['force_ip_resolve']) && !\filter_var($uri->getHost(), \FILTER_VALIDATE_IP)) {
if ('v4' === $options['force_ip_resolve']) {
$records = \dns_get_record($uri->getHost(), \DNS_A);
if (\false === $records || !isset($records[0]['ip'])) {
throw new ConnectException(\sprintf("Could not resolve IPv4 address for host '%s'", $uri->getHost()), $request);
}
return $uri->withHost($records[0]['ip']);
}
if ('v6' === $options['force_ip_resolve']) {
$records = \dns_get_record($uri->getHost(), \DNS_AAAA);
if (\false === $records || !isset($records[0]['ipv6'])) {
throw new ConnectException(\sprintf("Could not resolve IPv6 address for host '%s'", $uri->getHost()), $request);
}
return $uri->withHost('[' . $records[0]['ipv6'] . ']');
}
}
return $uri;
}
private function getDefaultContext(RequestInterface $request) : array
{
$headers = '';
foreach ($request->getHeaders() as $name => $value) {
foreach ($value as $val) {
$headers .= "{$name}: {$val}\r\n";
}
}
$context = ['http' => ['method' => $request->getMethod(), 'header' => $headers, 'protocol_version' => $request->getProtocolVersion(), 'ignore_errors' => \true, 'follow_location' => 0], 'ssl' => ['peer_name' => $request->getUri()->getHost()]];
$body = (string) $request->getBody();
if ('' !== $body) {
$context['http']['content'] = $body;
// Prevent the HTTP handler from adding a Content-Type header.
if (!$request->hasHeader('Content-Type')) {
$context['http']['header'] .= "Content-Type:\r\n";
}
}
$context['http']['header'] = \rtrim($context['http']['header']);
return $context;
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_proxy(RequestInterface $request, array &$options, $value, array &$params) : void
{
$uri = null;
if (!\is_array($value)) {
$uri = $value;
} else {
$scheme = $request->getUri()->getScheme();
if (isset($value[$scheme])) {
if (!isset($value['no']) || !Utils::isHostInNoProxy($request->getUri()->getHost(), $value['no'])) {
$uri = $value[$scheme];
}
}
}
if (!$uri) {
return;
}
$parsed = $this->parse_proxy($uri);
$options['http']['proxy'] = $parsed['proxy'];
if ($parsed['auth']) {
if (!isset($options['http']['header'])) {
$options['http']['header'] = [];
}
$options['http']['header'] .= "\r\nProxy-Authorization: {$parsed['auth']}";
}
}
/**
* Parses the given proxy URL to make it compatible with the format PHP's stream context expects.
*/
private function parse_proxy(string $url) : array
{
$parsed = \parse_url($url);
if ($parsed !== \false && isset($parsed['scheme']) && $parsed['scheme'] === 'http') {
if (isset($parsed['host']) && isset($parsed['port'])) {
$auth = null;
if (isset($parsed['user']) && isset($parsed['pass'])) {
$auth = \base64_encode("{$parsed['user']}:{$parsed['pass']}");
}
return ['proxy' => "tcp://{$parsed['host']}:{$parsed['port']}", 'auth' => $auth ? "Basic {$auth}" : null];
}
}
// Return proxy as-is.
return ['proxy' => $url, 'auth' => null];
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_timeout(RequestInterface $request, array &$options, $value, array &$params) : void
{
if ($value > 0) {
$options['http']['timeout'] = $value;
}
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_crypto_method(RequestInterface $request, array &$options, $value, array &$params) : void
{
if ($value === \STREAM_CRYPTO_METHOD_TLSv1_0_CLIENT || $value === \STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT || $value === \STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT || \defined('STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT') && $value === \STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT) {
$options['http']['crypto_method'] = $value;
return;
}
throw new \InvalidArgumentException('Invalid crypto_method request option: unknown version provided');
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_verify(RequestInterface $request, array &$options, $value, array &$params) : void
{
if ($value === \false) {
$options['ssl']['verify_peer'] = \false;
$options['ssl']['verify_peer_name'] = \false;
return;
}
if (\is_string($value)) {
$options['ssl']['cafile'] = $value;
if (!\file_exists($value)) {
throw new \RuntimeException("SSL CA bundle not found: {$value}");
}
} elseif ($value !== \true) {
throw new \InvalidArgumentException('Invalid verify request option');
}
$options['ssl']['verify_peer'] = \true;
$options['ssl']['verify_peer_name'] = \true;
$options['ssl']['allow_self_signed'] = \false;
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_cert(RequestInterface $request, array &$options, $value, array &$params) : void
{
if (\is_array($value)) {
$options['ssl']['passphrase'] = $value[1];
$value = $value[0];
}
if (!\file_exists($value)) {
throw new \RuntimeException("SSL certificate not found: {$value}");
}
$options['ssl']['local_cert'] = $value;
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_progress(RequestInterface $request, array &$options, $value, array &$params) : void
{
self::addNotification($params, static function ($code, $a, $b, $c, $transferred, $total) use($value) {
if ($code == \STREAM_NOTIFY_PROGRESS) {
// The upload progress cannot be determined. Use 0 for cURL compatibility:
// https://curl.se/libcurl/c/CURLOPT_PROGRESSFUNCTION.html
$value($total, $transferred, 0, 0);
}
});
}
/**
* @param mixed $value as passed via Request transfer options.
*/
private function add_debug(RequestInterface $request, array &$options, $value, array &$params) : void
{
if ($value === \false) {
return;
}
static $map = [\STREAM_NOTIFY_CONNECT => 'CONNECT', \STREAM_NOTIFY_AUTH_REQUIRED => 'AUTH_REQUIRED', \STREAM_NOTIFY_AUTH_RESULT => 'AUTH_RESULT', \STREAM_NOTIFY_MIME_TYPE_IS => 'MIME_TYPE_IS', \STREAM_NOTIFY_FILE_SIZE_IS => 'FILE_SIZE_IS', \STREAM_NOTIFY_REDIRECTED => 'REDIRECTED', \STREAM_NOTIFY_PROGRESS => 'PROGRESS', \STREAM_NOTIFY_FAILURE => 'FAILURE', \STREAM_NOTIFY_COMPLETED => 'COMPLETED', \STREAM_NOTIFY_RESOLVE => 'RESOLVE'];
static $args = ['severity', 'message', 'message_code', 'bytes_transferred', 'bytes_max'];
$value = Utils::debugResource($value);
$ident = $request->getMethod() . ' ' . $request->getUri()->withFragment('');
self::addNotification($params, static function (int $code, ...$passed) use($ident, $value, $map, $args) : void {
\fprintf($value, '<%s> [%s] ', $ident, $map[$code]);
foreach (\array_filter($passed) as $i => $v) {
\fwrite($value, $args[$i] . ': "' . $v . '" ');
}
\fwrite($value, "\n");
});
}
private static function addNotification(array &$params, callable $notify) : void
{
// Wrap the existing function if needed.
if (!isset($params['notification'])) {
$params['notification'] = $notify;
} else {
$params['notification'] = self::callArray([$params['notification'], $notify]);
}
}
private static function callArray(array $functions) : callable
{
return static function (...$args) use($functions) {
foreach ($functions as $fn) {
$fn(...$args);
}
};
}
}

View File

@@ -0,0 +1,238 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
/**
* Creates a composed Guzzle handler function by stacking middlewares on top of
* an HTTP handler function.
*
* @final
*/
class HandlerStack
{
/**
* @var (callable(RequestInterface, array): PromiseInterface)|null
*/
private $handler;
/**
* @var array{(callable(callable(RequestInterface, array): PromiseInterface): callable), (string|null)}[]
*/
private $stack = [];
/**
* @var (callable(RequestInterface, array): PromiseInterface)|null
*/
private $cached;
/**
* Creates a default handler stack that can be used by clients.
*
* The returned handler will wrap the provided handler or use the most
* appropriate default handler for your system. The returned HandlerStack has
* support for cookies, redirects, HTTP error exceptions, and preparing a body
* before sending.
*
* The returned handler stack can be passed to a client in the "handler"
* option.
*
* @param (callable(RequestInterface, array): PromiseInterface)|null $handler HTTP handler function to use with the stack. If no
* handler is provided, the best handler for your
* system will be utilized.
*/
public static function create(callable $handler = null) : self
{
$stack = new self($handler ?: Utils::chooseHandler());
$stack->push(Middleware::httpErrors(), 'http_errors');
$stack->push(Middleware::redirect(), 'allow_redirects');
$stack->push(Middleware::cookies(), 'cookies');
$stack->push(Middleware::prepareBody(), 'prepare_body');
return $stack;
}
/**
* @param (callable(RequestInterface, array): PromiseInterface)|null $handler Underlying HTTP handler.
*/
public function __construct(callable $handler = null)
{
$this->handler = $handler;
}
/**
* Invokes the handler stack as a composed handler
*
* @return ResponseInterface|PromiseInterface
*/
public function __invoke(RequestInterface $request, array $options)
{
$handler = $this->resolve();
return $handler($request, $options);
}
/**
* Dumps a string representation of the stack.
*
* @return string
*/
public function __toString()
{
$depth = 0;
$stack = [];
if ($this->handler !== null) {
$stack[] = '0) Handler: ' . $this->debugCallable($this->handler);
}
$result = '';
foreach (\array_reverse($this->stack) as $tuple) {
++$depth;
$str = "{$depth}) Name: '{$tuple[1]}', ";
$str .= 'Function: ' . $this->debugCallable($tuple[0]);
$result = "> {$str}\n{$result}";
$stack[] = $str;
}
foreach (\array_keys($stack) as $k) {
$result .= "< {$stack[$k]}\n";
}
return $result;
}
/**
* Set the HTTP handler that actually returns a promise.
*
* @param callable(RequestInterface, array): PromiseInterface $handler Accepts a request and array of options and
* returns a Promise.
*/
public function setHandler(callable $handler) : void
{
$this->handler = $handler;
$this->cached = null;
}
/**
* Returns true if the builder has a handler.
*/
public function hasHandler() : bool
{
return $this->handler !== null;
}
/**
* Unshift a middleware to the bottom of the stack.
*
* @param callable(callable): callable $middleware Middleware function
* @param string $name Name to register for this middleware.
*/
public function unshift(callable $middleware, string $name = null) : void
{
\array_unshift($this->stack, [$middleware, $name]);
$this->cached = null;
}
/**
* Push a middleware to the top of the stack.
*
* @param callable(callable): callable $middleware Middleware function
* @param string $name Name to register for this middleware.
*/
public function push(callable $middleware, string $name = '') : void
{
$this->stack[] = [$middleware, $name];
$this->cached = null;
}
/**
* Add a middleware before another middleware by name.
*
* @param string $findName Middleware to find
* @param callable(callable): callable $middleware Middleware function
* @param string $withName Name to register for this middleware.
*/
public function before(string $findName, callable $middleware, string $withName = '') : void
{
$this->splice($findName, $withName, $middleware, \true);
}
/**
* Add a middleware after another middleware by name.
*
* @param string $findName Middleware to find
* @param callable(callable): callable $middleware Middleware function
* @param string $withName Name to register for this middleware.
*/
public function after(string $findName, callable $middleware, string $withName = '') : void
{
$this->splice($findName, $withName, $middleware, \false);
}
/**
* Remove a middleware by instance or name from the stack.
*
* @param callable|string $remove Middleware to remove by instance or name.
*/
public function remove($remove) : void
{
if (!\is_string($remove) && !\is_callable($remove)) {
trigger_deprecation('guzzlehttp/guzzle', '7.4', 'Not passing a callable or string to %s::%s() is deprecated and will cause an error in 8.0.', __CLASS__, __FUNCTION__);
}
$this->cached = null;
$idx = \is_callable($remove) ? 0 : 1;
$this->stack = \array_values(\array_filter($this->stack, static function ($tuple) use($idx, $remove) {
return $tuple[$idx] !== $remove;
}));
}
/**
* Compose the middleware and handler into a single callable function.
*
* @return callable(RequestInterface, array): PromiseInterface
*/
public function resolve() : callable
{
if ($this->cached === null) {
if (($prev = $this->handler) === null) {
throw new \LogicException('No handler has been specified');
}
foreach (\array_reverse($this->stack) as $fn) {
/** @var callable(RequestInterface, array): PromiseInterface $prev */
$prev = $fn[0]($prev);
}
$this->cached = $prev;
}
return $this->cached;
}
private function findByName(string $name) : int
{
foreach ($this->stack as $k => $v) {
if ($v[1] === $name) {
return $k;
}
}
throw new \InvalidArgumentException("Middleware not found: {$name}");
}
/**
* Splices a function into the middleware list at a specific position.
*/
private function splice(string $findName, string $withName, callable $middleware, bool $before) : void
{
$this->cached = null;
$idx = $this->findByName($findName);
$tuple = [$middleware, $withName];
if ($before) {
if ($idx === 0) {
\array_unshift($this->stack, $tuple);
} else {
$replacement = [$tuple, $this->stack[$idx]];
\array_splice($this->stack, $idx, 1, $replacement);
}
} elseif ($idx === \count($this->stack) - 1) {
$this->stack[] = $tuple;
} else {
$replacement = [$this->stack[$idx], $tuple];
\array_splice($this->stack, $idx, 1, $replacement);
}
}
/**
* Provides a debug string for a given callable.
*
* @param callable|string $fn Function to write as a string.
*/
private function debugCallable($fn) : string
{
if (\is_string($fn)) {
return "callable({$fn})";
}
if (\is_array($fn)) {
return \is_string($fn[0]) ? "callable({$fn[0]}::{$fn[1]})" : "callable(['" . \get_class($fn[0]) . "', '{$fn[1]}'])";
}
/** @var object $fn */
return 'callable(' . \spl_object_hash($fn) . ')';
}
}

View File

@@ -0,0 +1,168 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\MessageInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
/**
* Formats log messages using variable substitutions for requests, responses,
* and other transactional data.
*
* The following variable substitutions are supported:
*
* - {request}: Full HTTP request message
* - {response}: Full HTTP response message
* - {ts}: ISO 8601 date in GMT
* - {date_iso_8601} ISO 8601 date in GMT
* - {date_common_log} Apache common log date using the configured timezone.
* - {host}: Host of the request
* - {method}: Method of the request
* - {uri}: URI of the request
* - {version}: Protocol version
* - {target}: Request target of the request (path + query + fragment)
* - {hostname}: Hostname of the machine that sent the request
* - {code}: Status code of the response (if available)
* - {phrase}: Reason phrase of the response (if available)
* - {error}: Any error messages (if available)
* - {req_header_*}: Replace `*` with the lowercased name of a request header to add to the message
* - {res_header_*}: Replace `*` with the lowercased name of a response header to add to the message
* - {req_headers}: Request headers
* - {res_headers}: Response headers
* - {req_body}: Request body
* - {res_body}: Response body
*
* @final
*/
class MessageFormatter implements MessageFormatterInterface
{
/**
* Apache Common Log Format.
*
* @see https://httpd.apache.org/docs/2.4/logs.html#common
*
* @var string
*/
public const CLF = '{hostname} {req_header_User-Agent} - [{date_common_log}] "{method} {target} HTTP/{version}" {code} {res_header_Content-Length}';
public const DEBUG = ">>>>>>>>\n{request}\n<<<<<<<<\n{response}\n--------\n{error}";
public const SHORT = '[{ts}] "{method} {target} HTTP/{version}" {code}';
/**
* @var string Template used to format log messages
*/
private $template;
/**
* @param string $template Log message template
*/
public function __construct(?string $template = self::CLF)
{
$this->template = $template ?: self::CLF;
}
/**
* Returns a formatted message string.
*
* @param RequestInterface $request Request that was sent
* @param ResponseInterface|null $response Response that was received
* @param \Throwable|null $error Exception that was received
*/
public function format(RequestInterface $request, ResponseInterface $response = null, \Throwable $error = null) : string
{
$cache = [];
/** @var string */
return \preg_replace_callback('/{\\s*([A-Za-z_\\-\\.0-9]+)\\s*}/', function (array $matches) use($request, $response, $error, &$cache) {
if (isset($cache[$matches[1]])) {
return $cache[$matches[1]];
}
$result = '';
switch ($matches[1]) {
case 'request':
$result = Psr7\Message::toString($request);
break;
case 'response':
$result = $response ? Psr7\Message::toString($response) : '';
break;
case 'req_headers':
$result = \trim($request->getMethod() . ' ' . $request->getRequestTarget()) . ' HTTP/' . $request->getProtocolVersion() . "\r\n" . $this->headers($request);
break;
case 'res_headers':
$result = $response ? \sprintf('HTTP/%s %d %s', $response->getProtocolVersion(), $response->getStatusCode(), $response->getReasonPhrase()) . "\r\n" . $this->headers($response) : 'NULL';
break;
case 'req_body':
$result = $request->getBody()->__toString();
break;
case 'res_body':
if (!$response instanceof ResponseInterface) {
$result = 'NULL';
break;
}
$body = $response->getBody();
if (!$body->isSeekable()) {
$result = 'RESPONSE_NOT_LOGGEABLE';
break;
}
$result = $response->getBody()->__toString();
break;
case 'ts':
case 'date_iso_8601':
$result = \gmdate('c');
break;
case 'date_common_log':
$result = \date('d/M/Y:H:i:s O');
break;
case 'method':
$result = $request->getMethod();
break;
case 'version':
$result = $request->getProtocolVersion();
break;
case 'uri':
case 'url':
$result = $request->getUri()->__toString();
break;
case 'target':
$result = $request->getRequestTarget();
break;
case 'req_version':
$result = $request->getProtocolVersion();
break;
case 'res_version':
$result = $response ? $response->getProtocolVersion() : 'NULL';
break;
case 'host':
$result = $request->getHeaderLine('Host');
break;
case 'hostname':
$result = \gethostname();
break;
case 'code':
$result = $response ? $response->getStatusCode() : 'NULL';
break;
case 'phrase':
$result = $response ? $response->getReasonPhrase() : 'NULL';
break;
case 'error':
$result = $error ? $error->getMessage() : 'NULL';
break;
default:
// handle prefixed dynamic headers
if (\strpos($matches[1], 'req_header_') === 0) {
$result = $request->getHeaderLine(\substr($matches[1], 11));
} elseif (\strpos($matches[1], 'res_header_') === 0) {
$result = $response ? $response->getHeaderLine(\substr($matches[1], 11)) : 'NULL';
}
}
$cache[$matches[1]] = $result;
return $result;
}, $this->template);
}
/**
* Get headers from message as string
*/
private function headers(MessageInterface $message) : string
{
$result = '';
foreach ($message->getHeaders() as $name => $values) {
$result .= $name . ': ' . \implode(', ', $values) . "\r\n";
}
return \trim($result);
}
}

View File

@@ -0,0 +1,17 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
interface MessageFormatterInterface
{
/**
* Returns a formatted message string.
*
* @param RequestInterface $request Request that was sent
* @param ResponseInterface|null $response Response that was received
* @param \Throwable|null $error Exception that was received
*/
public function format(RequestInterface $request, ResponseInterface $response = null, \Throwable $error = null) : string;
}

View File

@@ -0,0 +1,227 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Cookie\CookieJarInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\RequestException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Log\LoggerInterface;
/**
* Functions used to create and wrap handlers with handler middleware.
*/
final class Middleware
{
/**
* Middleware that adds cookies to requests.
*
* The options array must be set to a CookieJarInterface in order to use
* cookies. This is typically handled for you by a client.
*
* @return callable Returns a function that accepts the next handler.
*/
public static function cookies() : callable
{
return static function (callable $handler) : callable {
return static function ($request, array $options) use($handler) {
if (empty($options['cookies'])) {
return $handler($request, $options);
} elseif (!$options['cookies'] instanceof CookieJarInterface) {
throw new \InvalidArgumentException('Isolated\\Blue_Media\\Isolated_Php_ga4_mp\\cookies must be an instance of GuzzleHttp\\Cookie\\CookieJarInterface');
}
$cookieJar = $options['cookies'];
$request = $cookieJar->withCookieHeader($request);
return $handler($request, $options)->then(static function (ResponseInterface $response) use($cookieJar, $request) : ResponseInterface {
$cookieJar->extractCookies($request, $response);
return $response;
});
};
};
}
/**
* Middleware that throws exceptions for 4xx or 5xx responses when the
* "http_errors" request option is set to true.
*
* @param BodySummarizerInterface|null $bodySummarizer The body summarizer to use in exception messages.
*
* @return callable(callable): callable Returns a function that accepts the next handler.
*/
public static function httpErrors(BodySummarizerInterface $bodySummarizer = null) : callable
{
return static function (callable $handler) use($bodySummarizer) : callable {
return static function ($request, array $options) use($handler, $bodySummarizer) {
if (empty($options['http_errors'])) {
return $handler($request, $options);
}
return $handler($request, $options)->then(static function (ResponseInterface $response) use($request, $bodySummarizer) {
$code = $response->getStatusCode();
if ($code < 400) {
return $response;
}
throw RequestException::create($request, $response, null, [], $bodySummarizer);
});
};
};
}
/**
* Middleware that pushes history data to an ArrayAccess container.
*
* @param array|\ArrayAccess<int, array> $container Container to hold the history (by reference).
*
* @return callable(callable): callable Returns a function that accepts the next handler.
*
* @throws \InvalidArgumentException if container is not an array or ArrayAccess.
*/
public static function history(&$container) : callable
{
if (!\is_array($container) && !$container instanceof \ArrayAccess) {
throw new \InvalidArgumentException('history container must be an array or object implementing ArrayAccess');
}
return static function (callable $handler) use(&$container) : callable {
return static function (RequestInterface $request, array $options) use($handler, &$container) {
return $handler($request, $options)->then(static function ($value) use($request, &$container, $options) {
$container[] = ['request' => $request, 'response' => $value, 'error' => null, 'options' => $options];
return $value;
}, static function ($reason) use($request, &$container, $options) {
$container[] = ['request' => $request, 'response' => null, 'error' => $reason, 'options' => $options];
return P\Create::rejectionFor($reason);
});
};
};
}
/**
* Middleware that invokes a callback before and after sending a request.
*
* The provided listener cannot modify or alter the response. It simply
* "taps" into the chain to be notified before returning the promise. The
* before listener accepts a request and options array, and the after
* listener accepts a request, options array, and response promise.
*
* @param callable $before Function to invoke before forwarding the request.
* @param callable $after Function invoked after forwarding.
*
* @return callable Returns a function that accepts the next handler.
*/
public static function tap(callable $before = null, callable $after = null) : callable
{
return static function (callable $handler) use($before, $after) : callable {
return static function (RequestInterface $request, array $options) use($handler, $before, $after) {
if ($before) {
$before($request, $options);
}
$response = $handler($request, $options);
if ($after) {
$after($request, $options, $response);
}
return $response;
};
};
}
/**
* Middleware that handles request redirects.
*
* @return callable Returns a function that accepts the next handler.
*/
public static function redirect() : callable
{
return static function (callable $handler) : RedirectMiddleware {
return new RedirectMiddleware($handler);
};
}
/**
* Middleware that retries requests based on the boolean result of
* invoking the provided "decider" function.
*
* If no delay function is provided, a simple implementation of exponential
* backoff will be utilized.
*
* @param callable $decider Function that accepts the number of retries,
* a request, [response], and [exception] and
* returns true if the request is to be retried.
* @param callable $delay Function that accepts the number of retries and
* returns the number of milliseconds to delay.
*
* @return callable Returns a function that accepts the next handler.
*/
public static function retry(callable $decider, callable $delay = null) : callable
{
return static function (callable $handler) use($decider, $delay) : RetryMiddleware {
return new RetryMiddleware($decider, $handler, $delay);
};
}
/**
* Middleware that logs requests, responses, and errors using a message
* formatter.
*
* @phpstan-param \Psr\Log\LogLevel::* $logLevel Level at which to log requests.
*
* @param LoggerInterface $logger Logs messages.
* @param MessageFormatterInterface|MessageFormatter $formatter Formatter used to create message strings.
* @param string $logLevel Level at which to log requests.
*
* @return callable Returns a function that accepts the next handler.
*/
public static function log(LoggerInterface $logger, $formatter, string $logLevel = 'info') : callable
{
// To be compatible with Guzzle 7.1.x we need to allow users to pass a MessageFormatter
if (!$formatter instanceof MessageFormatter && !$formatter instanceof MessageFormatterInterface) {
throw new \LogicException(\sprintf('Argument 2 to %s::log() must be of type %s', self::class, MessageFormatterInterface::class));
}
return static function (callable $handler) use($logger, $formatter, $logLevel) : callable {
return static function (RequestInterface $request, array $options = []) use($handler, $logger, $formatter, $logLevel) {
return $handler($request, $options)->then(static function ($response) use($logger, $request, $formatter, $logLevel) : ResponseInterface {
$message = $formatter->format($request, $response);
$logger->log($logLevel, $message);
return $response;
}, static function ($reason) use($logger, $request, $formatter) : PromiseInterface {
$response = $reason instanceof RequestException ? $reason->getResponse() : null;
$message = $formatter->format($request, $response, P\Create::exceptionFor($reason));
$logger->error($message);
return P\Create::rejectionFor($reason);
});
};
};
}
/**
* This middleware adds a default content-type if possible, a default
* content-length or transfer-encoding header, and the expect header.
*/
public static function prepareBody() : callable
{
return static function (callable $handler) : PrepareBodyMiddleware {
return new PrepareBodyMiddleware($handler);
};
}
/**
* Middleware that applies a map function to the request before passing to
* the next handler.
*
* @param callable $fn Function that accepts a RequestInterface and returns
* a RequestInterface.
*/
public static function mapRequest(callable $fn) : callable
{
return static function (callable $handler) use($fn) : callable {
return static function (RequestInterface $request, array $options) use($handler, $fn) {
return $handler($fn($request), $options);
};
};
}
/**
* Middleware that applies a map function to the resolved promise's
* response.
*
* @param callable $fn Function that accepts a ResponseInterface and
* returns a ResponseInterface.
*/
public static function mapResponse(callable $fn) : callable
{
return static function (callable $handler) use($fn) : callable {
return static function (RequestInterface $request, array $options) use($handler, $fn) {
return $handler($request, $options)->then($fn);
};
};
}
}

View File

@@ -0,0 +1,116 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise as P;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\EachPromise;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromisorInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* Sends an iterator of requests concurrently using a capped pool size.
*
* The pool will read from an iterator until it is cancelled or until the
* iterator is consumed. When a request is yielded, the request is sent after
* applying the "request_options" request options (if provided in the ctor).
*
* When a function is yielded by the iterator, the function is provided the
* "request_options" array that should be merged on top of any existing
* options, and the function MUST then return a wait-able promise.
*
* @final
*/
class Pool implements PromisorInterface
{
/**
* @var EachPromise
*/
private $each;
/**
* @param ClientInterface $client Client used to send the requests.
* @param array|\Iterator $requests Requests or functions that return
* requests to send concurrently.
* @param array $config Associative array of options
* - concurrency: (int) Maximum number of requests to send concurrently
* - options: Array of request options to apply to each request.
* - fulfilled: (callable) Function to invoke when a request completes.
* - rejected: (callable) Function to invoke when a request is rejected.
*/
public function __construct(ClientInterface $client, $requests, array $config = [])
{
if (!isset($config['concurrency'])) {
$config['concurrency'] = 25;
}
if (isset($config['options'])) {
$opts = $config['options'];
unset($config['options']);
} else {
$opts = [];
}
$iterable = P\Create::iterFor($requests);
$requests = static function () use($iterable, $client, $opts) {
foreach ($iterable as $key => $rfn) {
if ($rfn instanceof RequestInterface) {
(yield $key => $client->sendAsync($rfn, $opts));
} elseif (\is_callable($rfn)) {
(yield $key => $rfn($opts));
} else {
throw new \InvalidArgumentException('Each value yielded by the iterator must be a Psr7\\Http\\Message\\RequestInterface or a callable that returns a promise that fulfills with a Psr7\\Message\\Http\\ResponseInterface object.');
}
}
};
$this->each = new EachPromise($requests(), $config);
}
/**
* Get promise
*/
public function promise() : PromiseInterface
{
return $this->each->promise();
}
/**
* Sends multiple requests concurrently and returns an array of responses
* and exceptions that uses the same ordering as the provided requests.
*
* IMPORTANT: This method keeps every request and response in memory, and
* as such, is NOT recommended when sending a large number or an
* indeterminate number of requests concurrently.
*
* @param ClientInterface $client Client used to send the requests
* @param array|\Iterator $requests Requests to send concurrently.
* @param array $options Passes through the options available in
* {@see \GuzzleHttp\Pool::__construct}
*
* @return array Returns an array containing the response or an exception
* in the same order that the requests were sent.
*
* @throws \InvalidArgumentException if the event format is incorrect.
*/
public static function batch(ClientInterface $client, $requests, array $options = []) : array
{
$res = [];
self::cmpCallback($options, 'fulfilled', $res);
self::cmpCallback($options, 'rejected', $res);
$pool = new static($client, $requests, $options);
$pool->promise()->wait();
\ksort($res);
return $res;
}
/**
* Execute callback(s)
*/
private static function cmpCallback(array &$options, string $name, array &$results) : void
{
if (!isset($options[$name])) {
$options[$name] = static function ($v, $k) use(&$results) {
$results[$k] = $v;
};
} else {
$currentFn = $options[$name];
$options[$name] = static function ($v, $k) use(&$results, $currentFn) {
$currentFn($v, $k);
$results[$k] = $v;
};
}
}
}

View File

@@ -0,0 +1,86 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
/**
* Prepares requests that contain a body, adding the Content-Length,
* Content-Type, and Expect headers.
*
* @final
*/
class PrepareBodyMiddleware
{
/**
* @var callable(RequestInterface, array): PromiseInterface
*/
private $nextHandler;
/**
* @param callable(RequestInterface, array): PromiseInterface $nextHandler Next handler to invoke.
*/
public function __construct(callable $nextHandler)
{
$this->nextHandler = $nextHandler;
}
public function __invoke(RequestInterface $request, array $options) : PromiseInterface
{
$fn = $this->nextHandler;
// Don't do anything if the request has no body.
if ($request->getBody()->getSize() === 0) {
return $fn($request, $options);
}
$modify = [];
// Add a default content-type if possible.
if (!$request->hasHeader('Content-Type')) {
if ($uri = $request->getBody()->getMetadata('uri')) {
if (\is_string($uri) && ($type = Psr7\MimeType::fromFilename($uri))) {
$modify['set_headers']['Content-Type'] = $type;
}
}
}
// Add a default content-length or transfer-encoding header.
if (!$request->hasHeader('Content-Length') && !$request->hasHeader('Transfer-Encoding')) {
$size = $request->getBody()->getSize();
if ($size !== null) {
$modify['set_headers']['Content-Length'] = $size;
} else {
$modify['set_headers']['Transfer-Encoding'] = 'chunked';
}
}
// Add the expect header if needed.
$this->addExpectHeader($request, $options, $modify);
return $fn(Psr7\Utils::modifyRequest($request, $modify), $options);
}
/**
* Add expect header
*/
private function addExpectHeader(RequestInterface $request, array $options, array &$modify) : void
{
// Determine if the Expect header should be used
if ($request->hasHeader('Expect')) {
return;
}
$expect = $options['expect'] ?? null;
// Return if disabled or if you're not using HTTP/1.1 or HTTP/2.0
if ($expect === \false || $request->getProtocolVersion() < 1.1) {
return;
}
// The expect header is unconditionally enabled
if ($expect === \true) {
$modify['set_headers']['Expect'] = '100-Continue';
return;
}
// By default, send the expect header when the payload is > 1mb
if ($expect === null) {
$expect = 1048576;
}
// Always add if the body cannot be rewound, the size cannot be
// determined, or the size is greater than the cutoff threshold
$body = $request->getBody();
$size = $body->getSize();
if ($size === null || $size >= (int) $expect || !$body->isSeekable()) {
$modify['set_headers']['Expect'] = '100-Continue';
}
}
}

View File

@@ -0,0 +1,162 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\BadResponseException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Exception\TooManyRedirectsException;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp\Promise\PromiseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\RequestInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\ResponseInterface;
use Isolated\Blue_Media\Isolated_Php_ga4_mp\Psr\Http\Message\UriInterface;
/**
* Request redirect middleware.
*
* Apply this middleware like other middleware using
* {@see \GuzzleHttp\Middleware::redirect()}.
*
* @final
*/
class RedirectMiddleware
{
public const HISTORY_HEADER = 'X-Guzzle-Redirect-History';
public const STATUS_HISTORY_HEADER = 'X-Guzzle-Redirect-Status-History';
/**
* @var array
*/
public static $defaultSettings = ['max' => 5, 'protocols' => ['http', 'https'], 'strict' => \false, 'referer' => \false, 'track_redirects' => \false];
/**
* @var callable(RequestInterface, array): PromiseInterface
*/
private $nextHandler;
/**
* @param callable(RequestInterface, array): PromiseInterface $nextHandler Next handler to invoke.
*/
public function __construct(callable $nextHandler)
{
$this->nextHandler = $nextHandler;
}
public function __invoke(RequestInterface $request, array $options) : PromiseInterface
{
$fn = $this->nextHandler;
if (empty($options['allow_redirects'])) {
return $fn($request, $options);
}
if ($options['allow_redirects'] === \true) {
$options['allow_redirects'] = self::$defaultSettings;
} elseif (!\is_array($options['allow_redirects'])) {
throw new \InvalidArgumentException('allow_redirects must be true, false, or array');
} else {
// Merge the default settings with the provided settings
$options['allow_redirects'] += self::$defaultSettings;
}
if (empty($options['allow_redirects']['max'])) {
return $fn($request, $options);
}
return $fn($request, $options)->then(function (ResponseInterface $response) use($request, $options) {
return $this->checkRedirect($request, $options, $response);
});
}
/**
* @return ResponseInterface|PromiseInterface
*/
public function checkRedirect(RequestInterface $request, array $options, ResponseInterface $response)
{
if (\strpos((string) $response->getStatusCode(), '3') !== 0 || !$response->hasHeader('Location')) {
return $response;
}
$this->guardMax($request, $response, $options);
$nextRequest = $this->modifyRequest($request, $options, $response);
// If authorization is handled by curl, unset it if URI is cross-origin.
if (Psr7\UriComparator::isCrossOrigin($request->getUri(), $nextRequest->getUri()) && \defined('\\CURLOPT_HTTPAUTH')) {
unset($options['curl'][\CURLOPT_HTTPAUTH], $options['curl'][\CURLOPT_USERPWD]);
}
if (isset($options['allow_redirects']['on_redirect'])) {
$options['allow_redirects']['on_redirect']($request, $response, $nextRequest->getUri());
}
$promise = $this($nextRequest, $options);
// Add headers to be able to track history of redirects.
if (!empty($options['allow_redirects']['track_redirects'])) {
return $this->withTracking($promise, (string) $nextRequest->getUri(), $response->getStatusCode());
}
return $promise;
}
/**
* Enable tracking on promise.
*/
private function withTracking(PromiseInterface $promise, string $uri, int $statusCode) : PromiseInterface
{
return $promise->then(static function (ResponseInterface $response) use($uri, $statusCode) {
// Note that we are pushing to the front of the list as this
// would be an earlier response than what is currently present
// in the history header.
$historyHeader = $response->getHeader(self::HISTORY_HEADER);
$statusHeader = $response->getHeader(self::STATUS_HISTORY_HEADER);
\array_unshift($historyHeader, $uri);
\array_unshift($statusHeader, (string) $statusCode);
return $response->withHeader(self::HISTORY_HEADER, $historyHeader)->withHeader(self::STATUS_HISTORY_HEADER, $statusHeader);
});
}
/**
* Check for too many redirects.
*
* @throws TooManyRedirectsException Too many redirects.
*/
private function guardMax(RequestInterface $request, ResponseInterface $response, array &$options) : void
{
$current = $options['__redirect_count'] ?? 0;
$options['__redirect_count'] = $current + 1;
$max = $options['allow_redirects']['max'];
if ($options['__redirect_count'] > $max) {
throw new TooManyRedirectsException("Will not follow more than {$max} redirects", $request, $response);
}
}
public function modifyRequest(RequestInterface $request, array $options, ResponseInterface $response) : RequestInterface
{
// Request modifications to apply.
$modify = [];
$protocols = $options['allow_redirects']['protocols'];
// Use a GET request if this is an entity enclosing request and we are
// not forcing RFC compliance, but rather emulating what all browsers
// would do.
$statusCode = $response->getStatusCode();
if ($statusCode == 303 || $statusCode <= 302 && !$options['allow_redirects']['strict']) {
$safeMethods = ['GET', 'HEAD', 'OPTIONS'];
$requestMethod = $request->getMethod();
$modify['method'] = \in_array($requestMethod, $safeMethods) ? $requestMethod : 'GET';
$modify['body'] = '';
}
$uri = self::redirectUri($request, $response, $protocols);
if (isset($options['idn_conversion']) && $options['idn_conversion'] !== \false) {
$idnOptions = $options['idn_conversion'] === \true ? \IDNA_DEFAULT : $options['idn_conversion'];
$uri = Utils::idnUriConvert($uri, $idnOptions);
}
$modify['uri'] = $uri;
Psr7\Message::rewindBody($request);
// Add the Referer header if it is told to do so and only
// add the header if we are not redirecting from https to http.
if ($options['allow_redirects']['referer'] && $modify['uri']->getScheme() === $request->getUri()->getScheme()) {
$uri = $request->getUri()->withUserInfo('');
$modify['set_headers']['Referer'] = (string) $uri;
} else {
$modify['remove_headers'][] = 'Referer';
}
// Remove Authorization and Cookie headers if URI is cross-origin.
if (Psr7\UriComparator::isCrossOrigin($request->getUri(), $modify['uri'])) {
$modify['remove_headers'][] = 'Authorization';
$modify['remove_headers'][] = 'Cookie';
}
return Psr7\Utils::modifyRequest($request, $modify);
}
/**
* Set the appropriate URL on the request based on the location header.
*/
private static function redirectUri(RequestInterface $request, ResponseInterface $response, array $protocols) : UriInterface
{
$location = Psr7\UriResolver::resolve($request->getUri(), new Psr7\Uri($response->getHeaderLine('Location')));
// Ensure that the redirect URI is allowed based on the protocols.
if (!\in_array($location->getScheme(), $protocols)) {
throw new BadResponseException(\sprintf('Redirect URI, %s, does not use one of the allowed redirect protocols: %s', $location, \implode(', ', $protocols)), $request, $response);
}
return $location;
}
}

View File

@@ -0,0 +1,246 @@
<?php
namespace Isolated\Blue_Media\Isolated_Php_ga4_mp\GuzzleHttp;
/**
* This class contains a list of built-in Guzzle request options.
*
* More documentation for each option can be found at http://guzzlephp.org/.
*
* @see http://docs.guzzlephp.org/en/v6/request-options.html
*/
final class RequestOptions
{
/**
* allow_redirects: (bool|array) Controls redirect behavior. Pass false
* to disable redirects, pass true to enable redirects, pass an
* associative to provide custom redirect settings. Defaults to "false".
* This option only works if your handler has the RedirectMiddleware. When
* passing an associative array, you can provide the following key value
* pairs:
*
* - max: (int, default=5) maximum number of allowed redirects.
* - strict: (bool, default=false) Set to true to use strict redirects
* meaning redirect POST requests with POST requests vs. doing what most
* browsers do which is redirect POST requests with GET requests
* - referer: (bool, default=false) Set to true to enable the Referer
* header.
* - protocols: (array, default=['http', 'https']) Allowed redirect
* protocols.
* - on_redirect: (callable) PHP callable that is invoked when a redirect
* is encountered. The callable is invoked with the request, the redirect
* response that was received, and the effective URI. Any return value
* from the on_redirect function is ignored.
*/
public const ALLOW_REDIRECTS = 'allow_redirects';
/**
* auth: (array) Pass an array of HTTP authentication parameters to use
* with the request. The array must contain the username in index [0],
* the password in index [1], and you can optionally provide a built-in
* authentication type in index [2]. Pass null to disable authentication
* for a request.
*/
public const AUTH = 'auth';
/**
* body: (resource|string|null|int|float|StreamInterface|callable|\Iterator)
* Body to send in the request.
*/
public const BODY = 'body';
/**
* cert: (string|array) Set to a string to specify the path to a file
* containing a PEM formatted SSL client side certificate. If a password
* is required, then set cert to an array containing the path to the PEM
* file in the first array element followed by the certificate password
* in the second array element.
*/
public const CERT = 'cert';
/**
* cookies: (bool|GuzzleHttp\Cookie\CookieJarInterface, default=false)
* Specifies whether or not cookies are used in a request or what cookie
* jar to use or what cookies to send. This option only works if your
* handler has the `cookie` middleware. Valid values are `false` and
* an instance of {@see \GuzzleHttp\Cookie\CookieJarInterface}.
*/
public const COOKIES = 'cookies';
/**
* connect_timeout: (float, default=0) Float describing the number of
* seconds to wait while trying to connect to a server. Use 0 to wait
* 300 seconds (the default behavior).
*/
public const CONNECT_TIMEOUT = 'connect_timeout';
/**
* crypto_method: (int) A value describing the minimum TLS protocol
* version to use.
*
* This setting must be set to one of the
* ``STREAM_CRYPTO_METHOD_TLS*_CLIENT`` constants. PHP 7.4 or higher is
* required in order to use TLS 1.3, and cURL 7.34.0 or higher is required
* in order to specify a crypto method, with cURL 7.52.0 or higher being
* required to use TLS 1.3.
*/
public const CRYPTO_METHOD = 'crypto_method';
/**
* debug: (bool|resource) Set to true or set to a PHP stream returned by
* fopen() enable debug output with the HTTP handler used to send a
* request.
*/
public const DEBUG = 'debug';
/**
* decode_content: (bool, default=true) Specify whether or not
* Content-Encoding responses (gzip, deflate, etc.) are automatically
* decoded.
*/
public const DECODE_CONTENT = 'decode_content';
/**
* delay: (int) The amount of time to delay before sending in milliseconds.
*/
public const DELAY = 'delay';
/**
* expect: (bool|integer) Controls the behavior of the
* "Expect: 100-Continue" header.
*
* Set to `true` to enable the "Expect: 100-Continue" header for all
* requests that sends a body. Set to `false` to disable the
* "Expect: 100-Continue" header for all requests. Set to a number so that
* the size of the payload must be greater than the number in order to send
* the Expect header. Setting to a number will send the Expect header for
* all requests in which the size of the payload cannot be determined or
* where the body is not rewindable.
*
* By default, Guzzle will add the "Expect: 100-Continue" header when the
* size of the body of a request is greater than 1 MB and a request is
* using HTTP/1.1.
*/
public const EXPECT = 'expect';
/**
* form_params: (array) Associative array of form field names to values
* where each value is a string or array of strings. Sets the Content-Type
* header to application/x-www-form-urlencoded when no Content-Type header
* is already present.
*/
public const FORM_PARAMS = 'form_params';
/**
* headers: (array) Associative array of HTTP headers. Each value MUST be
* a string or array of strings.
*/
public const HEADERS = 'headers';
/**
* http_errors: (bool, default=true) Set to false to disable exceptions
* when a non- successful HTTP response is received. By default,
* exceptions will be thrown for 4xx and 5xx responses. This option only
* works if your handler has the `httpErrors` middleware.
*/
public const HTTP_ERRORS = 'http_errors';
/**
* idn: (bool|int, default=true) A combination of IDNA_* constants for
* idn_to_ascii() PHP's function (see "options" parameter). Set to false to
* disable IDN support completely, or to true to use the default
* configuration (IDNA_DEFAULT constant).
*/
public const IDN_CONVERSION = 'idn_conversion';
/**
* json: (mixed) Adds JSON data to a request. The provided value is JSON
* encoded and a Content-Type header of application/json will be added to
* the request if no Content-Type header is already present.
*/
public const JSON = 'json';
/**
* multipart: (array) Array of associative arrays, each containing a
* required "name" key mapping to the form field, name, a required
* "contents" key mapping to a StreamInterface|resource|string, an
* optional "headers" associative array of custom headers, and an
* optional "filename" key mapping to a string to send as the filename in
* the part. If no "filename" key is present, then no "filename" attribute
* will be added to the part.
*/
public const MULTIPART = 'multipart';
/**
* on_headers: (callable) A callable that is invoked when the HTTP headers
* of the response have been received but the body has not yet begun to
* download.
*/
public const ON_HEADERS = 'on_headers';
/**
* on_stats: (callable) allows you to get access to transfer statistics of
* a request and access the lower level transfer details of the handler
* associated with your client. ``on_stats`` is a callable that is invoked
* when a handler has finished sending a request. The callback is invoked
* with transfer statistics about the request, the response received, or
* the error encountered. Included in the data is the total amount of time
* taken to send the request.
*/
public const ON_STATS = 'on_stats';
/**
* progress: (callable) Defines a function to invoke when transfer
* progress is made. The function accepts the following positional
* arguments: the total number of bytes expected to be downloaded, the
* number of bytes downloaded so far, the number of bytes expected to be
* uploaded, the number of bytes uploaded so far.
*/
public const PROGRESS = 'progress';
/**
* proxy: (string|array) Pass a string to specify an HTTP proxy, or an
* array to specify different proxies for different protocols (where the
* key is the protocol and the value is a proxy string).
*/
public const PROXY = 'proxy';
/**
* query: (array|string) Associative array of query string values to add
* to the request. This option uses PHP's http_build_query() to create
* the string representation. Pass a string value if you need more
* control than what this method provides
*/
public const QUERY = 'query';
/**
* sink: (resource|string|StreamInterface) Where the data of the
* response is written to. Defaults to a PHP temp stream. Providing a
* string will write data to a file by the given name.
*/
public const SINK = 'sink';
/**
* synchronous: (bool) Set to true to inform HTTP handlers that you intend
* on waiting on the response. This can be useful for optimizations. Note
* that a promise is still returned if you are using one of the async
* client methods.
*/
public const SYNCHRONOUS = 'synchronous';
/**
* ssl_key: (array|string) Specify the path to a file containing a private
* SSL key in PEM format. If a password is required, then set to an array
* containing the path to the SSL key in the first array element followed
* by the password required for the certificate in the second element.
*/
public const SSL_KEY = 'ssl_key';
/**
* stream: Set to true to attempt to stream a response rather than
* download it all up-front.
*/
public const STREAM = 'stream';
/**
* verify: (bool|string, default=true) Describes the SSL certificate
* verification behavior of a request. Set to true to enable SSL
* certificate verification using the system CA bundle when available
* (the default). Set to false to disable certificate verification (this
* is insecure!). Set to a string to provide the path to a CA bundle on
* disk to enable verification using a custom certificate.
*/
public const VERIFY = 'verify';
/**
* timeout: (float, default=0) Float describing the timeout of the
* request in seconds. Use 0 to wait indefinitely (the default behavior).
*/
public const TIMEOUT = 'timeout';
/**
* read_timeout: (float, default=default_socket_timeout ini setting) Float describing
* the body read timeout, for stream requests.
*/
public const READ_TIMEOUT = 'read_timeout';
/**
* version: (float) Specifies the HTTP protocol version to attempt to use.
*/
public const VERSION = 'version';
/**
* force_ip_resolve: (bool) Force client to use only ipv4 or ipv6 protocol
*/
public const FORCE_IP_RESOLVE = 'force_ip_resolve';
}

Some files were not shown because too many files have changed in this diff Show More