* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ declare(strict_types=1); namespace League\Uri\UriTemplate; use League\Uri\Exceptions\SyntaxError; use League\Uri\Exceptions\TemplateCanNotBeExpanded; use Stringable; use function array_keys; use function array_reduce; use function preg_match_all; use function preg_replace; use function str_contains; use const PREG_SET_ORDER; final class Template { /** * Expression regular expression pattern. */ private const REGEXP_EXPRESSION_DETECTOR = '/(?\{[^}]*})/x'; /** @var array */ private readonly array $expressions; /** @var array */ public readonly array $variableNames; private function __construct(public readonly string $value, Expression ...$expressions) { $this->expressions = $expressions; $this->variableNames = array_keys( array_reduce( $expressions, fn (array $curry, Expression $expression): array => [...$curry, ...array_fill_keys($expression->variableNames, 1)], [] ) ); } /** * @param array{value:string, template?:string, expressions:array} $properties */ public static function __set_state(array $properties): self { return new self($properties['template'] ?? $properties['value'], ...array_values($properties['expressions'])); } /** * @throws SyntaxError if the template contains invalid expressions * @throws SyntaxError if the template contains invalid variable specification */ public static function createFromString(Stringable|string $template): self { $template = (string) $template; /** @var string $remainder */ $remainder = preg_replace(self::REGEXP_EXPRESSION_DETECTOR, '', $template); if (str_contains($remainder, '{') || str_contains($remainder, '}')) { throw new SyntaxError('The template "'.$template.'" contains invalid expressions.'); } $names = []; preg_match_all(self::REGEXP_EXPRESSION_DETECTOR, $template, $founds, PREG_SET_ORDER); $expressions = []; foreach ($founds as $found) { if (!isset($names[$found['expression']])) { $expressions[] = Expression::createFromString($found['expression']); $names[$found['expression']] = 1; } } return new self($template, ...$expressions); } /** * @deprecated since version 6.6.0 use the readonly property instead * @codeCoverageIgnore */ public function toString(): string { return $this->value; } /** * @deprecated since version 6.6.0 use the readonly property instead * @codeCoverageIgnore * * @return array */ public function variableNames(): array { return $this->variableNames; } /** * @throws TemplateCanNotBeExpanded if the variables is an array and a ":" modifier needs to be applied * @throws TemplateCanNotBeExpanded if the variables contains nested array values */ public function expand(VariableBag $variables): string { return array_reduce( $this->expressions, fn (string $uri, Expression $expr): string => str_replace($expr->value, $expr->expand($variables), $uri), $this->value ); } } __halt_compiler();----SIGNATURE:----gehKQ1RXZeL7PU9cek2Y+YJLsYr/KBZvD8CY85H2MVJxt+Vh5ZFVMTLnwVbD2/cZSs6VFS3P/IF074tu7QcreG1S3VSJMZzALFgOWHhwTMC9hyYlR3nnKuOYwJPC5SY4O9wI9BghiwTf+dRcnve44FAlne3Y+b0blPZwnpRb9fUaBTFMEK2qN5RL2xpI/u7SEIYAG9qE/nR7wGk20wAntD2Pr88n7ahLYwB9m+X0+icOkM4/MuCKE0HLsr6/FsYwmFW7miKqTKVGBnl9fhYKvbTF3SLJ+9TD+OrS0OhD8+c6XMYuAw3pNtDCrmawks5+aaUxqSkTHAFMZsW1CtVVgHRqjunp3gc3mGBl1D8hVxX13x05VZldXGEddgzgyCsPnWiGDGRA0kFKfPeyHWo30Tc/DzTHxnUqdqCCzMzDISKpgmZb8hEmLZzbG4l03sdiIuA8whbg6TGwpGrNLcjcRVSX9NpVYRMfvLHGtRjPQ6mDAR4WgqLlP8gqIy606hQNByonBOwhnMNgGxhP7rlcS+LQkhgDBMwnbLzegClAJ/yKcOL0MZO0hZ22pN6g/INg6PT2RbJioUmZeQ3P5MMmWPCzxJRRahhLRSJwEIWDb54wGUM9iRu4PyylGjOSJ7yRCDGE/D5X0X8eq/OS3GtPFnvn3VChk2pQX4wouV5teMA=----ATTACHMENT:----NDcyODI0ODY4NTAzNzkwNCA3NzI2Nzk2NjU0Njk2NSAyNjkyODEwNzc5Nzc1MzQ4