Completed
Pull Request — master (#622)
by
unknown
02:21
created

DoctrineBundle.php (2 issues)

Labels
Severity

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
/*
4
 * This file is part of the Doctrine Bundle
5
 *
6
 * The code was originally distributed inside the Symfony framework.
7
 *
8
 * (c) Fabien Potencier <[email protected]>
9
 * (c) Doctrine Project, Benjamin Eberlei <[email protected]>
10
 *
11
 * For the full copyright and license information, please view the LICENSE
12
 * file that was distributed with this source code.
13
 */
14
15
namespace Doctrine\Bundle\DoctrineBundle;
16
17
use Doctrine\Common\Util\ClassUtils;
18
use Doctrine\Bundle\DoctrineBundle\Command\CreateDatabaseDoctrineCommand;
19
use Doctrine\Bundle\DoctrineBundle\Command\DropDatabaseDoctrineCommand;
20
use Doctrine\Bundle\DoctrineBundle\Command\Proxy\RunSqlDoctrineCommand;
21
use Doctrine\Bundle\DoctrineBundle\DependencyInjection\Compiler\EntityListenerPass;
22
use Doctrine\ORM\Proxy\Autoloader;
23
use Symfony\Component\Console\Application;
24
use Symfony\Component\DependencyInjection\Compiler\PassConfig;
25
use Symfony\Component\DependencyInjection\ContainerBuilder;
26
use Symfony\Component\DependencyInjection\IntrospectableContainerInterface;
27
use Symfony\Component\HttpKernel\Bundle\Bundle;
28
use Symfony\Bridge\Doctrine\DependencyInjection\CompilerPass\DoctrineValidationPass;
29
use Symfony\Bridge\Doctrine\DependencyInjection\CompilerPass\RegisterEventListenersAndSubscribersPass;
30
use Symfony\Bridge\Doctrine\DependencyInjection\Security\UserProvider\EntityFactory;
31
32
/**
33
 * Bundle.
34
 *
35
 * @author Fabien Potencier <[email protected]>
36
 * @author Jonathan H. Wage <[email protected]>
37
 */
38
class DoctrineBundle extends Bundle
39
{
40
    private $autoloader;
41
42
    /**
43
     * {@inheritDoc}
44
     */
45
    public function build(ContainerBuilder $container)
46
    {
47
        parent::build($container);
48
49
        $container->addCompilerPass(new RegisterEventListenersAndSubscribersPass('doctrine.connections', 'doctrine.dbal.%s_connection.event_manager', 'doctrine'), PassConfig::TYPE_BEFORE_OPTIMIZATION);
50
51
        if ($container->hasExtension('security')) {
52
            $container->getExtension('security')->addUserProviderFactory(new EntityFactory('entity', 'doctrine.orm.security.user.provider'));
53
        }
54
55
        $container->addCompilerPass(new DoctrineValidationPass('orm'));
56
        $container->addCompilerPass(new EntityListenerPass());
57
    }
58
59
    /**
60
     * {@inheritDoc}
61
     */
62
    public function boot()
63
    {
64
        // Register an autoloader for proxies to avoid issues when unserializing them
65
        // when the ORM is used.
66
        if ($this->container->hasParameter('doctrine.orm.proxy_namespace')) {
67
            $namespace = $this->container->getParameter('doctrine.orm.proxy_namespace');
68
            $dir = $this->container->getParameter('doctrine.orm.proxy_dir');
69
            $proxyGenerator = null;
70
71
            if ($this->container->getParameter('doctrine.orm.auto_generate_proxy_classes')) {
72
                // See https://github.com/symfony/symfony/pull/3419 for usage of references
73
                $container = &$this->container;
74
75
                $proxyGenerator = function ($proxyDir, $proxyNamespace, $class) use (&$container) {
76
                    $originalClassName = ClassUtils::getRealClass($class);
77
                    /** @var $registry Registry */
78
                    $registry = $container->get('doctrine');
79
80
                    // Tries to auto-generate the proxy file
81
                    /** @var $em \Doctrine\ORM\EntityManager */
82
                    foreach ($registry->getManagers() as $em) {
83
                        if (!$em->getConfiguration()->getAutoGenerateProxyClasses()) {
84
                            continue;
85
                        }
86
87
                        $metadataFactory = $em->getMetadataFactory();
88
89
                        if ($metadataFactory->isTransient($originalClassName)) {
90
                            continue;
91
                        }
92
93
                        $classMetadata = $metadataFactory->getMetadataFor($originalClassName);
94
95
                        $em->getProxyFactory()->generateProxyClasses(array($classMetadata));
96
97
                        clearstatcache(true, Autoloader::resolveFile($proxyDir, $proxyNamespace, $class));
98
99
                        break;
100
                    }
101
                };
102
            }
103
104
            $this->autoloader = Autoloader::register($dir, $namespace, $proxyGenerator);
105
        }
106
    }
107
108
    /**
109
     * {@inheritDoc}
110
     */
111
    public function shutdown()
112
    {
113
        if (null !== $this->autoloader) {
114
            spl_autoload_unregister($this->autoloader);
115
            $this->autoloader = null;
116
        }
117
118
        // Clear all entity managers to clear references to entities for GC
119 View Code Duplication
        if ($this->container->hasParameter('doctrine.entity_managers')) {
120
            foreach ($this->container->getParameter('doctrine.entity_managers') as $id) {
121
                if (!$this->container instanceof IntrospectableContainerInterface || $this->container->initialized($id)) {
0 ignored issues
show
The class Symfony\Component\Depend...tableContainerInterface does not exist. Did you forget a USE statement, or did you not list all dependencies?

This error could be the result of:

1. Missing dependencies

PHP Analyzer uses your composer.json file (if available) to determine the dependencies of your project and to determine all the available classes and functions. It expects the composer.json to be in the root folder of your repository.

Are you sure this class is defined by one of your dependencies, or did you maybe not list a dependency in either the require or require-dev section?

2. Missing use statement

PHP does not complain about undefined classes in ìnstanceof checks. For example, the following PHP code will work perfectly fine:

if ($x instanceof DoesNotExist) {
    // Do something.
}

If you have not tested against this specific condition, such errors might go unnoticed.

Loading history...
122
                    $this->container->get($id)->clear();
123
                }
124
            }
125
        }
126
127
        // Close all connections to avoid reaching too many connections in the process when booting again later (tests)
128 View Code Duplication
        if ($this->container->hasParameter('doctrine.connections')) {
129
            foreach ($this->container->getParameter('doctrine.connections') as $id) {
130
                if (!$this->container instanceof IntrospectableContainerInterface || $this->container->initialized($id)) {
0 ignored issues
show
The class Symfony\Component\Depend...tableContainerInterface does not exist. Did you forget a USE statement, or did you not list all dependencies?

This error could be the result of:

1. Missing dependencies

PHP Analyzer uses your composer.json file (if available) to determine the dependencies of your project and to determine all the available classes and functions. It expects the composer.json to be in the root folder of your repository.

Are you sure this class is defined by one of your dependencies, or did you maybe not list a dependency in either the require or require-dev section?

2. Missing use statement

PHP does not complain about undefined classes in ìnstanceof checks. For example, the following PHP code will work perfectly fine:

if ($x instanceof DoesNotExist) {
    // Do something.
}

If you have not tested against this specific condition, such errors might go unnoticed.

Loading history...
131
                    $this->container->get($id)->close();
132
                }
133
            }
134
        }
135
    }
136
137
    /**
138
     * {@inheritDoc}
139
     */
140
    public function registerCommands(Application $application)
141
    {
142
        // Use the default logic when the ORM is available.
143
        // This avoids listing all ORM commands by hand.
144
        if (class_exists('Doctrine\\ORM\\Version')) {
145
            parent::registerCommands($application);
146
147
            return;
148
        }
149
150
        // Register only the DBAL commands if the ORM is not available.
151
        $application->add(new CreateDatabaseDoctrineCommand());
152
        $application->add(new DropDatabaseDoctrineCommand());
153
        $application->add(new RunSqlDoctrineCommand());
154
    }
155
}
156