vendor/symfony/event-dispatcher/EventDispatcher.php line 270

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\EventDispatcher;
  11. use Psr\EventDispatcher\StoppableEventInterface;
  12. use Symfony\Component\EventDispatcher\Debug\WrappedListener;
  13. /**
  14.  * The EventDispatcherInterface is the central point of Symfony's event listener system.
  15.  *
  16.  * Listeners are registered on the manager and events are dispatched through the
  17.  * manager.
  18.  *
  19.  * @author Guilherme Blanco <guilhermeblanco@hotmail.com>
  20.  * @author Jonathan Wage <jonwage@gmail.com>
  21.  * @author Roman Borschel <roman@code-factory.org>
  22.  * @author Bernhard Schussek <bschussek@gmail.com>
  23.  * @author Fabien Potencier <fabien@symfony.com>
  24.  * @author Jordi Boggiano <j.boggiano@seld.be>
  25.  * @author Jordan Alliot <jordan.alliot@gmail.com>
  26.  * @author Nicolas Grekas <p@tchwork.com>
  27.  */
  28. class EventDispatcher implements EventDispatcherInterface
  29. {
  30.     private $listeners = [];
  31.     private $sorted = [];
  32.     private $optimized;
  33.     public function __construct()
  34.     {
  35.         if (__CLASS__ === static::class) {
  36.             $this->optimized = [];
  37.         }
  38.     }
  39.     /**
  40.      * {@inheritdoc}
  41.      */
  42.     public function dispatch(object $eventstring $eventName null): object
  43.     {
  44.         $eventName $eventName ?? \get_class($event);
  45.         if (null !== $this->optimized) {
  46.             $listeners $this->optimized[$eventName] ?? (empty($this->listeners[$eventName]) ? [] : $this->optimizeListeners($eventName));
  47.         } else {
  48.             $listeners $this->getListeners($eventName);
  49.         }
  50.         if ($listeners) {
  51.             $this->callListeners($listeners$eventName$event);
  52.         }
  53.         return $event;
  54.     }
  55.     /**
  56.      * {@inheritdoc}
  57.      */
  58.     public function getListeners(string $eventName null)
  59.     {
  60.         if (null !== $eventName) {
  61.             if (empty($this->listeners[$eventName])) {
  62.                 return [];
  63.             }
  64.             if (!isset($this->sorted[$eventName])) {
  65.                 $this->sortListeners($eventName);
  66.             }
  67.             return $this->sorted[$eventName];
  68.         }
  69.         foreach ($this->listeners as $eventName => $eventListeners) {
  70.             if (!isset($this->sorted[$eventName])) {
  71.                 $this->sortListeners($eventName);
  72.             }
  73.         }
  74.         return array_filter($this->sorted);
  75.     }
  76.     /**
  77.      * {@inheritdoc}
  78.      */
  79.     public function getListenerPriority(string $eventName$listener)
  80.     {
  81.         if (empty($this->listeners[$eventName])) {
  82.             return null;
  83.         }
  84.         if (\is_array($listener) && isset($listener[0]) && $listener[0] instanceof \Closure && >= \count($listener)) {
  85.             $listener[0] = $listener[0]();
  86.             $listener[1] = $listener[1] ?? '__invoke';
  87.         }
  88.         foreach ($this->listeners[$eventName] as $priority => &$listeners) {
  89.             foreach ($listeners as &$v) {
  90.                 if ($v !== $listener && \is_array($v) && isset($v[0]) && $v[0] instanceof \Closure && >= \count($v)) {
  91.                     $v[0] = $v[0]();
  92.                     $v[1] = $v[1] ?? '__invoke';
  93.                 }
  94.                 if ($v === $listener) {
  95.                     return $priority;
  96.                 }
  97.             }
  98.         }
  99.         return null;
  100.     }
  101.     /**
  102.      * {@inheritdoc}
  103.      */
  104.     public function hasListeners(string $eventName null)
  105.     {
  106.         if (null !== $eventName) {
  107.             return !empty($this->listeners[$eventName]);
  108.         }
  109.         foreach ($this->listeners as $eventListeners) {
  110.             if ($eventListeners) {
  111.                 return true;
  112.             }
  113.         }
  114.         return false;
  115.     }
  116.     /**
  117.      * {@inheritdoc}
  118.      */
  119.     public function addListener(string $eventName$listenerint $priority 0)
  120.     {
  121.         $this->listeners[$eventName][$priority][] = $listener;
  122.         unset($this->sorted[$eventName], $this->optimized[$eventName]);
  123.     }
  124.     /**
  125.      * {@inheritdoc}
  126.      */
  127.     public function removeListener(string $eventName$listener)
  128.     {
  129.         if (empty($this->listeners[$eventName])) {
  130.             return;
  131.         }
  132.         if (\is_array($listener) && isset($listener[0]) && $listener[0] instanceof \Closure && >= \count($listener)) {
  133.             $listener[0] = $listener[0]();
  134.             $listener[1] = $listener[1] ?? '__invoke';
  135.         }
  136.         foreach ($this->listeners[$eventName] as $priority => &$listeners) {
  137.             foreach ($listeners as $k => &$v) {
  138.                 if ($v !== $listener && \is_array($v) && isset($v[0]) && $v[0] instanceof \Closure && >= \count($v)) {
  139.                     $v[0] = $v[0]();
  140.                     $v[1] = $v[1] ?? '__invoke';
  141.                 }
  142.                 if ($v === $listener) {
  143.                     unset($listeners[$k], $this->sorted[$eventName], $this->optimized[$eventName]);
  144.                 }
  145.             }
  146.             if (!$listeners) {
  147.                 unset($this->listeners[$eventName][$priority]);
  148.             }
  149.         }
  150.     }
  151.     /**
  152.      * {@inheritdoc}
  153.      */
  154.     public function addSubscriber(EventSubscriberInterface $subscriber)
  155.     {
  156.         foreach ($subscriber->getSubscribedEvents() as $eventName => $params) {
  157.             if (\is_string($params)) {
  158.                 $this->addListener($eventName, [$subscriber$params]);
  159.             } elseif (\is_string($params[0])) {
  160.                 $this->addListener($eventName, [$subscriber$params[0]], $params[1] ?? 0);
  161.             } else {
  162.                 foreach ($params as $listener) {
  163.                     $this->addListener($eventName, [$subscriber$listener[0]], $listener[1] ?? 0);
  164.                 }
  165.             }
  166.         }
  167.     }
  168.     /**
  169.      * {@inheritdoc}
  170.      */
  171.     public function removeSubscriber(EventSubscriberInterface $subscriber)
  172.     {
  173.         foreach ($subscriber->getSubscribedEvents() as $eventName => $params) {
  174.             if (\is_array($params) && \is_array($params[0])) {
  175.                 foreach ($params as $listener) {
  176.                     $this->removeListener($eventName, [$subscriber$listener[0]]);
  177.                 }
  178.             } else {
  179.                 $this->removeListener($eventName, [$subscriber\is_string($params) ? $params $params[0]]);
  180.             }
  181.         }
  182.     }
  183.     /**
  184.      * Triggers the listeners of an event.
  185.      *
  186.      * This method can be overridden to add functionality that is executed
  187.      * for each listener.
  188.      *
  189.      * @param callable[] $listeners The event listeners
  190.      * @param string     $eventName The name of the event to dispatch
  191.      * @param object     $event     The event object to pass to the event handlers/listeners
  192.      */
  193.     protected function callListeners(iterable $listenersstring $eventNameobject $event)
  194.     {
  195.         $stoppable $event instanceof StoppableEventInterface;
  196.         foreach ($listeners as $listener) {
  197.             if ($stoppable && $event->isPropagationStopped()) {
  198.                 break;
  199.             }
  200.             $listener($event$eventName$this);
  201.         }
  202.     }
  203.     /**
  204.      * Sorts the internal list of listeners for the given event by priority.
  205.      */
  206.     private function sortListeners(string $eventName)
  207.     {
  208.         krsort($this->listeners[$eventName]);
  209.         $this->sorted[$eventName] = [];
  210.         foreach ($this->listeners[$eventName] as &$listeners) {
  211.             foreach ($listeners as $k => &$listener) {
  212.                 if (\is_array($listener) && isset($listener[0]) && $listener[0] instanceof \Closure && >= \count($listener)) {
  213.                     $listener[0] = $listener[0]();
  214.                     $listener[1] = $listener[1] ?? '__invoke';
  215.                 }
  216.                 $this->sorted[$eventName][] = $listener;
  217.             }
  218.         }
  219.     }
  220.     /**
  221.      * Optimizes the internal list of listeners for the given event by priority.
  222.      */
  223.     private function optimizeListeners(string $eventName): array
  224.     {
  225.         krsort($this->listeners[$eventName]);
  226.         $this->optimized[$eventName] = [];
  227.         foreach ($this->listeners[$eventName] as &$listeners) {
  228.             foreach ($listeners as &$listener) {
  229.                 $closure = &$this->optimized[$eventName][];
  230.                 if (\is_array($listener) && isset($listener[0]) && $listener[0] instanceof \Closure && >= \count($listener)) {
  231.                     $closure = static function (...$args) use (&$listener, &$closure) {
  232.                         if ($listener[0] instanceof \Closure) {
  233.                             $listener[0] = $listener[0]();
  234.                             $listener[1] = $listener[1] ?? '__invoke';
  235.                         }
  236.                         ($closure \Closure::fromCallable($listener))(...$args);
  237.                     };
  238.                 } else {
  239.                     $closure $listener instanceof \Closure || $listener instanceof WrappedListener $listener \Closure::fromCallable($listener);
  240.                 }
  241.             }
  242.         }
  243.         return $this->optimized[$eventName];
  244.     }
  245. }
