<?php
declare(strict_types=1);
namespace Sentry\SentryBundle\EventListener;
use Sentry\State\HubInterface;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Route;
abstract class AbstractTracingRequestListener
{
use KernelEventForwardCompatibilityTrait;
/**
* @var HubInterface The current hub
*/
protected $hub;
/**
* Constructor.
*
* @param HubInterface $hub The current hub
*/
public function __construct(HubInterface $hub)
{
$this->hub = $hub;
}
/**
* This method is called once a response for the current HTTP request is
* created, but before it is sent off to the client. Its use is mainly for
* gathering information like the HTTP status code and attaching them as
* tags of the span/transaction.
*
* @param RequestListenerResponseEvent $event The event
*/
public function handleKernelResponseEvent(RequestListenerResponseEvent $event): void
{
/** @var Response $response */
$response = $event->getResponse();
$span = $this->hub->getSpan();
if (null === $span) {
return;
}
$span->setHttpStatus($response->getStatusCode());
}
/**
* Gets the name of the route or fallback to the controller FQCN if the
* route is anonymous (e.g. a subrequest).
*
* @param Request $request The HTTP request
*/
protected function getRouteName(Request $request): string
{
$route = $request->attributes->get('_route');
if ($route instanceof Route) {
$route = $route->getPath();
}
if (null === $route) {
$route = $request->attributes->get('_controller');
if (\is_array($route) && \is_callable($route, true)) {
$route = sprintf('%s::%s', \is_object($route[0]) ? get_debug_type($route[0]) : $route[0], $route[1]);
}
}
return \is_string($route) ? $route : '<unknown>';
}
}