forked from codeigniter4/CodeIgniter4
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathErrorlogHandler.php
More file actions
95 lines (80 loc) · 2.45 KB
/
ErrorlogHandler.php
File metadata and controls
95 lines (80 loc) · 2.45 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
declare(strict_types=1);
/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <[email protected]>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
namespace CodeIgniter\Log\Handlers;
use CodeIgniter\Log\Exceptions\LogException;
/**
* Log handler that writes to PHP's `error_log()`
*
* @see \CodeIgniter\Log\Handlers\ErrorlogHandlerTest
*/
class ErrorlogHandler extends BaseHandler
{
/**
* Message is sent to PHP's system logger, using the Operating System's
* system logging mechanism or a file, depending on what the error_log
* configuration directive is set to.
*/
public const TYPE_OS = 0;
/**
* Message is sent directly to the SAPI logging handler.
*/
public const TYPE_SAPI = 4;
/**
* Says where the error should go. Currently supported are
* 0 (`TYPE_OS`) and 4 (`TYPE_SAPI`).
*
* @var 0|4
*/
protected $messageType = 0;
/**
* Constructor.
*
* @param array{handles?: list<string>, messageType?: int} $config
*/
public function __construct(array $config = [])
{
parent::__construct($config);
$messageType = $config['messageType'] ?? self::TYPE_OS;
if (! is_int($messageType) || ! in_array($messageType, [self::TYPE_OS, self::TYPE_SAPI], true)) {
throw LogException::forInvalidMessageType(print_r($messageType, true));
}
$this->messageType = $messageType;
}
/**
* Handles logging the message.
* If the handler returns false, then execution of handlers
* will stop. Any handlers that have not run, yet, will not
* be run.
*
* @param string $level
* @param string $message
* @param array<string, mixed> $context
*/
public function handle($level, $message, array $context = []): bool
{
if ($context !== []) {
$message .= ' ' . $this->encodeContext($context);
}
$message = strtoupper($level) . ' --> ' . $message . "\n";
return $this->errorLog($message, $this->messageType);
}
/**
* Extracted call to `error_log()` in order to be tested.
*
* @param 0|4 $messageType
*
* @codeCoverageIgnore
*/
protected function errorLog(string $message, int $messageType): bool
{
return error_log($message, $messageType);
}
}