HTTP/2 401 returned for "https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240". (500 Internal Server Error)

Symfony Exception

ClientException

HTTP 500 Internal Server Error

HTTP/2 401 returned for "https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240".

Exception

Symfony\Component\HttpClient\Exception\ ClientException

  1.         if (500 <= $code) {
  2.             throw new ServerException($this);
  3.         }
  4.         if (400 <= $code) {
  5.             throw new ClientException($this);
  6.         }
  7.         if (300 <= $code) {
  8.             throw new RedirectionException($this);
  9.         }
  1.         } finally {
  2.             if ($this->event && $this->event->isStarted()) {
  3.                 $this->event->stop();
  4.             }
  5.             if ($throw) {
  6.                 $this->checkStatusCode($this->response->getStatusCode());
  7.             }
  8.         }
  9.     }
  10.     public function toArray(bool $throw true): array
TraceableResponse->getContent() in src/Blog.php (line 181)
  1.                     'hapikey' => $this->hubSpotKey,
  2.                     'after' => $after,
  3.                 ],
  4.             ]);
  5.             $result json_decode($response->getContent(), true);
  6.         } catch (HttpExceptionInterface $e) {
  7.             $this->logger->error('Could not load blog posts from HubSpot', ['exception' => $e]);
  8.             throw $e;
  9.         }
