8
0
Fork 0
oxid-sql-logger/src/OxidSQLLogger.php

60 Zeilen
1.2 KiB
PHP

<?php
/**
* @author Tobias Matthaiou <developer@tobimat.eu>
* @author D3 Data Development - Daniel Seifert <support@shopmodule.com>
*/
namespace D3\OxidSqlLogger;
use Doctrine\DBAL\Logging\SQLLogger;
use Monolog;
/**
* Class OxidSQLLogger
*/
class OxidSQLLogger implements SQLLogger
{
public $message;
public $file;
public $line;
/**
* @inheritDoc
*/
public function __construct($message = null, $file = null, $line = null)
{
if (!Monolog\Registry::hasLogger('sql')) {
Monolog\Registry::addLogger((new LoggerFactory())->create('sql'));
}
$this->message = $message;
$this->file = $file;
$this->line = $line;
}
/**
* @inheritDoc
*/
public function startQuery($sql, array $params = null, array $types = null)
{
Monolog\Registry::sql()->addDebug(
$this->message,
[
'query' => $sql,
'params' => $params,
'types' => $types,
'calling_file' => $this->file,
'calling_line' => $this->line
]
);
}
/**
* @inheritDoc
*/
public function stopQuery()
{
}
}