/home/kueuepay/public_html/vendor/spatie/backtrace/src/Arguments/ArgumentReducers.php
<?php

namespace Spatie\Backtrace\Arguments;

use Spatie\Backtrace\Arguments\Reducers\ArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\ArrayArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\BaseTypeArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\ClosureArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\DateTimeArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\DateTimeZoneArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\EnumArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\MinimalArrayArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\SensitiveParameterArrayReducer;
use Spatie\Backtrace\Arguments\Reducers\StdClassArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\StringableArgumentReducer;
use Spatie\Backtrace\Arguments\Reducers\SymphonyRequestArgumentReducer;

class ArgumentReducers
{
    /** @var array<int, ArgumentReducer> */
    public $argumentReducers = [];

    /**
     * @param array<ArgumentReducer|class-string<ArgumentReducer>> $argumentReducers
     */
    public static function create(array $argumentReducers): self
    {
        return new self(array_map(
            function ($argumentReducer) {
                /** @var $argumentReducer ArgumentReducer|class-string<ArgumentReducer> */
                return $argumentReducer instanceof ArgumentReducer ? $argumentReducer : new $argumentReducer();
            },
            $argumentReducers
        ));
    }

    public static function default(array $extra = []): self
    {
        return new self(static::defaultReducers($extra));
    }

    public static function minimal(array $extra = []): self
    {
        return new self(static::minimalReducers($extra));
    }

    /**
     * @param array<int, ArgumentReducer> $argumentReducers
     */
    protected function __construct(array $argumentReducers)
    {
        $this->argumentReducers = $argumentReducers;
    }

    protected static function defaultReducers(array $extra = []): array
    {
        return array_merge($extra, [
            new BaseTypeArgumentReducer(),
            new ArrayArgumentReducer(),
            new StdClassArgumentReducer(),
            new EnumArgumentReducer(),
            new ClosureArgumentReducer(),
            new SensitiveParameterArrayReducer(),
            new DateTimeArgumentReducer(),
            new DateTimeZoneArgumentReducer(),
            new SymphonyRequestArgumentReducer(),
            new StringableArgumentReducer(),
        ]);
    }

    protected static function minimalReducers(array $extra = []): array
    {
        return array_merge($extra, [
            new BaseTypeArgumentReducer(),
            new MinimalArrayArgumentReducer(),
            new EnumArgumentReducer(),
            new ClosureArgumentReducer(),
            new SensitiveParameterArrayReducer(),
        ]);
    }
}
Best Practice

Best Practices

To ensure a smooth integration process and optimal performance, follow these best practices:

  1. Use secure HTTPS connections for all API requests.
  2. Implement robust error handling to handle potential issues gracefully.
  3. Regularly update your integration to stay current with any API changes or enhancements.