JFIF  x x C         C     "        } !1AQa "q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz        w !1AQ aq"2B #3Rbr{ gilour

File "Expression.php"

Full Path: /home/u735268861/domains/palsarh.in/public_html/vendor/rize/uri-template/src/Rize/UriTemplate/Node/Expression.php
File size: 3.48 KB
MIME-type: text/x-php
Charset: utf-8

<?php

namespace Rize\UriTemplate\Node;

use Rize\UriTemplate\Operator;
use Rize\UriTemplate\Parser;

class Expression extends Abstraction
{
    /**
     * @param string $forwardLookupSeparator
     */
    public function __construct(string $token, private readonly Operator\Abstraction $operator, private readonly ?array $variables = null, /**
     * Whether to do a forward lookup for a given separator.
     */
        private $forwardLookupSeparator = null)
    {
        parent::__construct($token);
    }

    public function getOperator(): Operator\Abstraction
    {
        return $this->operator;
    }

    public function getVariables(): ?array
    {
        return $this->variables;
    }

    public function getForwardLookupSeparator(): string
    {
        return $this->forwardLookupSeparator;
    }

    public function setForwardLookupSeparator(string $forwardLookupSeparator): void
    {
        $this->forwardLookupSeparator = $forwardLookupSeparator;
    }

    public function expand(Parser $parser, array $params = []): ?string
    {
        $data = [];
        $op = $this->operator;

        if ($this->variables === null) {
            return $op->first;
        }

        // check for variable modifiers
        foreach ($this->variables as $var) {
            $val = $op->expand($parser, $var, $params);

            // skip null value
            if (!is_null($val)) {
                $data[] = $val;
            }
        }

        return $data ? $op->first . implode($op->sep, $data) : null;
    }

    /**
     * Matches given URI against current node.
     *
     * @return null|array `uri and params` or `null` if not match and $strict is true
     */
    public function match(Parser $parser, string $uri, array $params = [], bool $strict = false): ?array
    {
        $op = $this->operator;

        // check expression operator first
        if ($op->id && isset($uri[0]) && $uri[0] !== $op->id) {
            return [$uri, $params];
        }

        // remove operator from input
        if ($op->id) {
            $uri = substr($uri, 1);
        }

        foreach ($this->sortVariables($this->variables) as $var) {
            $regex = '#' . $op->toRegex($parser, $var) . '#';
            $val   = null;

            // do a forward lookup and get just the relevant part
            $remainingUri = '';
            $preparedUri = $uri;
            if ($this->forwardLookupSeparator) {
                $lastOccurrenceOfSeparator = stripos($uri, $this->forwardLookupSeparator);
                $preparedUri = substr($uri, 0, $lastOccurrenceOfSeparator);
                $remainingUri = substr($uri, $lastOccurrenceOfSeparator);
            }

            if (preg_match($regex, $preparedUri, $match)) {
                // remove matched part from input
                $preparedUri = preg_replace($regex, '', $preparedUri, 1);
                $val = $op->extract($parser, $var, $match[0]);
            }

            // if strict is given, we quit immediately when there's no match
            elseif ($strict) {
                return null;
            }

            $uri = $preparedUri . $remainingUri;

            $params[$var->getToken()] = $val;
        }

        return [$uri, $params];
    }

    /**
     * Sort variables before extracting data from uri.
     * We have to sort vars by non-explode to explode.
     */
    protected function sortVariables(array $vars): array
    {
        usort($vars, static fn($a, $b) => $a->options['modifier'] <=> $b->options['modifier']);

        return $vars;
    }
}