$path
$path : string|null
ExpressionRequestMatcher uses an expression to match a Request.
__construct(string|null $path = null, string|null $host = null, string|array<mixed,string>|null $methods = null, string|array<mixed,string>|null $ips = null, array $attributes = array(), string|array<mixed,string>|null $schemes = null)
string|null | $path | |
string|null | $host | |
string|array<mixed,string>|null | $methods | |
string|array<mixed,string>|null | $ips | |
array | $attributes | |
string|array<mixed,string>|null | $schemes |
matches(\Symfony\Component\HttpFoundation\Request $request) : boolean
Decides whether the rule(s) implemented by the strategy matches the supplied request.
\Symfony\Component\HttpFoundation\Request | $request |
true if the request matches, false otherwise
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\HttpFoundation;
use Symfony\Component\ExpressionLanguage\ExpressionLanguage;
/**
* ExpressionRequestMatcher uses an expression to match a Request.
*
* @author Fabien Potencier <fabien@symfony.com>
*/
class ExpressionRequestMatcher extends RequestMatcher
{
private $language;
private $expression;
public function setExpression(ExpressionLanguage $language, $expression)
{
$this->language = $language;
$this->expression = $expression;
}
public function matches(Request $request)
{
if (!$this->language) {
throw new \LogicException('Unable to match the request as the expression language is not available.');
}
return $this->language->evaluate($this->expression, array(
'request' => $request,
'method' => $request->getMethod(),
'path' => rawurldecode($request->getPathInfo()),
'host' => $request->getHost(),
'ip' => $request->getClientIp(),
'attributes' => $request->attributes->all(),
)) && parent::matches($request);
}
}