mirror of
https://github.com/Seldaek/monolog.git
synced 2025-10-22 17:16:18 +02:00
CS fixes and set the default NewRelicHandler level to ERROR, refs #105
This commit is contained in:
@@ -64,7 +64,7 @@ class CubeHandler extends AbstractProcessingHandler
|
|||||||
protected function connectUdp()
|
protected function connectUdp()
|
||||||
{
|
{
|
||||||
if (!extension_loaded('sockets')) {
|
if (!extension_loaded('sockets')) {
|
||||||
throw new \LogicException('The sockets extension is needed to use udp URLs with the CubeHandler');
|
throw new MissingExtensionException('The sockets extension is required to use udp URLs with the CubeHandler');
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->udpConnection = socket_create(AF_INET, SOCK_DGRAM, 0);
|
$this->udpConnection = socket_create(AF_INET, SOCK_DGRAM, 0);
|
||||||
|
@@ -11,43 +11,49 @@
|
|||||||
|
|
||||||
namespace Monolog\Handler;
|
namespace Monolog\Handler;
|
||||||
|
|
||||||
use Monolog\Handler\MissingExtensionException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class to record a log on a NewRelic application
|
* Class to record a log on a NewRelic application
|
||||||
*
|
*
|
||||||
* @see https://newrelic.com/docs/php/new-relic-for-php
|
* @see https://newrelic.com/docs/php/new-relic-for-php
|
||||||
*/
|
*/
|
||||||
class NewRelicHandler extends AbstractProcessingHandler
|
class NewRelicHandler extends AbstractProcessingHandler
|
||||||
{
|
{
|
||||||
const ERROR_MISSING_EXTENSION = "The NewRelic PHP extension is not installed on this system, therefore you can't use the NewRelicHandler";
|
|
||||||
const NEWRELIC_EXTENSION_NAME = 'newrelic';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritdoc}
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
public function __construct($level = Logger::ERROR, $bubble = true)
|
||||||
|
{
|
||||||
|
parent::__construct($level, $bubble);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
protected function write(array $record)
|
protected function write(array $record)
|
||||||
{
|
{
|
||||||
if ($this->isNewRelicEnabled()) {
|
if (!$this->isNewRelicEnabled()) {
|
||||||
newrelic_notice_error($record['message']);
|
throw new MissingExtensionException('The newrelic PHP extension is required to use the NewRelicHandler');
|
||||||
|
}
|
||||||
foreach ($record['context'] as $key => $parameter) {
|
|
||||||
newrelic_add_custom_parameter($key, $parameter);
|
if (isset($record['context']['exception']) && $record['context']['exception'] instanceof \Exception) {
|
||||||
}
|
newrelic_notice_error($record['message'], $record['context']['exception']);
|
||||||
|
unset($record['context']['exception']);
|
||||||
return;
|
} else {
|
||||||
|
newrelic_notice_error($record['message']);
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($record['context'] as $key => $parameter) {
|
||||||
|
newrelic_add_custom_parameter($key, $parameter);
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new MissingExtensionException(self::ERROR_MISSING_EXTENSION);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks whether the NewRelic extension is enabled in the system.
|
* Checks whether the NewRelic extension is enabled in the system.
|
||||||
*
|
*
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
protected function isNewRelicEnabled()
|
protected function isNewRelicEnabled()
|
||||||
{
|
{
|
||||||
return (bool) extension_loaded(self::NEWRELIC_EXTENSION_NAME);
|
return extension_loaded('newrelic');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user