* * 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 * @author Pierrick Vignand */ 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; } }