Как получить доступ к $ container в классе middleware В Slim v3?
Я читал, что в Slim v2 $app был привязан к классу middleware. Я нахожу, что это не так в v3? Ниже приведен мой класс middleware, но я просто получаю неопределенное:
<?php
namespace CrSrcMiddleware;
class Auth
{
/**
* Example middleware invokable class
*
* @param PsrHttpMessageServerRequestInterface $request PSR7 request
* @param PsrHttpMessageResponseInterface $response PSR7 response
* @param callable $next Next middleware
*
* @return PsrHttpMessageResponseInterface
*/
public function __invoke($request, $response, $next)
{
// before
var_dump($this->getContainer()); // method undefined
var_dump($this->auth); exit; // method undefined
if (! $this->get('auth')->isAuthenticated()) {
// Not authenticated and must be authenticated to access this resource
return $response->withStatus(401);
}
// pass onto the next callable
$response = $next($request, $response);
// after
return $response;
}
}
каков правильный способ доступа к контейнеру DI в промежуточном по? Полагаю, должен быть способ?
2 ответов
немного опоздала на вечеринку, но может помочь другим... При создании экземпляра промежуточного программного обеспечения
$container = $app->getContainer();
$app->add(new Auth($container));
и Ваше промежуточное ПО нуждается в конструкторе
<?php
namespace CrSrc\Middleware;
class Auth
{
private $container;
public function __construct($container) {
$this->container = $container
}
/**
* Example middleware invokable class
*
* @param \Psr\Http\Message\ServerRequestInterface $request PSR7 request
* @param \Psr\Http\Message\ResponseInterface $response PSR7 response
* @param callable $next Next middleware
*
* @return \Psr\Http\Message\ResponseInterface
*/
public function __invoke($request, $response, $next)
{
// $this->container has the DI
}
}
LE: Расширяя немного первоначальный ответ, контейнер получает вводится в конструктор если вы поставляете промежуточное ПО как класс строка
$app->add('Auth');
или
$app->add('Auth:similarToInvokeMethod')
насколько я понимаю код, Slim (v3) работает следующим образом:
- если вы передаете закрытие как промежуточное ПО, то оно вызывает
bindTo
с контейнером как param. -
Если вы передаете класс / строку, которая разрешается в класс, то Slim создает экземпляр и передает контейнер как param конструктору
<?php $app->add(Auth);
в противном случае (например, если вы добавляете экземпляр промежуточного ПО, созданный ранее), то похоже, что вам нужно забота о прохождении всех необходимых справок.