Total Complexity | 8 |
Total Lines | 50 |
Duplicated Lines | 0 % |
Coverage | 100% |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
11 | class Target extends YiiTarget |
||
12 | { |
||
13 | protected ?Component $component = null; |
||
14 | |||
15 | 2 | public function init() |
|
16 | { |
||
17 | 2 | parent::init(); |
|
18 | |||
19 | 2 | $this->component = Yii::$app->honeybadger; |
|
20 | } |
||
21 | |||
22 | /** |
||
23 | * Exports the log messages to Honeybadger |
||
24 | * |
||
25 | * This method iterates through the collected log messages and sends them to Honeybadger. |
||
26 | * It handles both exceptions and error messages, sending them with appropriate context. |
||
27 | */ |
||
28 | 1 | public function export() |
|
29 | { |
||
30 | 1 | foreach ($this->messages as $message) { |
|
31 | 1 | [$context, , $category , , $traces] = $message; |
|
32 | |||
33 | 1 | if ($context instanceof Throwable) { |
|
34 | 1 | $this->component?->notify($context); |
|
35 | 1 | } elseif (is_string($context)) { |
|
36 | 1 | $data = [ |
|
37 | 1 | 'title' => $category, |
|
38 | 1 | 'message' => $context, |
|
39 | 1 | ]; |
|
40 | 1 | if (isset($traces[0]['file'])) { |
|
41 | 1 | $data['file'] = $traces[0]['file']; |
|
42 | } |
||
43 | 1 | if (isset($traces[0]['line'])) { |
|
44 | 1 | $data['line'] = $traces[0]['line']; |
|
45 | } |
||
46 | 1 | $this->component?->customNotification($data); |
|
47 | } |
||
48 | } |
||
49 | } |
||
50 | |||
51 | /** |
||
52 | * Generates the context information to be logged. |
||
53 | * The default implementation will dump user information, system variables, etc. |
||
54 | * Here returns an empty string. |
||
55 | * |
||
56 | * @return string the context information. If an empty string, it means no context information. |
||
57 | */ |
||
58 | 1 | protected function getContextMessage() |
|
61 | } |
||
62 | } |
||
63 |