vendor/symfony/http-kernel/EventListener/ExceptionListener.php line 25

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of the Symfony package.
  4.  *
  5.  * (c) Fabien Potencier <fabien@symfony.com>
  6.  *
  7.  * For the full copyright and license information, please view the LICENSE
  8.  * file that was distributed with this source code.
  9.  */
  10. namespace Symfony\Component\HttpKernel\EventListener;
  11. use Psr\Log\LoggerInterface;
  12. use Symfony\Component\ErrorHandler\Exception\FlattenException;
  13. use Symfony\Component\EventDispatcher\EventDispatcherInterface;
  14. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  15. use Symfony\Component\HttpFoundation\Request;
  16. use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent;
  17. use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
  18. use Symfony\Component\HttpKernel\HttpKernelInterface;
  19. use Symfony\Component\HttpKernel\KernelEvents;
  20. use Symfony\Component\HttpKernel\Log\DebugLoggerInterface;
  21. @trigger_error(sprintf('The "%s" class is deprecated since Symfony 4.4, use "ErrorListener" instead.'ExceptionListener::class), \E_USER_DEPRECATED);
  22. /**
  23.  * @deprecated since Symfony 4.4, use ErrorListener instead
  24.  */
  25. class ExceptionListener implements EventSubscriberInterface
  26. {
  27.     protected $controller;
  28.     protected $logger;
  29.     protected $debug;
  30.     public function __construct($controllerLoggerInterface $logger null$debug false)
  31.     {
  32.         $this->controller $controller;
  33.         $this->logger $logger;
  34.         $this->debug $debug;
  35.     }
  36.     public function logKernelException(GetResponseForExceptionEvent $event)
  37.     {
  38.         $e FlattenException::createFromThrowable($event->getException());
  39.         $this->logException($event->getException(), sprintf('Uncaught PHP Exception %s: "%s" at %s line %s'$e->getClass(), $e->getMessage(), $e->getFile(), $e->getLine()));
  40.     }
  41.     public function onKernelException(GetResponseForExceptionEvent $event)
  42.     {
  43.         if (null === $this->controller) {
  44.             return;
  45.         }
  46.         $exception $event->getException();
  47.         $request $this->duplicateRequest($exception$event->getRequest());
  48.         $eventDispatcher = \func_num_args() > func_get_arg(2) : null;
  49.         try {
  50.             $response $event->getKernel()->handle($requestHttpKernelInterface::SUB_REQUESTfalse);
  51.         } catch (\Exception $e) {
  52.             $f FlattenException::createFromThrowable($e);
  53.             $this->logException($esprintf('Exception thrown when handling an exception (%s: %s at %s line %s)'$f->getClass(), $f->getMessage(), $e->getFile(), $e->getLine()));
  54.             $prev $e;
  55.             do {
  56.                 if ($exception === $wrapper $prev) {
  57.                     throw $e;
  58.                 }
  59.             } while ($prev $wrapper->getPrevious());
  60.             $prev = new \ReflectionProperty($wrapper instanceof \Exception ? \Exception::class : \Error::class, 'previous');
  61.             $prev->setAccessible(true);
  62.             $prev->setValue($wrapper$exception);
  63.             throw $e;
  64.         }
  65.         $event->setResponse($response);
  66.         if ($this->debug && $eventDispatcher instanceof EventDispatcherInterface) {
  67.             $cspRemovalListener = function ($event) use (&$cspRemovalListener$eventDispatcher) {
  68.                 $event->getResponse()->headers->remove('Content-Security-Policy');
  69.                 $eventDispatcher->removeListener(KernelEvents::RESPONSE$cspRemovalListener);
  70.             };
  71.             $eventDispatcher->addListener(KernelEvents::RESPONSE$cspRemovalListener, -128);
  72.         }
  73.     }
  74.     public static function getSubscribedEvents()
  75.     {
  76.         return [
  77.             KernelEvents::EXCEPTION => [
  78.                 ['logKernelException'0],
  79.                 ['onKernelException', -128],
  80.             ],
  81.         ];
  82.     }
  83.     /**
  84.      * Logs an exception.
  85.      *
  86.      * @param \Exception $exception The \Exception instance
  87.      * @param string     $message   The error message to log
  88.      */
  89.     protected function logException(\Exception $exception$message)
  90.     {
  91.         if (null !== $this->logger) {
  92.             if (!$exception instanceof HttpExceptionInterface || $exception->getStatusCode() >= 500) {
  93.                 $this->logger->critical($message, ['exception' => $exception]);
  94.             } else {
  95.                 $this->logger->error($message, ['exception' => $exception]);
  96.             }
  97.         }
  98.     }
  99.     /**
  100.      * Clones the request for the exception.
  101.      *
  102.      * @return Request The cloned request
  103.      */
  104.     protected function duplicateRequest(\Exception $exceptionRequest $request)
  105.     {
  106.         $attributes = [
  107.             '_controller' => $this->controller,
  108.             'exception' => FlattenException::createFromThrowable($exception),
  109.             'logger' => $this->logger instanceof DebugLoggerInterface $this->logger null,
  110.         ];
  111.         $request $request->duplicate(nullnull$attributes);
  112.         $request->setMethod('GET');
  113.         return $request;
  114.     }
  115. }
