food_server/vendor/yansongda/artful/src/Logger.php
tk 9ef6902c1d 【类 型】:fix
【主	题】:提交runing字段
【描	述】:
	[原因]:正则匹配 bind_route 添加runing字段 PS:对应取出bind_route的, 即分割符
	[过程]:
	[影响]:
【结	束】
2024-07-09 17:35:54 +08:00

50 lines
1.6 KiB
PHP

<?php
declare(strict_types=1);
namespace Yansongda\Artful;
use Yansongda\Artful\Contract\ConfigInterface;
use Yansongda\Artful\Contract\LoggerInterface;
use Yansongda\Artful\Exception\ContainerException;
use Yansongda\Artful\Exception\Exception;
use Yansongda\Artful\Exception\InvalidParamsException;
use Yansongda\Artful\Exception\ServiceNotFoundException;
/**
* @method static void emergency($message, array $context = [])
* @method static void alert($message, array $context = [])
* @method static void critical($message, array $context = [])
* @method static void error($message, array $context = [])
* @method static void warning($message, array $context = [])
* @method static void notice($message, array $context = [])
* @method static void info($message, array $context = [])
* @method static void debug($message, array $context = [])
* @method static void log($message, array $context = [])
*/
class Logger
{
/**
* @throws ContainerException
* @throws ServiceNotFoundException
* @throws InvalidParamsException
*/
public static function __callStatic(string $method, array $args): void
{
if (!Artful::hasContainer() || !Artful::has(LoggerInterface::class)
|| false === Artful::get(ConfigInterface::class)->get('logger.enable', false)) {
return;
}
$class = Artful::get(LoggerInterface::class);
if ($class instanceof \Psr\Log\LoggerInterface) {
$class->{$method}(...$args);
return;
}
throw new InvalidParamsException(Exception::PARAMS_LOGGER_DRIVER_INVALID, '配置异常: 配置的 `LoggerInterface` 不符合 PSR 规范');
}
}