Blog->loadBlogAuthors() in src/Blog.php (line 152)
  1.         if (!isset($this->authors)) {
  2.             $beta $bustCache INF null;
  3.             $this->authors $this->cache->get('blog_authors', function (ItemInterface $item) {
  4.                 $item->expiresAfter(86400); // cache for 1 day
  5.                 return $this->loadBlogAuthors();
  6.             }, $beta);
  7.         }
  8.         return $this->authors;
  9.     }
  1.         $isHit true;
  2.         $callback = function (CacheItem $itembool &$save) use ($callback, &$isHit) {
  3.             $isHit $item->isHit();
  4.             return $callback($item$save);
  5.         };
  6.         $event $this->start(__FUNCTION__);
  7.         try {
  8.             $value $this->pool->get($key$callback$beta$metadata);
in vendor/symfony/cache/LockRegistry.php -> Symfony\Component\Cache\Adapter\{closure} (line 108)
  1.                 if ($locked || !$wouldBlock) {
  2.                     $logger && $logger->info(sprintf('Lock %s, now computing item "{key}"'$locked 'acquired' 'not supported'), ['key' => $item->getKey()]);
  3.                     self::$lockedFiles[$key] = true;
  4.                     $value $callback($item$save);
  5.                     if ($save) {
  6.                         if ($setMetadata) {
  7.                             $setMetadata($item);
  8.                         }
  1.             }
  2.             try {
  3.                 $value = ($this->callbackWrapper)($callback$item$save$pool, function (CacheItem $item) use ($setMetadata$startTime, &$metadata) {
  4.                     $setMetadata($item$startTime$metadata);
  5.                 }, $this->logger ?? null);
  6.                 $setMetadata($item$startTime$metadata);
  7.                 return $value;
  8.             } finally {
  9.                 unset($this->computing[$key]);
in vendor/symfony/cache-contracts/CacheTrait.php -> Symfony\Component\Cache\Traits\{closure} (line 72)
  1.             }
  2.         }
  3.         if ($recompute) {
  4.             $save true;
  5.             $item->set($callback($item$save));
  6.             if ($save) {
  7.                 $pool->save($item);
  8.             }
  9.         }
  1.                 return $value;
  2.             } finally {
  3.                 unset($this->computing[$key]);
  4.             }
  5.         }, $beta$metadata$this->logger ?? null);
  6.     }
  7. }
  1.      *
  2.      * @return mixed
  3.      */
  4.     public function get(string $key, callable $callbackfloat $beta null, array &$metadata null)
  5.     {
  6.         return $this->doGet($this$key$callback$beta$metadata);
  7.     }
  8.     /**
  9.      * {@inheritdoc}
  10.      */
  1.             return $callback($item$save);
  2.         };
  3.         $event $this->start(__FUNCTION__);
  4.         try {
  5.             $value $this->pool->get($key$callback$beta$metadata);
  6.             $event->result[$key] = get_debug_type($value);
  7.         } finally {
  8.             $event->end microtime(true);
  9.         }
  10.         if ($isHit) {
TraceableAdapter->get('blog_authors', object(Closure), INF) in src/Blog.php (line 149)
  1.     public function getAuthors(bool $bustCache false): array
  2.     {
  3.         if (!isset($this->authors)) {
  4.             $beta $bustCache INF null;
  5.             $this->authors $this->cache->get('blog_authors', function (ItemInterface $item) {
  6.                 $item->expiresAfter(86400); // cache for 1 day
  7.                 return $this->loadBlogAuthors();
  8.             }, $beta);
  9.         }
Blog->getAuthors(true) in src/Blog.php (line 37)
  1.      * WARNING: This will be slow and should not be called
  2.      * unless intentional.
  3.      */
  4.     public function bustCache(): void
  5.     {
  6.         $this->getAuthors(true);
  7.         $this->getTags(true);
  8.         $this->getAllPosts(true);
  9.     }
  10.     public function getAuthor(string $slug): ?array
  1.         // Update the last refresh time now to minimize cache stampede
  2.         $this->cache->get('lastContentRefresh', function () {
  3.             return time();
  4.         }, INF);
  5.         $this->blog->bustCache();
  6.     }
  7.     public static function getSubscribedEvents(): array
  8.     {
  9.         return [
ContentRefreshSubscriber->refresh() in src/EventSubscriber/ContentRefreshSubscriber.php (line 34)
  1.         $lastRefresh $this->cache->get('lastContentRefresh', function () {
  2.             return 0;
  3.         });
  4.         if ($lastRefresh strtotime('-5 minutes')) {
  5.             $this->refresh();
  6.         }
  7.     }
  8.     private function refresh(): void
  9.     {
  1.                     $closure = static function (...$args) use (&$listener, &$closure) {
  2.                         if ($listener[0] instanceof \Closure) {
  3.                             $listener[0] = $listener[0]();
  4.                             $listener[1] = $listener[1] ?? '__invoke';
  5.                         }
  6.                         ($closure \Closure::fromCallable($listener))(...$args);
  7.                     };
  8.                 } else {
  9.                     $closure $listener instanceof \Closure || $listener instanceof WrappedListener $listener \Closure::fromCallable($listener);
  10.                 }
  11.             }
in vendor/symfony/event-dispatcher/EventDispatcher.php :: Symfony\Component\EventDispatcher\{closure} (line 230)
  1.         foreach ($listeners as $listener) {
  2.             if ($stoppable && $event->isPropagationStopped()) {
  3.                 break;
  4.             }
  5.             $listener($event$eventName$this);
  6.         }
  7.     }
  8.     /**
  9.      * Sorts the internal list of listeners for the given event by priority.
  1.         } else {
  2.             $listeners $this->getListeners($eventName);
  3.         }
  4.         if ($listeners) {
  5.             $this->callListeners($listeners$eventName$event);
  6.         }
  7.         return $event;
  8.     }
  1.     /**
  2.      * {@inheritdoc}
  3.      */
  4.     public function terminate(Request $requestResponse $response)
  5.     {
  6.         $this->dispatcher->dispatch(new TerminateEvent($this$request$response), KernelEvents::TERMINATE);
  7.     }
  8.     /**
  9.      * @internal
  10.      */
