<?php
declare(strict_types=1);
namespace Http\HttplugBundle\Collector;
use Http\Client\Common\PluginClientFactory as DefaultPluginClientFactory;
use Symfony\Component\EventDispatcher\Event as LegacyEvent;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpKernel\Kernel;
use Symfony\Contracts\EventDispatcher\Event;
if (Kernel::MAJOR_VERSION >= 5) {
\class_alias(Event::class, 'Http\HttplugBundle\Collector\PluginClientFactoryListenerEventClass');
} else {
\class_alias(LegacyEvent::class, 'Http\HttplugBundle\Collector\PluginClientFactoryListenerEventClass');
}
/**
* This subscriber ensures that every PluginClient created when using Http\Client\Common\PluginClientFactory without
* using the Symfony dependency injection container uses the Http\HttplugBundle\Collector\PluginClientFactory factory
* when profiling is enabled. This allows 0 config profiling of third party libraries which use HTTPlug.
*
* @author Fabien Bourigault <bourigaultfabien@gmail.com>
*
* @internal
*/
final class PluginClientFactoryListener implements EventSubscriberInterface
{
/**
* @var PluginClientFactory
*/
private $factory;
public function __construct(PluginClientFactory $factory)
{
$this->factory = $factory;
}
/**
* Make sure to profile clients created using PluginClientFactory.
*/
public function onEvent(PluginClientFactoryListenerEventClass $e)
{
DefaultPluginClientFactory::setFactory([$this->factory, 'createClient']);
}
/**
* {@inheritdoc}
*/
public static function getSubscribedEvents(): array
{
return [
'kernel.request' => ['onEvent', 1024],
'console.command' => ['onEvent', 1024],
];
}
}