Total Complexity | 6 |
Total Lines | 52 |
Duplicated Lines | 0 % |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
7 | class Logger extends AbstractLogger |
||
8 | { |
||
9 | private function formatMessage($message, $logLevel, $context) |
||
10 | { |
||
11 | $message = str_replace("'", "\'", $message); |
||
12 | $formattedMessage = '[' . date('Y-m-d H:i:s') . ']'; |
||
13 | $formattedMessage = $formattedMessage . ' ' . strtoupper($logLevel) . ': '; |
||
14 | $formattedMessage = $formattedMessage . 'Message: ' . $message; |
||
15 | if (!empty($context)) { |
||
16 | $formattedMessage = $formattedMessage . ', Context: ' . json_encode($context); |
||
17 | } |
||
18 | return $formattedMessage; |
||
19 | } |
||
20 | |||
21 | public function log($logLevel, $message, array $context = []) |
||
22 | { |
||
23 | $consoleFunctionMap = [ |
||
24 | 'emergency' => 'error', |
||
25 | 'alert' => 'warn', |
||
26 | 'critical' => 'error', |
||
27 | 'error' => 'error', |
||
28 | 'warning' => 'warn', |
||
29 | 'notice' => 'log', |
||
30 | 'info' => 'info', |
||
31 | 'debug' => 'debug', |
||
32 | ]; |
||
33 | $message = $this->formatMessage($message, $logLevel, $context); |
||
34 | echo "<script>"; |
||
35 | echo sprintf("console.%s('%s');", $consoleFunctionMap[$logLevel], $message); |
||
36 | echo "</script>"; |
||
37 | } |
||
38 | |||
39 | public function clearLog() |
||
40 | { |
||
41 | echo "<script>"; |
||
42 | echo "console.clear();"; |
||
43 | echo "</script>"; |
||
44 | } |
||
45 | |||
46 | public function group($groupLabel) |
||
47 | { |
||
48 | $groupLabel = str_replace("'", "\'", $groupLabel); |
||
49 | echo "<script>"; |
||
50 | echo sprintf("console.group('%s');", $groupLabel); |
||
51 | echo "</script>"; |
||
52 | } |
||
53 | |||
54 | public function groupEnd() |
||
59 | } |
||
60 | } |
||
61 |