Classes/Log/Message/ExceptionHandlerLogRecordMessage.php
<?php
declare(strict_types=1);
/*
* This file is part of the TYPO3 CMS extension "mteu/typo3-stream-writer".
*
* Copyright (C) 2024 Martin Adler <mteu@mailbox.org>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
namespace mteu\StreamWriter\Log\Message;
use TYPO3\CMS\Core\Log\LogRecord;
/**
* LogOutput.
*
* @author Martin Adler <mteu@mailbox.org>
* @license GPL-3.0-or-later
*/
final class ExceptionHandlerLogRecordMessage implements Message
{
public function __construct(
private readonly string $level,
private readonly string $component,
private readonly string $mode,
private readonly string $applicationMode,
private readonly string $exceptionClass,
private readonly int|string $exceptionCode,
private readonly string $file,
private readonly int|string $line,
private readonly string $message,
) {}
public function print(): string
{
return sprintf(
'[%s] %s: %s' . PHP_EOL,
strtoupper($this->level),
$this->component,
$this->printData(),
);
}
public function printData(): string
{
return sprintf(
'(%s: %s) %s, code %d, file %s, line %d: %s',
$this->mode,
$this->applicationMode,
$this->exceptionClass,
$this->exceptionCode,
$this->file,
$this->line,
$this->message,
);
}
public static function create(LogRecord $record): self
{
$recordData = $record->getData();
return new self(
$record->getLevel(),
$record->getComponent(),
$recordData['mode'] ?? '',
$recordData['application_mode'] ?? '',
$recordData['exception_class'] ?? '',
$recordData['exception_code'] ?? 0,
$recordData['file'] ?? '',
$recordData['line'] ?? 0,
$recordData['message'] ?? '',
);
}
}