mirror of
https://github.com/shlinkio/shlink.git
synced 2025-01-20 21:43:12 -06:00
67 lines
2.0 KiB
PHP
67 lines
2.0 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Shlinkio\Shlink;
|
|
|
|
use Laminas\ServiceManager\Factory\InvokableFactory;
|
|
use Monolog\Level;
|
|
use Monolog\Logger;
|
|
use PhpMiddleware\RequestId;
|
|
use Psr\Log\LoggerInterface;
|
|
use Psr\Log\NullLogger;
|
|
use Shlinkio\Shlink\Common\Logger\LoggerFactory;
|
|
use Shlinkio\Shlink\Common\Logger\LoggerType;
|
|
use Shlinkio\Shlink\Common\Middleware\AccessLogMiddleware;
|
|
|
|
use function Shlinkio\Shlink\Config\runningInRoadRunner;
|
|
|
|
return (static function (): array {
|
|
$common = [
|
|
'level' => Level::Info->value,
|
|
'processors' => [RequestId\MonologProcessor::class],
|
|
'line_format' => '[%datetime%] [%extra.request_id%] %channel%.%level_name% - %message%',
|
|
];
|
|
|
|
return [
|
|
|
|
'logger' => [
|
|
'Shlink' => [
|
|
'type' => LoggerType::FILE->value,
|
|
...$common,
|
|
],
|
|
'Access' => [
|
|
'type' => LoggerType::STREAM->value,
|
|
'destination' => 'php://stderr',
|
|
'add_new_line' => ! runningInRoadRunner(),
|
|
...$common,
|
|
],
|
|
],
|
|
|
|
'dependencies' => [
|
|
'factories' => [
|
|
'Logger_Shlink' => [LoggerFactory::class, 'Shlink'],
|
|
'Logger_Access' => [LoggerFactory::class, 'Access'],
|
|
NullLogger::class => InvokableFactory::class,
|
|
],
|
|
'aliases' => [
|
|
'logger' => 'Logger_Shlink',
|
|
Logger::class => 'Logger_Shlink',
|
|
LoggerInterface::class => 'Logger_Shlink',
|
|
AccessLogMiddleware::LOGGER_SERVICE_NAME => 'Logger_Access',
|
|
],
|
|
],
|
|
|
|
'mezzio-swoole' => [
|
|
'swoole-http-server' => [
|
|
'logger' => [
|
|
// Let's disable mezio-swoole access logging, so that we can provide our own implementation,
|
|
// consistent for roadrunner and openswoole
|
|
'logger-name' => NullLogger::class,
|
|
],
|
|
],
|
|
],
|
|
|
|
];
|
|
})();
|