-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLoggerAdapter.php
78 lines (68 loc) · 1.73 KB
/
LoggerAdapter.php
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
<?php
namespace WebStream\Log;
use Psr\Log\LoggerInterface;
use Psr\Log\LoggerTrait;
/**
* LoggerAdapterクラス
* PSR-3実装のロガーをWebStreamロガーに委譲
* @author Ryuichi Tanaka
* @since 2015/12/03
* @version 0.7
*/
class LoggerAdapter implements LoggerInterface
{
use LoggerTrait;
/**
* @var Logger ロガーインスタンス
*/
private Logger $logger;
/**
* コンストラクタ
* @param Logger $logger ロガー
*/
public function __construct(Logger $logger)
{
$this->logger = $logger;
}
/**
* PSR-3ロガーに定義されていないログレベルの呼び出しを受ける
* @param string $name ログレベル
* @param array $arguments 引数
*/
public function __call(string $name, array $arguments)
{
$message = null;
if (array_key_exists(0, $arguments)) {
$message = $arguments[0];
}
if (array_key_exists(1, $arguments)) {
$this->log($name, $message, $arguments[1]);
} else {
$this->log($name, $message, []);
}
}
/**
* Logs with an arbitrary level.
* @param mixed $level ログレベル
* @param mixed $message メッセージ
* @param array $context 埋め込み値リスト
*/
public function log($level, $message, array $context = []): void
{
$this->logger->write($level, $message, $context);
}
/**
* 遅延書き出しを有効にする
*/
public function enableLazyWrite()
{
$this->logger->lazyWrite();
}
/**
* 即時書き出しを有効にする
*/
public function enableDirectWrite()
{
$this->logger->directWrite();
}
}