PHP-DI с использованием ранее определенного класса - PullRequest
0 голосов
/ 24 июня 2019

Я пытаюсь улучшить конфигурацию PHP-DI, и теперь я застрял.

Я хочу повторно использовать уже определенный класс для другого класса.

entityManager класс должен исходить от Database->getEntityManager

Вот часть моего файла конфигурации:

return [
    'database.user'     => 'xxxxxxx',
    'database.password' => 'xxxxxxx',
    'database.name'     => 'xxxxxxx',
    'database.host'     => '127.0.0.1',
    'database.port'     => 3306,

    \ABCData\Database\Database::class => DI\autowire()->constructor(
        DI\get('database.user'),
        DI\get('database.password'),
        DI\get('database.name'),
        DI\get('database.host'),
        DI\get('database.port')
    ),


//    \Doctrine\ORM\EntityManager::class => DI\factory(function () {
//        $database = new ABCData\Database\Database(
//            \ABCData\Database\Config::DB_USER,
//            \ABCData\Database\Config::DB_PASSWORD,
//            \ABCData\Database\Config::DB_DATABASE,
//            \ABCData\Database\Config::DB_HOST
//        );
//        return $database->getEntityManager();
//    }),


    \Doctrine\ORM\EntityManager::class => DI\autowire(\ABCData\Database\Database::class)->method('getEntityManager'),
...

Когда я внедряю базу данных, это прекрасно работает. Прокомментированное определение работает хорошо, но я хочу добиться последней строки, но она терпит неудачу.

Вот моя полная реализация моего класса базы данных:

private $userName;

private $password;

private $database;

private $host;

private $port;

public function __construct($username, $password, $database, $host, $port = 3306)
{
    $this->userName = $username;
    $this->password = $password;
    $this->database = $database;
    $this->host = $host;
    $this->port = $port;
}

public function getEntityManager()
{
    $isDevMode = true;
    $paths = [APP_DIR . 'classes/Entities'];
    $connectionCredentials = $this->getConnectionCredentials();

    $config = Setup::createAnnotationMetadataConfiguration($paths, $isDevMode);
    $entityManager = \Doctrine\ORM\EntityManager::create($connectionCredentials, $config);
    $connection = $entityManager->getConnection();

    $sqlSchemaManager = new SQLServerSchemaManager($connection);
    $sqlSchemaManager->getDatabasePlatform()->registerDoctrineTypeMapping('enum', 'string');

    return $entityManager;
}

private function getConnectionCredentials()
{
    return [
        'driver'   => 'pdo_mysql',
        'user'     => $this->userName,
        'password' => $this->password,
        'dbname'   => $this->database,
        'host'     => $this->host,
        'port'     => $this->port
    ];
}

Когда мой код должен создать экземпляр entityManager, я получаю эту ошибку:

Entry "ABCData\ABCDataAPI\CronJob" cannot be resolved: Entry "ABCData\DataStructure\Save" cannot be resolved: Entry "Doctrine\ORM\EntityManager" cannot be resolved: Parameter $username of __construct() has no value defined or guessable
Full definition:
Object (
    class = ABCData\Database\Database
    lazy = false
    __construct(
        $username = #UNDEFINED#
        $password = #UNDEFINED#
        $database = #UNDEFINED#
        $host = #UNDEFINED#
        $port = (default value) 3306
    )
    getEntityManager(

    )
)

Кажется, он не использует ранее определенную базу данных.

Что я не так делаю?

1 Ответ

0 голосов
/ 01 июля 2019

Хорошо, я неправильно понял документацию.

Это то, что я сделал. Если у вас есть идея получше, скажите, пожалуйста:

\Doctrine\ORM\EntityManager::class => DI\factory(function (\ABCData\Database\Database $database) {
    return $database->getEntityManager();
}),
...