mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 18:56:51 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Exceptions;
 | |
| 
 | |
| use Exception;
 | |
| use Filament\Notifications\Notification;
 | |
| use Illuminate\Http\Request;
 | |
| use Psr\Log\LoggerInterface;
 | |
| use Illuminate\Http\Response;
 | |
| use Illuminate\Container\Container;
 | |
| use Prologue\Alerts\AlertsMessageBag;
 | |
| use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
 | |
| 
 | |
| class DisplayException extends PanelException implements HttpExceptionInterface
 | |
| {
 | |
|     public const LEVEL_DEBUG = 'debug';
 | |
|     public const LEVEL_INFO = 'info';
 | |
|     public const LEVEL_WARNING = 'warning';
 | |
|     public const LEVEL_ERROR = 'error';
 | |
| 
 | |
|     /**
 | |
|      * DisplayException constructor.
 | |
|      */
 | |
|     public function __construct(string $message, ?\Throwable $previous = null, protected string $level = self::LEVEL_ERROR, int $code = 0)
 | |
|     {
 | |
|         parent::__construct($message, $code, $previous);
 | |
|     }
 | |
| 
 | |
|     public function getErrorLevel(): string
 | |
|     {
 | |
|         return $this->level;
 | |
|     }
 | |
| 
 | |
|     public function getStatusCode(): int
 | |
|     {
 | |
|         return Response::HTTP_BAD_REQUEST;
 | |
|     }
 | |
| 
 | |
|     public function getHeaders(): array
 | |
|     {
 | |
|         return [];
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Render the exception to the user by adding a flashed message to the session
 | |
|      * and then redirecting them back to the page that they came from. If the
 | |
|      * request originated from an API hit, return the error in JSONAPI spec format.
 | |
|      */
 | |
|     public function render(Request $request)
 | |
|     {
 | |
|         if ($request->is('livewire/update')) {
 | |
|             Notification::make()
 | |
|                 ->title(static::class)
 | |
|                 ->body($this->getMessage())
 | |
|                 ->danger()
 | |
|                 ->send();
 | |
| 
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         if ($request->expectsJson()) {
 | |
|             return response()->json(Handler::toArray($this), $this->getStatusCode(), $this->getHeaders());
 | |
|         }
 | |
| 
 | |
|         app(AlertsMessageBag::class)->danger($this->getMessage())->flash();
 | |
| 
 | |
|         return redirect()->back()->withInput();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Log the exception to the logs using the defined error level only if the previous
 | |
|      * exception is set.
 | |
|      *
 | |
|      * @throws \Throwable
 | |
|      */
 | |
|     public function report()
 | |
|     {
 | |
|         if (!$this->getPrevious() instanceof \Exception || !Handler::isReportable($this->getPrevious())) {
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         try {
 | |
|             $logger = Container::getInstance()->make(LoggerInterface::class);
 | |
|         } catch (Exception) {
 | |
|             throw $this->getPrevious();
 | |
|         }
 | |
| 
 | |
|         return $logger->{$this->getErrorLevel()}($this->getPrevious());
 | |
|     }
 | |
| }
 | 
