mirror of
https://github.com/Seldaek/monolog.git
synced 2025-08-08 14:16:42 +02:00
Format deep array params before sending to newrelic, fixes #579
This commit is contained in:
@@ -12,6 +12,7 @@
|
|||||||
namespace Monolog\Handler;
|
namespace Monolog\Handler;
|
||||||
|
|
||||||
use Monolog\Logger;
|
use Monolog\Logger;
|
||||||
|
use Monolog\Formatter\NormalizerFormatter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class to record a log on a NewRelic application.
|
* Class to record a log on a NewRelic application.
|
||||||
@@ -80,33 +81,33 @@ class NewRelicHandler extends AbstractProcessingHandler
|
|||||||
|
|
||||||
if ($transactionName = $this->getTransactionName($record['context'])) {
|
if ($transactionName = $this->getTransactionName($record['context'])) {
|
||||||
$this->setNewRelicTransactionName($transactionName);
|
$this->setNewRelicTransactionName($transactionName);
|
||||||
unset($record['context']['transaction_name']);
|
unset($record['formatted']['context']['transaction_name']);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($record['context']['exception']) && $record['context']['exception'] instanceof \Exception) {
|
if (isset($record['context']['exception']) && $record['context']['exception'] instanceof \Exception) {
|
||||||
newrelic_notice_error($record['message'], $record['context']['exception']);
|
newrelic_notice_error($record['message'], $record['context']['exception']);
|
||||||
unset($record['context']['exception']);
|
unset($record['formatted']['context']['exception']);
|
||||||
} else {
|
} else {
|
||||||
newrelic_notice_error($record['message']);
|
newrelic_notice_error($record['message']);
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($record['context'] as $key => $parameter) {
|
foreach ($record['formatted']['context'] as $key => $parameter) {
|
||||||
if (is_array($parameter) && $this->explodeArrays) {
|
if (is_array($parameter) && $this->explodeArrays) {
|
||||||
foreach ($parameter as $paramKey => $paramValue) {
|
foreach ($parameter as $paramKey => $paramValue) {
|
||||||
newrelic_add_custom_parameter('context_' . $key . '_' . $paramKey, $paramValue);
|
$this->setNewRelicParameter('context_' . $key . '_' . $paramKey, $paramValue);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
newrelic_add_custom_parameter('context_' . $key, $parameter);
|
$this->setNewRelicParameter('context_' . $key, $parameter);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($record['extra'] as $key => $parameter) {
|
foreach ($record['formatted']['extra'] as $key => $parameter) {
|
||||||
if (is_array($parameter) && $this->explodeArrays) {
|
if (is_array($parameter) && $this->explodeArrays) {
|
||||||
foreach ($parameter as $paramKey => $paramValue) {
|
foreach ($parameter as $paramKey => $paramValue) {
|
||||||
newrelic_add_custom_parameter('extra_' . $key . '_' . $paramKey, $paramValue);
|
$this->setNewRelicParameter('extra_' . $key . '_' . $paramKey, $paramValue);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
newrelic_add_custom_parameter('extra_' . $key, $parameter);
|
$this->setNewRelicParameter('extra_' . $key, $parameter);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -167,10 +168,31 @@ class NewRelicHandler extends AbstractProcessingHandler
|
|||||||
/**
|
/**
|
||||||
* Overwrites the name of the current transaction
|
* Overwrites the name of the current transaction
|
||||||
*
|
*
|
||||||
* @param $transactionName
|
* @param string $transactionName
|
||||||
*/
|
*/
|
||||||
protected function setNewRelicTransactionName($transactionName)
|
protected function setNewRelicTransactionName($transactionName)
|
||||||
{
|
{
|
||||||
newrelic_name_transaction($transactionName);
|
newrelic_name_transaction($transactionName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $key
|
||||||
|
* @param mixed $value
|
||||||
|
*/
|
||||||
|
protected function setNewRelicParameter($key, $value)
|
||||||
|
{
|
||||||
|
if (null === $value || is_scalar($value)) {
|
||||||
|
newrelic_add_custom_parameter($key, $value);
|
||||||
|
} else {
|
||||||
|
newrelic_add_custom_parameter($key, @json_encode($value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
protected function getDefaultFormatter()
|
||||||
|
{
|
||||||
|
return new NormalizerFormatter();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user