firefly-iii/config/logging.php

135 lines
4.6 KiB
PHP
Raw Normal View History

2018-03-07 13:47:39 -06:00
<?php
/**
* logging.php
2020-03-17 11:06:30 -05:00
* Copyright (c) 2019 james@firefly-iii.org.
2018-03-07 13:47:39 -06:00
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2018-03-07 13:47:39 -06:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
2018-03-07 13:47:39 -06:00
*
* This program is distributed in the hope that it will be useful,
2018-03-07 13:47:39 -06:00
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
2018-03-07 13:47:39 -06:00
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
2018-03-07 13:47:39 -06:00
*/
declare(strict_types=1);
2019-02-09 13:44:31 -06:00
2019-02-08 00:13:59 -06:00
use FireflyIII\Support\Logging\AuditLogger;
2021-10-02 23:48:22 -05:00
use Monolog\Handler\SyslogUdpHandler;
2018-03-07 13:47:39 -06:00
2023-08-30 08:38:15 -05:00
// to correctly redirect audit channel messages the
// options for the audit stack are set here, but can be overruled
// from an environment variable:
$auditChannels = ['audit_daily', 'audit_stdout'];
$option = envNonEmpty('AUDIT_LOG_CHANNEL', '');
if ('' !== (string)$option) {
$auditChannels = [$option];
}
2018-03-07 13:47:39 -06:00
return [
/*
|--------------------------------------------------------------------------
| Default Log Channel
|--------------------------------------------------------------------------
|
| This option defines the default log channel that gets used when writing
| messages to the logs. The name specified in this option should match
| one of the channels defined in the "channels" configuration array.
|
*/
2020-02-13 13:13:17 -06:00
'default' => envNonEmpty('LOG_CHANNEL', 'stack'),
2020-03-17 11:06:30 -05:00
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
2018-03-07 13:47:39 -06:00
/*
|--------------------------------------------------------------------------
| Log Channels
|--------------------------------------------------------------------------
|
| Here you may configure the log channels for your application. Out of
| the box, Laravel uses the Monolog PHP logging library. This gives
| you a variety of powerful log handlers / formatters to utilize.
|
| Available Drivers: "single", "daily", "slack", "syslog",
| "errorlog", "custom", "stack"
|
*/
'channels' => [
2023-08-30 08:38:15 -05:00
// default channels for 'stack' and 'audit' logs are stdout and daily logs.
2022-03-29 08:01:12 -05:00
'stack' => [
2018-03-07 13:47:39 -06:00
'driver' => 'stack',
'channels' => ['daily', 'stdout'],
2018-03-07 13:47:39 -06:00
],
2022-03-29 08:01:12 -05:00
'audit' => [
2020-08-13 06:18:54 -05:00
'driver' => 'stack',
2023-08-30 08:38:15 -05:00
'channels' => $auditChannels,
2020-08-13 06:18:54 -05:00
],
2022-03-29 08:01:12 -05:00
'papertrail' => [
'driver' => 'monolog',
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
'handler' => SyslogUdpHandler::class,
2021-10-02 23:48:22 -05:00
'handler_with' => [
'host' => env('PAPERTRAIL_HOST'),
'port' => env('PAPERTRAIL_PORT'),
],
2021-10-02 23:26:25 -05:00
],
// single laravel log file:
2022-03-29 08:01:12 -05:00
'single' => [
2018-03-07 13:47:39 -06:00
'driver' => 'single',
'path' => storage_path('logs/laravel.log'),
2018-08-17 13:01:46 -05:00
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
],
2021-10-02 23:26:25 -05:00
// stdout, used in stack 'stack' by default:
2022-03-29 08:01:12 -05:00
'stdout' => [
2018-08-17 13:01:46 -05:00
'driver' => 'single',
'path' => 'php://stdout',
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
2018-03-07 13:47:39 -06:00
],
2021-10-02 23:26:25 -05:00
// daily, used in stack 'stack' by default:
2022-03-29 08:01:12 -05:00
'daily' => [
2018-03-07 13:47:39 -06:00
'driver' => 'daily',
2023-06-21 05:34:58 -05:00
'path' => storage_path('logs/ff3-' . PHP_SAPI . '.log'),
2018-04-26 23:26:37 -05:00
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
2018-03-07 13:47:39 -06:00
'days' => 7,
],
2021-10-02 23:26:25 -05:00
// the audit log destinations:
2022-03-29 08:01:12 -05:00
'audit_daily' => [
2020-08-13 06:18:54 -05:00
'driver' => 'daily',
2019-02-08 00:13:59 -06:00
'path' => storage_path('logs/ff3-audit.log'),
2019-02-09 13:44:31 -06:00
'tap' => [AuditLogger::class],
2020-11-20 08:44:17 -06:00
'level' => envNonEmpty('AUDIT_LOG_LEVEL', 'info'),
2019-02-08 00:13:59 -06:00
'days' => 90,
],
2022-03-29 08:01:12 -05:00
'audit_stdout' => [
2020-08-13 06:55:16 -05:00
'driver' => 'single',
'path' => 'php://stdout',
'tap' => [AuditLogger::class],
2021-03-14 10:08:49 -05:00
'level' => envNonEmpty('AUDIT_LOG_LEVEL', 'info'),
2020-08-13 06:55:16 -05:00
],
2018-03-07 13:47:39 -06:00
2021-10-02 23:26:25 -05:00
// syslog destination
2022-03-29 08:01:12 -05:00
'syslog' => [
2018-03-07 13:47:39 -06:00
'driver' => 'syslog',
2018-04-26 23:26:37 -05:00
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
2018-03-07 13:47:39 -06:00
],
2021-10-02 23:26:25 -05:00
// errorlog destination
2022-03-29 08:01:12 -05:00
'errorlog' => [
2018-03-07 13:47:39 -06:00
'driver' => 'errorlog',
2018-04-26 23:26:37 -05:00
'level' => envNonEmpty('APP_LOG_LEVEL', 'info'),
2018-03-07 13:47:39 -06:00
],
],
];