in vendor/symfony/http-kernel/Kernel.php -> terminate (line 159)
  1.         if (false === $this->booted) {
  2.             return;
  3.         }
  4.         if ($this->getHttpKernel() instanceof TerminableInterface) {
  5.             $this->getHttpKernel()->terminate($request$response);
  6.         }
  7.     }
  8.     /**
  9.      * {@inheritdoc}
Kernel->terminate(object(Request), object(Response)) in public/index.php (line 36)
  1. $kernel = new Kernel($_SERVER['APP_ENV'], (bool) $_SERVER['APP_DEBUG']);
  2. $request Request::createFromGlobals();
  3. $response $kernel->handle($request);
  4. $response->send();
  5. $kernel->terminate($request$response);

Logs 3

Level Channel Message
INFO 06:26:36 php User Deprecated: Since symfony/framework-bundle 5.3: The "session.storage.native" service is deprecated, use "session.storage.factory.native" instead.
{
    "exception": {}
}
INFO 06:26:36 php User Deprecated: Since symfony/framework-bundle 5.3: The "session.storage.metadata_bag" service is deprecated, create your own "session.storage.factory" instead.
{
    "exception": {}
}
INFO 06:26:36 request Matched route "_profiler_open_file".
{
    "route": "_profiler_open_file",
    "route_parameters": {
        "_route": "_profiler_open_file",
        "_controller": "web_profiler.controller.profiler::openAction"
    },
    "request_uri": "http://invoiced.project-release.info/_profiler/open?file=vendor%2Fsymfony%2Fevent-dispatcher%2FEventDispatcher.php&line=270",
    "method": "GET"
}
INFO 06:26:36 cache Item "lastContentRefresh" is locked, waiting for it to be released
{
    "key": "lastContentRefresh"
}
INFO 06:26:36 cache Item "lastContentRefresh" retrieved after lock was released
{
    "key": "lastContentRefresh"
}
INFO 06:26:36 cache Item "blog_authors" is locked, waiting for it to be released
{
    "key": "blog_authors"
}
INFO 06:26:36 cache Item "blog_authors" not found while lock was released, now retrying
{
    "key": "blog_authors"
}
INFO 06:26:36 cache Lock acquired, now computing item "blog_authors"
{
    "key": "blog_authors"
}
INFO 06:26:36 http_client Request: "GET https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240"
INFO 06:26:37 http_client Response: "401 https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240"
ERROR 06:26:37 app Could not load blog posts from HubSpot
{
    "exception": {}
}
CRITICAL 06:26:37 php Uncaught Exception: HTTP/2 401 returned for "https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240".
{
    "exception": {}
}
CRITICAL 06:26:37 request Uncaught PHP Exception Symfony\Component\HttpClient\Exception\ClientException: "HTTP/2 401 returned for "https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240"." at /var/www/invoiced/data/www/invoiced.project-release.info/vendor/symfony/http-client/Response/TraceableResponse.php line 212
{
    "exception": {}
}

Stack Trace

ClientException
Symfony\Component\HttpClient\Exception\ClientException:
HTTP/2 401  returned for "https://api.hubapi.com/cms/v3/blogs/authors?hapikey=41d1972b-a2ce-454d-9e57-cd6355e00240".

  at vendor/symfony/http-client/Response/TraceableResponse.php:212
  at Symfony\Component\HttpClient\Response\TraceableResponse->checkStatusCode(401)
     (vendor/symfony/http-client/Response/TraceableResponse.php:103)
  at Symfony\Component\HttpClient\Response\TraceableResponse->getContent()
     (src/Blog.php:181)
  at App\Blog->loadBlogAuthors()
     (src/Blog.php:152)
  at App\Blog->App\{closure}(object(CacheItem), true)
     (vendor/symfony/cache/Adapter/TraceableAdapter.php:51)
  at Symfony\Component\Cache\Adapter\TraceableAdapter->Symfony\Component\Cache\Adapter\{closure}(object(CacheItem), true)
     (vendor/symfony/cache/LockRegistry.php:108)
  at Symfony\Component\Cache\LockRegistry::compute(object(Closure), object(CacheItem), true, object(FilesystemAdapter), object(Closure), object(Logger))
     (vendor/symfony/cache/Traits/ContractsTrait.php:100)
  at Symfony\Component\Cache\Adapter\AbstractAdapter->Symfony\Component\Cache\Traits\{closure}(object(CacheItem), true)
     (vendor/symfony/cache-contracts/CacheTrait.php:72)
  at Symfony\Component\Cache\Adapter\AbstractAdapter->contractsGet(object(FilesystemAdapter), 'blog_authors', object(Closure), INF, array(), object(Logger))
     (vendor/symfony/cache/Traits/ContractsTrait.php:107)
  at Symfony\Component\Cache\Adapter\AbstractAdapter->doGet(object(FilesystemAdapter), 'blog_authors', object(Closure), INF, array())
     (vendor/symfony/cache-contracts/CacheTrait.php:35)
  at Symfony\Component\Cache\Adapter\AbstractAdapter->get('blog_authors', object(Closure), INF, array())
     (vendor/symfony/cache/Adapter/TraceableAdapter.php:56)
  at Symfony\Component\Cache\Adapter\TraceableAdapter->get('blog_authors', object(Closure), INF)
     (src/Blog.php:149)
  at App\Blog->getAuthors(true)
     (src/Blog.php:37)
  at App\Blog->bustCache()
     (src/EventSubscriber/ContentRefreshSubscriber.php:45)
  at App\EventSubscriber\ContentRefreshSubscriber->refresh()
     (src/EventSubscriber/ContentRefreshSubscriber.php:34)
  at App\EventSubscriber\ContentRefreshSubscriber->onKernelTerminate(object(TerminateEvent), 'kernel.terminate', object(EventDispatcher))
     (vendor/symfony/event-dispatcher/EventDispatcher.php:270)
  at Symfony\Component\EventDispatcher\EventDispatcher::Symfony\Component\EventDispatcher\{closure}(object(TerminateEvent), 'kernel.terminate', object(EventDispatcher))
     (vendor/symfony/event-dispatcher/EventDispatcher.php:230)
  at Symfony\Component\EventDispatcher\EventDispatcher->callListeners(array(object(Closure), object(Closure)), 'kernel.terminate', object(TerminateEvent))
     (vendor/symfony/event-dispatcher/EventDispatcher.php:59)
  at Symfony\Component\EventDispatcher\EventDispatcher->dispatch(object(TerminateEvent), 'kernel.terminate')
     (vendor/symfony/http-kernel/HttpKernel.php:94)
  at Symfony\Component\HttpKernel\HttpKernel->terminate(object(Request), object(Response))
     (vendor/symfony/http-kernel/Kernel.php:159)
  at Symfony\Component\HttpKernel\Kernel->terminate(object(Request), object(Response))
     (public/index.php:36)