Files
kiri-core/kiri-engine/Error/ErrorHandler.php
T

125 lines
2.8 KiB
PHP
Raw Normal View History

2022-01-09 03:50:38 +08:00
<?php
/**
* Created by PhpStorm.
* User: whwyy
* Date: 2018/4/26 0026
* Time: 10:00
*/
declare(strict_types=1);
namespace Kiri\Error;
2022-06-22 19:02:30 +08:00
use Closure;
2023-08-28 12:01:30 +08:00
use ErrorException;
2022-01-09 03:50:38 +08:00
use Kiri\Abstracts\Component;
2023-07-31 23:09:00 +08:00
use Kiri\Events\OnSystemError;
2023-08-28 12:01:30 +08:00
use Throwable;
2022-01-09 03:50:38 +08:00
/**
* Class ErrorHandler
2022-01-12 14:10:33 +08:00
* @package Kiri\Base
2022-01-09 03:50:38 +08:00
* @property-read $asError
*/
class ErrorHandler extends Component implements ErrorInterface
{
2023-07-26 17:26:47 +08:00
/**
* @var string
*/
public string $category = 'app';
/**
* @param array|Closure|null $callback
* @return void
2023-07-31 23:09:00 +08:00
* @throws
2023-07-26 17:26:47 +08:00
*/
public function registerExceptionHandler(null|array|Closure $callback): void
{
if (empty($callback)) {
$callback = [$this, 'exceptionHandler'];
} else if (is_array($callback) && is_string($callback[0])) {
2024-08-29 17:01:09 +08:00
$callback[0] = \Kiri::getDi()->get($callback[0]);
2023-07-06 16:53:53 +08:00
}
2023-07-26 17:26:47 +08:00
set_exception_handler($callback);
}
/**
* @param array|Closure|null $callback
* @return void
2023-07-31 23:09:00 +08:00
* @throws
2023-07-26 17:26:47 +08:00
*/
public function registerErrorHandler(null|array|Closure $callback): void
{
if (empty($callback)) {
$callback = [$this, 'errorHandler'];
} else if (is_array($callback) && is_string($callback[0])) {
2024-08-29 17:01:09 +08:00
$callback[0] = \Kiri::getDi()->get($callback[0]);
2023-07-26 17:26:47 +08:00
}
set_error_handler($callback);
}
/**
* @param array|Closure|null $callback
* @return void
2023-07-31 23:09:00 +08:00
* @throws
2023-07-26 17:26:47 +08:00
*/
public function registerShutdownHandler(null|array|Closure $callback): void
{
if (empty($callback)) {
$callback = [$this, 'shutdown'];
} else if (is_array($callback) && is_string($callback[0])) {
2024-08-29 17:01:09 +08:00
$callback[0] = \Kiri::getDi()->get($callback[0]);
2023-07-26 17:26:47 +08:00
}
register_shutdown_function($callback);
}
/**
* @return void
2023-12-13 21:01:59 +08:00
* @throws
2023-12-12 15:35:38 +08:00
* @throws
2023-07-26 17:26:47 +08:00
*/
public function shutdown(): void
{
$lastError = error_get_last();
if (empty($lastError) || $lastError['type'] !== E_ERROR) {
return;
}
2023-12-13 21:01:59 +08:00
2025-12-31 00:19:31 +08:00
$this->getLogger()->logCategory($lastError['message'] . PHP_EOL);
2023-12-13 21:01:59 +08:00
2023-07-31 23:09:00 +08:00
event(new OnSystemError());
2023-07-26 17:26:47 +08:00
}
/**
2023-08-28 12:01:30 +08:00
* @param Throwable $exception
2023-07-26 17:26:47 +08:00
*
2023-12-12 15:35:38 +08:00
* @throws
2023-07-26 17:26:47 +08:00
*/
2023-08-28 12:01:30 +08:00
public function exceptionHandler(Throwable $exception): void
2023-07-26 17:26:47 +08:00
{
$this->category = 'exception';
2025-12-31 00:19:31 +08:00
$this->getLogger()->logCategory($exception);
2023-07-26 17:26:47 +08:00
2023-07-31 23:09:00 +08:00
event(new OnSystemError());
2023-07-26 17:26:47 +08:00
}
/**
2023-12-12 15:35:38 +08:00
* @throws
2023-07-26 17:26:47 +08:00
*/
public function errorHandler()
{
2023-08-24 12:01:34 +08:00
$error = func_get_args();
2023-07-26 17:26:47 +08:00
2023-07-31 23:09:00 +08:00
event(new OnSystemError());
2023-07-26 17:26:47 +08:00
2023-08-28 12:01:30 +08:00
throw new ErrorException($error[1], $error[0], 1, $error[2], $error[3]);
2023-07-26 17:26:47 +08:00
}
2022-01-09 03:50:38 +08:00
}