ILIAS  trunk Revision v11.0_alpha-1689-g66c127b4ae8
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilTraceProcessor.php
Go to the documentation of this file.
1 <?php
2 
19 declare(strict_types=1);
32 {
33  private int $level = 0;
34 
35  public function __construct(int $a_level)
36  {
37  $this->level = $a_level;
38  }
39 
43  public function __invoke(array $record): array
44  {
45  if ($record['level'] < $this->level) {
46  return $record;
47  }
48 
49  $trace = debug_backtrace();
50 
51  // shift current method
52  array_shift($trace);
53 
54  // shift internal monolog calls
55  array_shift($trace);
56  array_shift($trace);
57  array_shift($trace);
58  array_shift($trace);
59 
60  if (is_array($trace) && count($trace)) {
61  $trace_info =
62  ($trace[0]['class'] ?? '') . '::' .
63  ($trace[0]['function'] ?? '') . ':' .
64  ($trace[0]['line'] ?? '');
65  $record['extra'] = array_merge(
66  $record['extra'],
67  array('trace' => $trace_info)
68  );
69  }
70  return $record;
71  }
72 }