Проблема с контроллером Slim 3: использование $ this, когда не в контексте объекта - PullRequest
0 голосов
/ 14 декабря 2018

Возникла проблема с использованием $this->container внутри моих контроллеров.

Когда я пытаюсь получить доступ к логгеру / монологу в приведенном ниже коде, он с треском проваливается:

$this->container->get('logger')->addInfo('Request: users->get-one');

Вот код в src/dependancies.php:

<?php

$container = $app->getContainer();

// monolog
$container['logger'] = function ($c) {
    $logs = $c->get('settings')['logger'];
    $logger = new Monolog\Logger($logs['name']);
    $logger->pushProcessor(new Monolog\Processor\UidProcessor());
    $logger->pushHandler(new Monolog\Handler\StreamHandler($logs['path'], $logs['level']));

    return $logger;
};

// database
$container['db'] = function ($c) {
    $database = $c->get('settings')['database'];

    $capsule = new \Illuminate\Database\Capsule\Manager;
    $capsule->addConnection([
        'driver' => 'mysql',
        'host' => $database['hostname'],
        'database' => $database['database'],
        'username' => $database['username'],
        'password' => $database['password'],
        'charset' => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix'    => '',
    ]);
    $capsule->setAsGlobal();
    $capsule->bootEloquent();

    return $capsule;
};

// register users controller
require __DIR__ . '/../src/controllers/users.php';

$container['UsersController'] = function($c) {
    return new UsersController($c);
};

Ниже приведен код, который находится в src/controllers/users.php:

<?php

use Psr\Container\ContainerInterface;
use Slim\Http\Request;
use Slim\Http\Response;

class UsersController {
    protected $container;

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

    public function get(Request $request, Response $response, $args) {
        $this->container->get('logger')->addInfo('Request: users->get-one');

        /**
         * TODO: Replace $args['id'] with the id from the current token payload
         */
        $data = Users::find($args['id']);

        return $response->withJSON($data)->withStatus(200);
    }

    public function create(Request $request, Response $response, $args) {
        $this->logger->addInfo('Request: users->create');

        $user = $request->getParsedBody();

        $data = Users::create([
            'first_name' => $user['first_name'],
            'last_name' => $user['last_name'],
            'email' => $user['email'],
            'password' => password_hash($user['password'], PASSWORD_BCRYPT),
            'telephone' => $user['telephone'],
            'timezone' => $user['timezone'],
            'verification' => '011010'
        ]);

        return $response->withJSON($data)->withStatus(200);
    }

    public function update(Request $request, Response $response, $args) {
        $this->logger->addInfo('Request: users->update');

        $user = $request->getParsedBody();

        $data = Users::where('id', $args['id'])->update([
            'first_name' => $user['first_name'],
            'last_name' => $user['last_name'],
            'email' => $user['email'],
            'password' => password_hash($user['password'], PASSWORD_BCRYPT),
            'telephone' => $user['telephone'],
            'timezone' => $user['timezone']
        ]);

        return $response->withJSON($data)->withStatus(200);
    }

    public function delete(Request $request, Response $response, $args) {
        $this->logger->addInfo('Request: users->delete');

        $data = Users::destroy($args['id']);

        return $response->withJSON($data)->withStatus(200);
    }

    /*
    * ==============================
    * Manager Functions Routines
    * ==============================
    */
    public function getAll(Request $request, Response $response, $args) {
        $this->logger->addInfo('Request: admin->users->getAll');

        $data = Users::all();

        return $response->withJSON($data)->withStatus(200);
    }
}

Я пробовал следовать различным учебным пособиям, а также документации на веб-сайте Slim, однако, похоже, что ничего не решило проблему.Я уверен, что это что-то легко исправить, что мне просто не хватает.

PHP Slim 3 Framework - Использовать MonoLog в пользовательском классе - Использование $ this, когда не в контексте объекта - Принятый ответ здесь простокажется глупым, когда я хочу иметь доступ ко всему контейнеру приложения, а не только к регистратору.

Любая помощь приветствуется.

Спасибо!

1 Ответ

0 голосов
/ 14 декабря 2018

Ну, я понял это.Очевидно, использование двух точек с запятой при вызове процедуры контроллера не является правильным способом выполнения действий.Ой!

/*
 * users::read::one
 * method:get
 */
$app->get('/users', '\UsersController::get');

Когда приведенный выше код настроен на использование только одной точки с запятой, он работает:

/*
 * users::read::one
 * method:get
 */
$app->get('/users', '\UsersController:get');
...