Установите дополнительное поле в Zend Logger при входе пользователя - PullRequest
0 голосов
/ 22 декабря 2018

Я пытаюсь обновить значение сопоставления столбцов, когда пользователь входит в систему.

В настоящее время мой регистратор инициализируется следующим образом:

$columnMap = [
                'timestamp' => 'timestamp',
                'priority' => 'priority',
                'priorityName' => 'priorityName',
                'message' => 'message',
                'extra' => array(
                    'userid' => 'userid'
                )
];

$writer = new \Zend\Log\Writer\Db($dbAdapter,'logs',$columnMap);
$formatter = new \Zend\Log\Formatter\Db();
$formatter->setDateTimeFormat("Y-m-d H:i:s");
$writer->setFormatter($formatter);
$this->logger->addWriter($writer);

Что я хотел бы сделатьобновляет userid extra field, когда пользователь входит в систему. Скорее всего, это произойдет внутри Module Class.У меня есть доступ к регистратору через диспетчер служб.

1 Ответ

0 голосов
/ 07 января 2019

Похоже, вам нужен слушатель для этого.Что-то вроде этого может удовлетворить ваши потребности:

<?php

namespace Authentication\Listener;

use Zend\EventManager\EventManagerInterface;
use Zend\EventManager\ListenerAggregateInterface;
use Zend\Mvc\MvcEvent;

class addFieldListener implements ListenerAggregateInterface
{
    //@todo add annotations
    protected $logger;

    /**
     * @var array
     */
    protected $listeners = [];

    // @todo strict type
    public function __construct($logger)
    {
        $this->setLogger($logger);
    }

    //You might have to change the priority, which is currently 1,
    public function attach(EventManagerInterface $events, $priority = 1)
    {
        $this->listeners[] = $events->attach(MvcEvent::EVENT_ROUTE, [$this, 'addField'], $priority);
    }

    public function detach(EventManagerInterface $events)
    {
        foreach ($this->listeners as $index => $listener) {
            if ($events->detach($listener)) {
                unset($this->listeners[$index]);
            }
        }
    }

    public function addField()
    {
        //Get logger and add field.
    }

    //Getters & setters.. ?
}

Config: module.config.php

<?php

use Authentication\Listener\addFieldListener;

return [
    'listeners' => [
        addFieldListener::class,
    ],
    'service_manager' => [
        'factories' => [
            addFieldListener::class => addFieldListenerFactory::class,
        ],
    ],
];

Примечание: Убедитесь, что фабрика предоставляет регистратор слушателю.

...