Skip to content

Commit

Permalink
Add Doctrine DHMiddleware by default (#331)
Browse files Browse the repository at this point in the history
  • Loading branch information
dmitryuk authored Nov 14, 2022
1 parent 9ad2367 commit f5c3fa3
Show file tree
Hide file tree
Showing 4 changed files with 161 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,22 @@
namespace DH\AuditorBundle\DependencyInjection\Compiler;

use DH\Auditor\Provider\Doctrine\Auditing\Annotation\AnnotationLoader;
use DH\Auditor\Provider\Doctrine\Auditing\Logger\Middleware\DHMiddleware;
use DH\Auditor\Provider\Doctrine\DoctrineProvider;
use DH\Auditor\Provider\Doctrine\Service\AuditingService;
use DH\Auditor\Provider\Doctrine\Service\StorageService;
use Doctrine\DBAL\Driver\Middleware;
use Symfony\Component\DependencyInjection\ChildDefinition;
use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Definition;
use Symfony\Component\DependencyInjection\Reference;

/** @see \DH\AuditorBundle\Tests\DependencyInjection\Compiler\DoctrineMiddlewareCompilerPassTest */
class DoctrineProviderConfigurationCompilerPass implements CompilerPassInterface
{
private bool $isDHMiddlewareSupported = false;

public function process(ContainerBuilder $container): void
{
if (!$container->hasDefinition(DoctrineProvider::class)) {
Expand Down Expand Up @@ -46,6 +52,9 @@ public function process(ContainerBuilder $container): void
}

\assert(\is_array($config) && \array_key_exists('auditing_services', $config));

$this->registerDHMiddleware($container);

foreach (array_unique($config['auditing_services']) as $entityManagerName) {
$entityManagerName = str_replace('@', '', $entityManagerName);
$entityManagerReference = new Reference($entityManagerName);
Expand All @@ -62,6 +71,40 @@ public function process(ContainerBuilder $container): void
$container->setDefinition(AnnotationLoader::class, $annotationLoaderDefinition);

$providerDefinition->addMethodCall('registerAuditingService', [$serviceReference]);
$this->configureDHMiddleware($container, $entityManagerName);
}
}

private function registerDHMiddleware(ContainerBuilder $container): void
{
if (interface_exists(Middleware::class) && class_exists(DHMiddleware::class)) {
$this->isDHMiddlewareSupported = true;
$container->register('doctrine.dbal.dh_middleware', DHMiddleware::class);
}
}

private function configureDHMiddleware(ContainerBuilder $container, string $entityManagerName): void
{
if (false === $this->isDHMiddlewareSupported) {
return;
}

$argument = $container->getDefinition($entityManagerName)->getArgument(0);
if (!$argument instanceof Reference) {
return;
}
$connectionName = (string) $argument;

/** @see vendor/doctrine/doctrine-bundle/DependencyInjection/DoctrineExtension.php */
$configurationName = $connectionName.'.configuration';
if (!$container->hasDefinition($configurationName)) {
return;
}
$configuration = $container->getDefinition($configurationName);
$DHMiddlewareDef = $container->setDefinition(
$connectionName.'.dh_middleware',
new ChildDefinition('doctrine.dbal.dh_middleware')
);
$configuration->addMethodCall('setMiddlewares', [[$DHMiddlewareDef]]);
}
}
9 changes: 7 additions & 2 deletions tests/App/Command/CreatePostCommand.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,15 +15,20 @@

class CreatePostCommand extends Command
{
protected static $defaultName = 'app:post:create';
private DoctrineProvider $doctrineProvider;

public function __construct(DoctrineProvider $doctrineProvider)
{
parent::__construct(self::$defaultName);
parent::__construct();
$this->doctrineProvider = $doctrineProvider;
}

protected function configure(): void
{
$this->setName('app:post:create');
parent::configure();
}

protected function execute(InputInterface $input, OutputInterface $output): int
{
$io = new SymfonyStyle($input, $output);
Expand Down
1 change: 1 addition & 0 deletions tests/App/config/packages/sf6/framework.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
framework:
secret: '%env(APP_SECRET)%'
test: true
http_method_override: false
router:
utf8: true
session:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
<?php

declare(strict_types=1);

namespace DH\AuditorBundle\Tests\DependencyInjection\Compiler;

use DH\Auditor\Configuration;
use DH\Auditor\Provider\Doctrine\Auditing\Logger\Middleware\DHMiddleware;
use DH\Auditor\Tests\Provider\Doctrine\Fixtures\Entity\Standard\Blog\Author;
use DH\Auditor\Tests\Provider\Doctrine\Fixtures\Entity\Standard\Blog\Comment;
use DH\Auditor\Tests\Provider\Doctrine\Fixtures\Entity\Standard\Blog\Post;
use DH\Auditor\Tests\Provider\Doctrine\Fixtures\Entity\Standard\Blog\Tag;
use DH\AuditorBundle\DependencyInjection\Compiler\DoctrineProviderConfigurationCompilerPass;
use DH\AuditorBundle\DependencyInjection\DHAuditorExtension;
use Doctrine\Bundle\DoctrineBundle\DependencyInjection\DoctrineExtension;
use Doctrine\DBAL\Driver\Middleware;
use Matthias\SymfonyDependencyInjectionTest\PhpUnit\AbstractCompilerPassTestCase;
use Symfony\Component\DependencyInjection\ChildDefinition;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Definition;

/**
* @internal
*
* @small
*/
final class DoctrineMiddlewareCompilerPassTest extends AbstractCompilerPassTestCase
{
public function testCompilerPass(): void
{
if (!interface_exists(Middleware::class) || !class_exists(DHMiddleware::class)) {
self::markTestSkipped('DHMiddleware isn\'t supported');
}
$this->container->setParameter('kernel.cache_dir', sys_get_temp_dir());
$this->container->setParameter('kernel.debug', false);
$this->container->setParameter('kernel.bundles', []);
$doctrineConfig = [
'dbal' => [
'default_connection' => 'default',
'connections' => [
'default' => [],
],
],
'orm' => [
'auto_mapping' => true,
],
];
$this->setParameter('doctrine', $doctrineConfig);

$DHConfig = [
'enabled' => true,
'timezone' => 'UTC',
'user_provider' => 'dh_auditor.user_provider',
'security_provider' => 'dh_auditor.security_provider',
'role_checker' => 'dh_auditor.role_checker',
'providers' => [
'doctrine' => [
'table_prefix' => '',
'table_suffix' => '_audit',
'ignored_columns' => [
0 => 'createdAt',
1 => 'updatedAt',
],
'entities' => [
Author::class => [
'enabled' => true,
],
Post::class => [
'enabled' => true,
],
Comment::class => [
'enabled' => true,
],
Tag::class => [
'enabled' => true,
],
],
'storage_services' => [
0 => '@doctrine.orm.default_entity_manager',
],
'auditing_services' => [
0 => '@doctrine.orm.default_entity_manager',
],
'viewer' => true,
'storage_mapper' => null,
],
],
];
$this->setParameter('dh_auditor.configuration', $DHConfig);

$auditorService = new Definition();
$this->setDefinition(Configuration::class, $auditorService);
$this->container->loadFromExtension('doctrine', $doctrineConfig);
$this->container->loadFromExtension('dh_auditor', $DHConfig);
$this->compile();

$this->assertContainerBuilderHasServiceDefinitionWithMethodCall(
'doctrine.dbal.default_connection.configuration',
'setMiddlewares',
[[new ChildDefinition('doctrine.dbal.dh_middleware')]]
);
}

protected function registerCompilerPass(ContainerBuilder $container): void
{
$this->container->registerExtension(new DoctrineExtension());
$this->container->registerExtension(new DHAuditorExtension());
$container->addCompilerPass(new DoctrineProviderConfigurationCompilerPass());
}
}

0 comments on commit f5c3fa3

Please # to comment.