mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 15:36:51 +01:00 
			
		
		
		
	 6125b07afa
			
		
	
	
		6125b07afa
		
			
		
	
	
	
	
		
			
			* Remove old admin * Remove controller test * Remove unused exceptions * Remove unused files * More small tweaks * Fix doc block * Remove unused service * Restore these * Add back autoDeploy * Revert "Add back autoDeploy" This reverts commit 630c1e08acf8056ce8e612f376fcd00c23d90aea. * Add these back * Add back exception * Remove ApiController again --------- Co-authored-by: RMartinOscar <40749467+RMartinOscar@users.noreply.github.com> Co-authored-by: Boy132 <mail@boy132.de> Co-authored-by: notCharles <charles@pelican.dev>
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Exceptions;
 | |
| 
 | |
| use Exception;
 | |
| use Filament\Notifications\Notification;
 | |
| use Illuminate\Http\JsonResponse;
 | |
| use Illuminate\Http\RedirectResponse;
 | |
| use Illuminate\Http\Request;
 | |
| use Psr\Log\LoggerInterface;
 | |
| use Illuminate\Http\Response;
 | |
| use Illuminate\Container\Container;
 | |
| 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): bool|RedirectResponse|JsonResponse
 | |
|     {
 | |
|         if ($request->is('livewire/update')) {
 | |
|             Notification::make()
 | |
|                 ->title(static::class)
 | |
|                 ->body($this->getMessage())
 | |
|                 ->danger()
 | |
|                 ->send();
 | |
| 
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         if ($request->expectsJson()) {
 | |
|             return response()->json(Handler::toArray($this), $this->getStatusCode(), $this->getHeaders());
 | |
|         }
 | |
| 
 | |
|         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(): void
 | |
|     {
 | |
|         if (!$this->getPrevious() instanceof \Exception || !Handler::isReportable($this->getPrevious())) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         try {
 | |
|             $logger = Container::getInstance()->make(LoggerInterface::class);
 | |
|         } catch (Exception) {
 | |
|             throw $this->getPrevious();
 | |
|         }
 | |
| 
 | |
|         $logger->{$this->getErrorLevel()}($this->getPrevious());
 | |
|     }
 | |
| }
 |