1
0
mirror of https://github.com/Seldaek/monolog.git synced 2025-10-23 09:36:11 +02:00

Amended PR #203 (RavenHandler batch improvements)

Filtered records based on their level
Took the record with the highest severity as the main one
This commit is contained in:
pvanliefland
2013-07-11 19:16:14 +02:00
parent 29ae147226
commit 474a0f7bc4

View File

@@ -66,20 +66,25 @@ class RavenHandler extends AbstractProcessingHandler
*/
public function handleBatch(array $records)
{
// the last records is the "main" one
$record = array_pop($records);
$level = $this->level;
// no need to go further if the main record is not at the right level
if ($record['level'] < $this->level) {
return;
}
// filter records based on their level
$records = array_filter($records, function($record) use($level) {
return $record['level'] >= $level;
});
// the record with the highest severity is the "main" one
$record = array_reduce($records, function($highest, $record) {
if($record['level'] >= $highest['level']) {
$highest = $record;
return $highest;
}
});
// the other ones are added as a context item
$logs = array();
foreach ($records as $r) {
if ($r['level'] < $this->level) {
continue;
}
$logs[] = $this->processRecord($r);
}