Я хочу написать имя пользователя как дополнительное поле в производственный журнал.
Как мне это сделать?
У меня есть этот конфиг в config.yml:
services:
monolog.formatter.logprocessor:
class: Monolog\Formatter\LineFormatter
arguments:
- "[%%datetime%%] [%%username%%] %%channel%%.%%level_name%%: %%message%%\n"
monolog.processor.logprocessor:
class: Acme\CoreBundle\Monolog\LogProcessor
tags:
- { name: monolog.processor, method: processRecord }
monolog:
handlers:
main:
type: stream
path: "%kernel.logs_dir%/%kernel.environment%.log"level: warning
formatter: monolog.formatter.logprocessor
Когда я пытался внедрить security.context в LogProcessor, я получаю сообщение об ошибке:
[Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException]
Circular reference detected for service "monolog.processor.logprocessor", path: "router ->
monolog.logger.router -> monolog.processor.logprocessor -> security.context -> security.a
uthorization_checker -> security.authentication.manager -> security.user.provider.concrete
.chain_provider -> security.user.provider.concrete.main -> doctrine.orm.default_entity_manager -> doctrine.dbal.default_connection -> monolog.logger.doctrine".
Вот конфигурация
# Service Configuration
services:
monolog.formatter.html:
class: Monolog\Formatter\HtmlFormatter
monolog.processor.web_processor:
class: Monolog\Processor\WebProcessor
tags:
- { name: monolog.processor, method: __invoke }
monolog.processor.user:
class: Company\ToolBoxBundle\Services\Monolog\ExtraProcessor
arguments: ["@security.token_storage"]
tags:
- { name: monolog.processor }
- { name: kernel.event_listener, event: kernel.request, method: onKernelRequest }
И сервисный код
namespace Company\ToolBoxBundle\Services\Monolog;
use Symfony\Component\HttpKernel\Event\GetResponseEvent;
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
class ExtraProcessor
{
private $tokenStorage = null;
private $user = null;
private $postParams = null;
public function __construct(TokenStorageInterface $tokenStorage)
{
$this->tokenStorage = $tokenStorage;
}
public function __invoke(array $record)
{
if (null !== $this->user) {
$record['extra']['user'] = $this->user->getUserDetails();
}
if (null !== $this->postParams) {
$record['extra']['postParams'] = $this->postParams;
}
return $record;
}
public function onKernelRequest(GetResponseEvent $event)
{
$postParams = $event->getRequest()->request->all();
if(false === empty($postParams)){
$this->postParams = serialize($postParams);
}
if (null === $token = $this->tokenStorage->getToken()) {
return;
}
if (!is_object($user = $token->getUser())) {
// e.g. anonymous authentication
return;
}
$this->user = $user;
}
}
Если вы используете версию Symfony> = 2.4, вы можете посмотреть на этот комплект
это должно помочь вам делать то, что вы хотите 🙂