71 lines
2.2 KiB
PHP
71 lines
2.2 KiB
PHP
<?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\Bridge\Monolog\Handler\FingersCrossed;
|
|
|
|
use Monolog\Handler\FingersCrossed\ActivationStrategyInterface;
|
|
use Monolog\LogRecord;
|
|
use Symfony\Component\HttpFoundation\RequestStack;
|
|
use Symfony\Component\HttpKernel\Exception\HttpException;
|
|
|
|
/**
|
|
* Activation strategy that ignores certain HTTP codes.
|
|
*
|
|
* @author Shaun Simmons <shaun@envysphere.com>
|
|
* @author Pierrick Vignand <pierrick.vignand@gmail.com>
|
|
*/
|
|
final class HttpCodeActivationStrategy implements ActivationStrategyInterface
|
|
{
|
|
/**
|
|
* @param array $exclusions each exclusion must have a "code" and "urls" keys
|
|
*/
|
|
public function __construct(
|
|
private RequestStack $requestStack,
|
|
private array $exclusions,
|
|
private ActivationStrategyInterface $inner,
|
|
) {
|
|
foreach ($exclusions as $exclusion) {
|
|
if (!\array_key_exists('code', $exclusion)) {
|
|
throw new \LogicException('An exclusion must have a "code" key.');
|
|
}
|
|
if (!\array_key_exists('urls', $exclusion)) {
|
|
throw new \LogicException('An exclusion must have a "urls" key.');
|
|
}
|
|
}
|
|
}
|
|
|
|
public function isHandlerActivated(LogRecord $record): bool
|
|
{
|
|
$isActivated = $this->inner->isHandlerActivated($record);
|
|
|
|
if (
|
|
$isActivated
|
|
&& isset($record->context['exception'])
|
|
&& $record->context['exception'] instanceof HttpException
|
|
&& ($request = $this->requestStack->getMainRequest())
|
|
) {
|
|
foreach ($this->exclusions as $exclusion) {
|
|
if ($record->context['exception']->getStatusCode() !== $exclusion['code']) {
|
|
continue;
|
|
}
|
|
|
|
if (\count($exclusion['urls'])) {
|
|
return !preg_match('{('.implode('|', $exclusion['urls']).')}i', $request->getPathInfo());
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return $isActivated;
|
|
}
|
|
}
|