WyriHaximus /
php-psr-3-bunny
| 1 | <?php declare(strict_types=1); |
||
| 2 | |||
| 3 | namespace WyriHaximus\React\PSR3\Bunny; |
||
| 4 | |||
| 5 | use Bunny\Channel; |
||
| 6 | use Psr\Log\AbstractLogger; |
||
| 7 | use function WyriHaximus\PSR3\checkCorrectLogLevel; |
||
| 8 | use function WyriHaximus\PSR3\normalizeContext; |
||
| 9 | use function WyriHaximus\PSR3\processPlaceHolders; |
||
| 10 | |||
| 11 | final class ChannelLogger extends AbstractLogger |
||
| 12 | { |
||
| 13 | /** |
||
| 14 | * @var Channel |
||
| 15 | */ |
||
| 16 | private $channel; |
||
| 17 | |||
| 18 | /** |
||
| 19 | * @var array |
||
| 20 | */ |
||
| 21 | private $publishArguments; |
||
| 22 | |||
| 23 | /** |
||
| 24 | * @param Channel $channel |
||
| 25 | * @param array $publishArguments |
||
| 26 | */ |
||
| 27 | 14 | public function __construct(Channel $channel, ...$publishArguments) |
|
| 28 | { |
||
| 29 | 14 | $this->channel = $channel; |
|
| 30 | 14 | $this->publishArguments = $publishArguments; |
|
| 31 | 14 | } |
|
| 32 | |||
| 33 | 13 | public function log($level, $message, array $context = []) |
|
| 34 | { |
||
| 35 | 13 | checkCorrectLogLevel($level); |
|
| 36 | 12 | $context = normalizeContext($context); |
|
| 37 | 12 | $message = (string)$message; |
|
| 38 | 12 | $message = processPlaceHolders($message, $context); |
|
| 39 | 12 | $json = json_encode([ |
|
| 40 | 12 | 'level' => $level, |
|
| 41 | 12 | 'message' => $message, |
|
| 42 | 12 | 'context' => $context, |
|
| 43 | ]); |
||
| 44 | 12 | $this->channel->publish($json, ...$this->publishArguments); |
|
|
0 ignored issues
–
show
Bug
introduced
by
Loading history...
|
|||
| 45 | 12 | } |
|
| 46 | } |
||
| 47 |