dobrowin | betleao | moverbet | winzada 777 | supremo | casadeapostas | dobrowin | betleao | moverbet | wazamba | fezbet | betsson | lvbet | dobrowin | betsul | pixbet | bwin | betobet | dobrowin | bet7 | betcris | blaze | 888 | betano | stake | stake | esportesdasorte | betmotion | rivalry | novibet | pinnacle | cbet | dobrowin | betleao | moverbet | gogowin | jogos win | campobet | mesk bet | infinity bet | betfury | doce | bet7k | jogowin | lobo888 | iribet | leao | dobrowin | allwin | aajogo | pgwin | greenbets | brapub | moverbet | onebra | flames | brdice | brwin | poplottery | queens | winbrl | omgbet | winbra | goinbet | codbet | betleao | fuwin | allwin568 | wingdus | juntosbet | today | talon777 | brlwin | fazobetai | pinup bet | bet sport | bet esporte | mrbet | premier bet | apostebet | spicy bet | prosport bet | bet nacional | luck | jogodeouro | heads bet | marjack bet | apostaganha | gbg bet | esoccer bet | esport bet | realbet | aposte e ganhe | aviator aposta | bet vitoria | imperador bet | realsbet | bet favorita | esportenet | flames bet | pague bet | betsury | doce888 | obabet | winzada | globalbet | bet77 | lottoland | 7gamesbet | dicasbet | esportivabet | tvbet | sportbet | misterjackbet | esportebet | nacionalbet | simplesbet | betestrela | batbet | Pk55 | Bet61 | Upsports Bet | roleta online | roleta | poker online | poker | blackjack online | bingo | 12bet | 33win | bet168 | bk8 | bong88 | bong99 | fcb8 | hb88 | hotlive | ibet888 | k8 | kubet77 | kubet | lode88 | mig8 | nbet | onebox63 | oxbet | s666 | sbobet | suncity | vwin | w88 | win2888 | zbet | xoso66 | zowin | sun | top88 | vnloto | 11bet | bet69 | 8xbet | Ceará | Paysandu | Juventude | Bahia | Sport | Cuiabá | Coritiba | Criciúma | Vitória | Fortaleza | Corinthians | São Paulo | Vasco | Grêmio | Fluminense | Cruzeiro | Botafogo | Flamengo | bingo slots | slots slots | hacker do slot | pg slot demo | slot win | pg slot soft | arne slot | riqueza slots | slots 777 | pg slot | 777 slot game | slot pg soft | hacker slot | 777 slots | slot-pg-soft | fortune ox demo grátis | demo fortune ox | fortune mouse demo | fortune ox demo | jogo fortune tiger | fortune tiger grátis | fortune tiger baixar | fortune tiger demo grátis | fortune tiger demo | fortune tiger 777 | 580bet | bet 7k | leao | luck 2 | john bet | 7755 bet | cbet | bet7 | pk55 | 8800 bet | doce | bet 4 | f12bet | bet7 | ggbet | bet77 | mrbet | bet61 | tvbet | pgwin | today | fuwin | brwin | bet7k | tv bet | allwin | stake | bwin 789 | lvbet | blaze | dj bet | umbet | b1bet | 20bet | bk bet | h2bet | 7kbet | fbbet | 9d bet | 9k bet | 73 bet | ktobet | 74 bet | betpix | betvip | batbet | onabet | f12bet | codbet | winbra | b2xbet | obabet | brlwin | onebra | winbrl | omgbet | queens | brdice | brapub | flames | betano | aajogo | iribet | pixbet | betsul | fezbet | curso beta | betway | bkbet | peixe beta | bet365 | pixbet | 4 play bet | 365bet | brxbet | 939 bet | seubet | cnc bet | gbg bet | 522bet | brl bet | pagbet | jonbet | jqk bet | 166bet | abc bet | bggbet | obabet | 136bet | mmabet | win bet | ir6 bet | 667bet | qqq bet | 193 bet | 3ss bet | 317 bet | kkk bet | 585 bet | 569 bet | vai bet | aaa bet | 969 bet | z11 bet | kw bet | 26 bet | mj bet | betio | 01 bet | ut bet | 9y bet | bet70 | f9 bet | hw bet | kg bet | 5e bet | bet br | hr bet | br bet | 75 bet | 03 bet | 6z bet | 6r bet | v6 bet | 78 bet | bt bet | 80 bet | 8g bet | 72 bet | xp bet | f12 bet | p9 bet | 5 bet | 4 bet | bet 4 | r7 bet | um bet | 29 bet | 5s bet | ck bet | pg bet | ea bet | 23 bet | bl bet | 3l bet | 2a bet | p7 bet | 888 bet | 707 bet | 361 bet | bet29 | 700 bet | 161 bet | bet777 | up bet | 58 bet | nn bet | 67 bet | 22 bet | 9g bet | 1x bet | bet10 | 70 bet | 2h bet | 9r bet | 16 bet | 81 bet | 7 bet | 5u bet | 6k bet | mg bet | b1 bet | 5h bet | je- bet | joya | hopa | nomini | ls bet | 1xbit | platin | ice bet | rant | bet us | bet go | 31 bet | slingo | flush | ice36 | weiss | bet9 | rabona | i bet | starda | dreams | bongo | snatch | 10 bet | daddy | metal | zep bet | drip | gama | drake | verde | shazam | wish | thor | exclusive | sol | highway | 500 casino | jazz | howl | supernova | sherbet | fresh | daddy | jet | wish | eclipse | inplay | drip | marvel | stake | scorpion | luxebet | drake | thor | puma | winzir | loki | shazam | rivalry | f1 casino | xgbet | sushi | bk8 | art casino | manga | pgasia | gemini | bingoplus | slot vip | help slot win | 8k8 slot | tadhana slot | jili slot | 55bmw slot | vip slot | nn777 slot | jili slot 777 | tg777 slot | w500 slot | phfun slot | bmw55 slot | sg777 slot | wj slot | slot free 100 | lucky cola slot | cc6 slot | taya777 slot | ph444 slot | slot games | fb777 slot | okebet slot | help slot | tg77 slot | phwin slot | vvjl slot | fc777 slot | slot vin | yy777 slot | define slot | define slot | inplay | 99bet | 60win | melbet | jollibet | jili slot | rich711 | tayabet | phl63 | unobet | 63jili | mwplay888 | gold99 | jolibet | ubet95 | nice88 | jili777 | nn777 | phlove | jiliko | 55bmw | phoenix game | 8k8 | cgebet | 7up gaming | diamond game | hellowin | win88 | big win | kabibe game | sabong bet | phcity | colorplay | tongits go | slotsgo | spinph | go perya | casino frenzy | aurora game | escala gaming | winning plus | bingo plus | ph dream | 747 live | niceph | lucky cola | pera play