внедрение зависимостей — параметр ввода PHP-DI по имени

Я использую php-di и Doctrine вместе. Для использования Доктрины есть bootstrap.php файл, который создает $entityManager объект. $entityManager объект определен глобально в этом файле, поэтому, чтобы использовать его в моих классах, я должен внедрить его.

Например, предположим, что класс ниже:

<?php
interface IAccountService{
function login(string $username, string $password);
}
class AccountService implements IAccountService {

private $entityManager;

public function __construct($entityManager) {
$this->entityManager = $entityManager;
}

public function login(string $email, string $password){
$q = $this->entityManager->createQueryBuilder()
->select('us.id, us.name, us.email, us.passwordHashed')
->from('User', 'us')
->where('us.email = ?1 AND us.passwordHashed = ?2')
->setMaxResults( '1' )
->setParameter(1,$email)
->setParameter(2, HASHHELPER::hashPasswordSHA512($password, $email))
->getQuery();

// echo $q->getSql();

$users = $q->getResult();

// print_r($users);

if(!empty($users) && count($users) > 0){
$_SESSION["USER"] = $users[0];
return true;
}
else{
return false;
}
}
}
?>

Но тип $entityManager не очень хорошо определен, и когда я звоню echo gettype($entityManager); это печатает "object" в результате. Поэтому я думаю, что мне нужно ввести этот параметр по имени, а не по типу. Я имею в виду что-то вроде этого:

$container->set('$entityManager', $entityManager);

Но это не работает. Какое решение и лучший способ?

1

Решение

Можете ли вы показать, как вы вводите EntityManager сейчас?

Кроме того, рекомендуется использовать подсказки типов:

public function __construct(EntityManager $entityManager) {
$this->entityManager = $entityManager;
}

ОБНОВИТЬ:

Хорошо, я обычно использую PHP-DI с файлом конфигурации PHP (http://php-di.org/doc/php-definitions.html). Это будет выглядеть примерно так:

return [
AccountService::class => DI\object(AccountService::class)->constructor("here goes EntityManager object")
];
2

Другие решения

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

AccountService.php

<?php
interface IAccountService{
function login(string $username, string $password);
}
class AccountService implements IAccountService {

private $entityManager;

public function __construct(Doctrine\ORM\EntityManagerInterface $entityManager) {
$this->entityManager = $entityManager;
}

public function login(string $email, string $password){
$q = $this->entityManager->createQueryBuilder()
->select('us.id, us.name, us.email, us.passwordHashed')
->from('User', 'us')
->where('us.email = ?1 AND us.passwordHashed = ?2')
->setMaxResults( '1' )
->setParameter(1,$email)
->setParameter(2, HASHHELPER::hashPasswordSHA512($password, $email))
->getQuery();

// echo $q->getSql();

$users = $q->getResult();

// print_r($users);

if(!empty($users) && count($users) > 0){
$_SESSION["USER"] = $users[0];
return true;
}
else{
return false;
}
}
}
?>

routes.php

<?php
spl_autoload_register(function ($class_name) {
switch ($class_name){
case 'AccountController':
require_once 'controllers/account_controller.php';
break;
case 'AccountService':
case 'IAccountService':
require_once 'services/account_service.php';
break;
case 'URLHELPER':
require_once 'helpers/URLHELPER.php';
break;
case 'STRINGHELPER':
require_once 'helpers/STRINGHELPER.php';
break;
case 'HASHHELPER':
require_once "helpers/HASHHELPER.php";
break;
case 'User':
require_once "models/entities/user.php";
break;
}
});

function call($controller, $action) {
global $entityManager;
$container = DI\ContainerBuilder::buildDevContainer();
$container->set('IAccountService', \DI\object('AccountService'));
$container->set('Doctrine\ORM\EntityManagerInterface', $entityManager);

// require the file that matches the controller name
require_once('controllers/' . $controller . '_controller.php');

// create a new instance of the needed controller
switch($controller) {
case 'home':
$controller = $container->get('HomeController');
break;
case 'account':
$controller = $container->get('AccountController');
break;
default:
$controller = 'home';
$action = 'index';
}

// call the action
$controller->{ $action }();
}

// just a list of the controllers we have and their actions
// we consider those "allowed" values
$controllers = array(
'home' => ['index', 'error']
,'account' => ['login']
);

// check that the requested controller and action are both allowed
// if someone tries to access something else he will be redirected to the error action of the pages controller
if (array_key_exists($controller, $controllers)) {
if (in_array($action, $controllers[$controller])) {
call($controller, $action);
} else {
call('home', 'error');
}
} else {
call('home', 'error');
}
?>

Спасибо тем, кто задумывался над этим вопросом.

0

По вопросам рекламы [email protected]