12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- <?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\Messenger\Middleware;
- use Symfony\Component\Messenger\Envelope;
- use Symfony\Component\Stopwatch\Stopwatch;
- /**
- * Collects some data about a middleware.
- *
- * @author Maxime Steinhausser <maxime.steinhausser@gmail.com>
- */
- class TraceableMiddleware implements MiddlewareInterface
- {
- private $stopwatch;
- private $busName;
- private $eventCategory;
- public function __construct(Stopwatch $stopwatch, string $busName, string $eventCategory = 'messenger.middleware')
- {
- $this->stopwatch = $stopwatch;
- $this->busName = $busName;
- $this->eventCategory = $eventCategory;
- }
- /**
- * {@inheritdoc}
- */
- public function handle(Envelope $envelope, StackInterface $stack): Envelope
- {
- $stack = new TraceableStack($stack, $this->stopwatch, $this->busName, $this->eventCategory);
- try {
- return $stack->next()->handle($envelope, $stack);
- } finally {
- $stack->stop();
- }
- }
- }
- /**
- * @internal
- */
- class TraceableStack implements StackInterface
- {
- private $stack;
- private $stopwatch;
- private $busName;
- private $eventCategory;
- private $currentEvent;
- public function __construct(StackInterface $stack, Stopwatch $stopwatch, string $busName, string $eventCategory)
- {
- $this->stack = $stack;
- $this->stopwatch = $stopwatch;
- $this->busName = $busName;
- $this->eventCategory = $eventCategory;
- }
- /**
- * {@inheritdoc}
- */
- public function next(): MiddlewareInterface
- {
- if (null !== $this->currentEvent && $this->stopwatch->isStarted($this->currentEvent)) {
- $this->stopwatch->stop($this->currentEvent);
- }
- if ($this->stack === $nextMiddleware = $this->stack->next()) {
- $this->currentEvent = 'Tail';
- } else {
- $this->currentEvent = sprintf('"%s"', get_debug_type($nextMiddleware));
- }
- $this->currentEvent .= sprintf(' on "%s"', $this->busName);
- $this->stopwatch->start($this->currentEvent, $this->eventCategory);
- return $nextMiddleware;
- }
- public function stop(): void
- {
- if (null !== $this->currentEvent && $this->stopwatch->isStarted($this->currentEvent)) {
- $this->stopwatch->stop($this->currentEvent);
- }
- $this->currentEvent = null;
- }
- }
|