Вход Регистрация
Файл: gapps/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php
Строк: 435
<?php

namespace IlluminateFoundationExceptions;

use 
Exception;
use 
PsrLogLoggerInterface;
use 
IlluminateHttpResponse;
use 
IlluminateAuthAuthenticationException;
use 
IlluminateValidationValidationException;
use 
IlluminateAuthAccessAuthorizationException;
use 
IlluminateHttpExceptionHttpResponseException;
use 
SymfonyComponentDebugExceptionFlattenException;
use 
IlluminateDatabaseEloquentModelNotFoundException;
use 
SymfonyComponentHttpKernelExceptionHttpException;
use 
SymfonyComponentConsoleApplication as ConsoleApplication;
use 
SymfonyComponentHttpFoundationResponse as SymfonyResponse;
use 
SymfonyComponentHttpKernelExceptionNotFoundHttpException;
use 
SymfonyComponentDebugExceptionHandler as SymfonyExceptionHandler;
use 
IlluminateContractsDebugExceptionHandler as ExceptionHandlerContract;

class 
Handler implements ExceptionHandlerContract
{
    
/**
     * The log implementation.
     *
     * @var PsrLogLoggerInterface
     */
    
protected $log;

    
/**
     * A list of the exception types that should not be reported.
     *
     * @var array
     */
    
protected $dontReport = [];

    
/**
     * Create a new exception handler instance.
     *
     * @param  PsrLogLoggerInterface  $log
     * @return void
     */
    
public function __construct(LoggerInterface $log)
    {
        
$this->log $log;
    }

    
/**
     * Report or log an exception.
     *
     * @param  Exception  $e
     * @return void
     */
    
public function report(Exception $e)
    {
        if (
$this->shouldReport($e)) {
            
$this->log->error($e);
        }
    }

    
/**
     * Determine if the exception should be reported.
     *
     * @param  Exception  $e
     * @return bool
     */
    
public function shouldReport(Exception $e)
    {
        return ! 
$this->shouldntReport($e);
    }

    
/**
     * Determine if the exception is in the "do not report" list.
     *
     * @param  Exception  $e
     * @return bool
     */
    
protected function shouldntReport(Exception $e)
    {
        
$dontReport array_merge($this->dontReport, [HttpResponseException::class]);

        foreach (
$dontReport as $type) {
            if (
$e instanceof $type) {
                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Render an exception into a response.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  Exception  $e
     * @return SymfonyComponentHttpFoundationResponse
     */
    
public function render($requestException $e)
    {
        if (
$e instanceof HttpResponseException) {
            return 
$e->getResponse();
        } elseif (
$e instanceof ModelNotFoundException) {
            
$e = new NotFoundHttpException($e->getMessage(), $e);
        } elseif (
$e instanceof AuthenticationException) {
            return 
$this->unauthenticated($request$e);
        } elseif (
$e instanceof AuthorizationException) {
            
$e = new HttpException(403$e->getMessage());
        } elseif (
$e instanceof ValidationException && $e->getResponse()) {
            return 
$e->getResponse();
        }

        if (
$this->isHttpException($e)) {
            return 
$this->toIlluminateResponse($this->renderHttpException($e), $e);
        } else {
            return 
$this->toIlluminateResponse($this->convertExceptionToResponse($e), $e);
        }
    }

    
/**
     * Map exception into an illuminate response.
     *
     * @param  SymfonyComponentHttpFoundationResponse  $response
     * @param  Exception  $e
     * @return IlluminateHttpResponse
     */
    
protected function toIlluminateResponse($responseException $e)
    {
        
$response = new Response($response->getContent(), $response->getStatusCode(), $response->headers->all());

        return 
$response->withException($e);
    }

    
/**
     * Render an exception to the console.
     *
     * @param  SymfonyComponentConsoleOutputOutputInterface  $output
     * @param  Exception  $e
     * @return void
     */
    
public function renderForConsole($outputException $e)
    {
        (new 
ConsoleApplication)->renderException($e$output);
    }

    
/**
     * Render the given HttpException.
     *
     * @param  SymfonyComponentHttpKernelExceptionHttpException  $e
     * @return SymfonyComponentHttpFoundationResponse
     */
    
protected function renderHttpException(HttpException $e)
    {
        
$status $e->getStatusCode();

        if (
view()->exists("errors.{$status}")) {
            return 
response()->view("errors.{$status}", ['exception' => $e], $status$e->getHeaders());
        } else {
            return 
$this->convertExceptionToResponse($e);
        }
    }

    
/**
     * Create a Symfony response for the given exception.
     *
     * @param  Exception  $e
     * @return SymfonyComponentHttpFoundationResponse
     */
    
protected function convertExceptionToResponse(Exception $e)
    {
        
$e FlattenException::create($e);

        
$handler = new SymfonyExceptionHandler(config('app.debug'));

        
$decorated $this->decorate($handler->getContent($e), $handler->getStylesheet($e));

        return 
SymfonyResponse::create($decorated$e->getStatusCode(), $e->getHeaders());
    }

    
/**
     * Convert an authentication exception into an unauthenticated response.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  IlluminateAuthAuthenticationException  $e
     * @return SymfonyComponentHttpFoundationResponse
     */
    
protected function unauthenticated($requestAuthenticationException $e)
    {
        if (
$request->ajax() || $request->wantsJson()) {
            return 
response('Unauthorized.'401);
        } else {
            return 
redirect()->guest('login');
        }
    }

    
/**
     * Get the html response content.
     *
     * @param  string  $content
     * @param  string  $css
     * @return string
     */
    
protected function decorate($content$css)
    {
        return <<<EOF
<!DOCTYPE html>
<html>
    <head>
        <meta name="robots" content="noindex,nofollow" />
        <style>
            /* Copyright (c) 2010, Yahoo! Inc. All rights reserved. Code licensed under the BSD License: http://developer.yahoo.com/yui/license.html */
            html{color:#000;background:#FFF;}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0;}table{border-collapse:collapse;border-spacing:0;}fieldset,img{border:0;}address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}li{list-style:none;}caption,th{text-align:left;}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}q:before,q:after{content:'';}abbr,acronym{border:0;font-variant:normal;}sup{vertical-align:text-top;}sub{vertical-align:text-bottom;}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}input,textarea,select{*font-size:100%;}legend{color:#000;}
            html { background: #eee; padding: 10px }
            img { border: 0; }
            #sf-resetcontent { width:970px; margin:0 auto; }
            
$css
        </style>
    </head>
    <body>
        
$content
    </body>
</html>
EOF;
    }

    
/**
     * Determine if the given exception is an HTTP exception.
     *
     * @param  Exception  $e
     * @return bool
     */
    
protected function isHttpException(Exception $e)
    {
        return 
$e instanceof HttpException;
    }
}
Онлайн: 1
Реклама