engelsystem/src/Logger/EngelsystemLogger.php

89 lines
2.0 KiB
PHP
Raw Normal View History

2017-09-19 18:30:42 +02:00
<?php
namespace Engelsystem\Logger;
2018-08-31 01:55:05 +02:00
use Engelsystem\Models\LogEntry;
2017-09-19 18:30:42 +02:00
use Psr\Log\AbstractLogger;
use Psr\Log\InvalidArgumentException;
use Psr\Log\LogLevel;
class EngelsystemLogger extends AbstractLogger
{
protected $allowedLevels = [
LogLevel::ALERT,
LogLevel::CRITICAL,
LogLevel::DEBUG,
LogLevel::EMERGENCY,
LogLevel::ERROR,
LogLevel::INFO,
LogLevel::NOTICE,
LogLevel::WARNING,
];
2018-08-31 01:55:05 +02:00
/** @var LogEntry */
protected $log;
/**
* EngelsystemLogger constructor.
*
* @param LogEntry $log
*/
2018-08-31 01:55:05 +02:00
public function __construct(LogEntry $log)
{
$this->log = $log;
}
2017-09-19 18:30:42 +02:00
/**
* Logs with an arbitrary level.
*
* @TODO: Implement $context['exception']
*
* @param mixed $level
* @param string $message
* @param array $context
*
* @throws InvalidArgumentException
*/
public function log($level, $message, array $context = [])
{
if (!$this->checkLevel($level)) {
2018-08-31 01:55:05 +02:00
throw new InvalidArgumentException('Unknown log level: ' . $level);
2017-09-19 18:30:42 +02:00
}
$message = $this->interpolate($message, $context);
2018-08-31 01:55:05 +02:00
$this->log->create(['level' => $level, 'message' => $message]);
2017-09-19 18:30:42 +02:00
}
/**
* Interpolates context values into the message placeholders.
*
* @param string $message
* @param array $context
* @return string
*/
protected function interpolate($message, array $context = [])
{
foreach ($context as $key => $val) {
// check that the value can be casted to string
if (is_array($val) || (is_object($val) && !method_exists($val, '__toString'))) {
continue;
}
// replace the values of the message
$message = str_replace('{' . $key . '}', $val, $message);
}
return $message;
}
/**
* @param string $level
* @return bool
*/
protected function checkLevel($level)
{
return in_array($level, $this->allowedLevels);
}
}