coolify/app/Exceptions/Handler.php

66 lines
1.7 KiB
PHP
Raw Normal View History

2023-03-17 15:33:48 +01:00
<?php
namespace App\Exceptions;
2023-06-08 08:18:14 +02:00
use App\Models\InstanceSettings;
2023-03-17 15:33:48 +01:00
use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
2023-05-30 09:50:50 +02:00
use Sentry\Laravel\Integration;
2023-09-01 11:20:58 +02:00
use Sentry\State\Scope;
use Throwable;
2023-03-17 15:33:48 +01:00
class Handler extends ExceptionHandler
{
2023-06-08 08:18:14 +02:00
2023-03-17 15:33:48 +01:00
/**
* A list of exception types with their corresponding custom log levels.
*
* @var array<class-string<\Throwable>, \Psr\Log\LogLevel::*>
*/
protected $levels = [
//
];
/**
* A list of the exception types that are not reported.
*
* @var array<int, class-string<\Throwable>>
*/
protected $dontReport = [
2023-09-11 17:36:30 +02:00
ProcessException::class
2023-03-17 15:33:48 +01:00
];
/**
* A list of the inputs that are never flashed to the session on validation exceptions.
*
* @var array<int, string>
*/
protected $dontFlash = [
'current_password',
'password',
'password_confirmation',
];
private InstanceSettings $settings;
2023-03-17 15:33:48 +01:00
/**
* Register the exception handling callbacks for the application.
*/
public function register(): void
{
$this->reportable(function (Throwable $e) {
2023-06-08 08:18:14 +02:00
$this->settings = InstanceSettings::get();
if ($this->settings->do_not_track || isDev()) {
2023-06-08 08:18:14 +02:00
return;
}
2023-09-01 11:20:58 +02:00
app('sentry')->configureScope(
2023-09-11 22:45:07 +02:00
function (Scope $scope) {
$scope->setUser(
[
'id' => config('sentry.server_name'),
'email' => auth()->user()->email
]
);
2023-09-01 11:20:58 +02:00
}
);
2023-05-30 09:50:50 +02:00
Integration::captureUnhandledException($e);
2023-03-17 15:33:48 +01:00
});
}
}