Sentry logger for Yii2
composer require notamedia/yii2-sentry
Add target class in the application config:
return [
'components' => [
'log' => [
'traceLevel' => YII_DEBUG ? 3 : 0,
'targets' => [
[
'class' => 'notamedia\sentry\SentryTarget',
'dsn' => 'http://2682ybvhbs347:[email protected]/1',
'levels' => ['error', 'warning'],
// Write the context information (the default is true):
'context' => true,
// Additional options for `Sentry\init`:
'clientOptions' => ['release' => '[email protected]']
],
],
],
],
];
Writing simple message:
\Yii::error('message', 'category');
Writing messages with extra data:
\Yii::warning([
'msg' => 'message',
'extra' => 'value',
], 'category');
extraCallback
property can modify extra's data as callable function:
'targets' => [
[
'class' => 'notamedia\sentry\SentryTarget',
'dsn' => 'http://2682ybvhbs347:[email protected]/1',
'levels' => ['error', 'warning'],
'context' => true, // Write the context information. The default is true.
'extraCallback' => function ($message, $extra) {
// some manipulation with data
$extra['some_data'] = \Yii::$app->someComponent->someMethod();
return $extra;
}
],
],
Writing messages with additional tags. If need to add additional tags for event, add tags
key in message. Tags are various key/value pairs that get assigned to an event, and can later be used as a breakdown or quick access to finding related events.
Example:
\Yii::warning([
'msg' => 'message',
'extra' => 'value',
'tags' => [
'extraTagKey' => 'extraTagValue',
]
], 'category');
More about tags see https://docs.sentry.io/learn/context/#tagging-events
Yii2 log levels converts to Sentry levels:
\yii\log\Logger::LEVEL_ERROR => 'error',
\yii\log\Logger::LEVEL_WARNING => 'warning',
\yii\log\Logger::LEVEL_INFO => 'info',
\yii\log\Logger::LEVEL_TRACE => 'debug',
\yii\log\Logger::LEVEL_PROFILE_BEGIN => 'debug',
\yii\log\Logger::LEVEL_PROFILE_END => 'debug',