RoutingTransactionNameSubscriber.php in New Relic 2.x
File
src/EventSubscriber/RoutingTransactionNameSubscriber.php
View source
<?php
namespace Drupal\new_relic_rpm\EventSubscriber;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Routing\RouteBuildEvent;
use Drupal\Core\Routing\RoutingEvents;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpFoundation\Request;
class RoutingTransactionNameSubscriber implements EventSubscriberInterface {
public static function getSubscribedEvents() {
return [
RoutingEvents::ALTER => [
'addTransactionNamesToRoutes',
],
];
}
public function addTransactionNamesToRoutes(RouteBuildEvent $event) {
$collection = $event
->getRouteCollection();
foreach ($collection as $route_name => $route) {
$route
->setDefault('_transaction_name', $route_name);
if (substr_compare($route_name, 'entity.', 0)) {
$route
->setDefault('_transaction_name_callback', [
self::class,
'entityBundleRouteTransactionName',
]);
}
}
if ($route = $collection
->get('node.add')) {
$route
->setDefault('_transaction_name_callback', [
self::class,
'nodeAddTransactionName',
]);
}
}
public static function entityBundleRouteTransactionName(Request $request) {
$name = $request->attributes
->get('_transaction_name');
if (preg_match('/^entity\\.([a-z_]+)\\./', $name, $matches)) {
$entity_type = $matches[1];
if (($entity = $request->attributes
->get($entity_type)) && $entity instanceof EntityInterface && $entity
->getEntityTypeId() !== $entity
->bundle()) {
return sprintf('%s:%s', $name, $entity
->bundle());
}
}
return $name;
}
public static function nodeAddTransactionName(Request $request) {
$name = $request->attributes
->get('_transaction_name');
if (($node_type = $request->attributes
->get('node_type')) && $node_type instanceof EntityInterface) {
return sprintf('%s:%s', $name, $node_type
->id());
}
return $name;
}
}