Skip to content
This repository has been archived by the owner on May 3, 2020. It is now read-only.

Latest commit

 

History

History
358 lines (227 loc) · 12.8 KB

README.md

File metadata and controls

358 lines (227 loc) · 12.8 KB

Latest Stable Version Total Downloads License

GitHub forks GitHub stars GitHub issues

Español

Licencia

El codigo de licencia debe seguirse al pie de la letra, si usted utiliza esta libreria los derechos de autor deben estar incluidos en todas la copias.

Para mas informacion la puede encontra en el archivo LICENSE.txt.

Descripcion

Es un generador de excepciones, su fin es lanzar excepciones controladas al usuario con la posibilidad de generar log detallados al desarollador.

El paquete es capaz de detectar una application/json de una peticion http por defecto.

Este paquete entrega al usuario una vista en caso de ser http normal en donde se vera mensaje del error y un codigo de error, si la peticion es JSON el error sera devuelto en un resonse en formato JSON.

Instalacion

Ejecutar en la consola dentro en la raiz del proyecto el comando:

$ composer require furiosojack/lara-exception

o añadiendo directamente el el archivo composer.json

{
    "require": {
        "furiosojack/lara-exception": "^1.0.0"
    }
}

Si usted tiene una version de Laravel < 5.6 debe hacer lo siguiente ⬇️ ⬇️

Luego en el archivo config/app.php incluir el siguiente service provider

'providers' => [
    FuriosoJack\LaraException\Providers\LaraExceptionServiceProvider::class,
];

y en el mismo archivo mas abajo la siguiente alianza

'aliases' => [
    'LaraException' => FuriosoJack\LaraException\Facades\LaraExceptionFacade::class,
  ],

Si usted tiene una version de Laravel < 5.6 debe hacer lo siguiente ⬆️ ⬆️


En su archivo app/Exceptions/Handler.php es necesario incluir la clase LaraExceptionManager en ese archivo. Se puede hacer de la siguiente forma.

Iportar la clase

use FuriosoJack\LaraException\Exceptions\LaraExceptionManager;

ahora la clase Handler.php en lugar de extender de ExceptionHandler debe extender es de LaraExceptionManager
quedando algo como esto:

        
    namespace App\Exceptions;
    
    use Exception;
    use Illuminate\Auth\AuthenticationException;
    use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
    use FuriosoJack\LaraException\Exceptions\LaraExceptionManager;
    class Handler extends LaraExceptionManager
    {
        
    

Para finalizar debe pulicar la configuracion para ello en su consola debe ejecutar el comando.

 $ php artisan vendor:publish --tag=config.lara_exception

Metodos

EL paquete provee unos parametros para ser la excepcion mas personalizada.

  • message(string) - Obligatorio ‼️ Este metodo recibe string que seria el mensaje que se va a mostrar en la excepcion
    📐 Siempre Visible

  • debugCode(int) - Este metodo recibe un entero correpondiente al codigo de error de la excepcion (Util cuando se parametriza los errores). Si no se especifica el codigo de error por defecto sera 0. 📐 Siempre Visible

  • details(string) - Este metodo recibe un string que corresponse al de talle del error, generalmente creado para dar mas detalles al programador, por defecto no se le puestra al usuario pero si se muestra en el log. 📐 Visible u Oculto

  • withLog() - Este metodo no recibe ningun parametros. Es usado para indicar que se quiere generar un log por dicha excepcion. Los logs quedan almacenados dependiendo de como se tenga configurado en el proyecto, un proyecto donde no se le haya modificado el lugar de los log estos se almacenaran en storage/logs/laravel.log, si se especifican detalles y errores siempre seran mostrado en el log.

  • showDetails() - Este metodo permite que se muestre los detalles a la excepcion que se le muestra al usuario ya sea por HTTP norml o por JSON.

  • showErros() - Muestra los errores en la respuesta si no se especifican errores se mostrara como null

  • errors(array) Recibe un array de los errores que se quieran ajuntas mas al error principal, estos errores solo son mostrados al usuario si se usan en conjunto con showErrors

  • style(string) Recibe un string, permite especificar un estilo visual que corresponde a el key que tiene que estar declarado en config/LaraException. (Leer Seccion)

  • build(int = 200) - Este el utimo metodo que se debe llamar. Obligatorio ‼️ Este es el encargado de que la excepcion se lance, al metodo se le puede especificar el codigo http de respuesta (HTTP STATUS CODE) por defecto si no se le especifica es 200.

Ejemplos

Lanza una excepcion con el mensaje indicado

\LaraException::message("hola mundo")->build();

Lanza una excepcion con un codigo de debugueo personalizado

\LaraException::message("hola mundo")->debugCode(15)->build();

Lanza un excepcion con detalles y con debug code perzonalizado

 \LaraException::message("hola mundo")
 ->debugCode(15)
 ->details("Ya dije hola mundo?")
 ->build();

Lanza un excepcion con detalles y con debug code perzonalizado y un log

 \LaraException::message("hola mundo")
 ->debugCode(15)
 ->details("Ya dije hola mundo?")
 ->withLog()
 ->build();

Lanza un excepcion con detalles y con debug code perzonalizado y un log y muestra los detalles al usuario

 \LaraException::message("hola mundo")
 ->debugCode(15)
 ->details("Ya dije hola mundo?")
 ->withLog()
 ->showDetails()
 ->showErrors()
 ->build();

En el siguiente ejemplo corresonde a la forma de enviar los errores en un array, solo funciona cuando la peticion tiene el header Accept: applitacion/json

 \LaraException::message("hola mundo")
 ->debugCode(15)
 ->details("Ya dije hola mundo?")
 ->withLog()
 ->errors([
   "juan" => "nombre invalido",
   "petro" => "nombre no existe"
 ])
 ->showDetails()
 ->build();

Se puede hace varias combinaciones de los metodos ya que estan encadenados pero obiamente teniendoen cuenta que el metodo build() siempre sea el ultimo.

Tambien puede usar el helper en lugar de usar la fachada como se mosotro anteriormente, para usar el helper puede usar los mismos metodos ya mostrados, por ejemplo para relizar

El primer parametro que recibira esta funcion sera el mensaje

 lara_exception("hola mundo")
 ->debugCode(15)
 ->details("Ya dije hola mundo?")
 ->withLog()
 ->errors([
   "juan" => "nombre invalido",
   "petro" => "nombre no existe"
 ])
 ->showDetails()
 ->build();

Salidas

En el caso de que la peticion sea JSON la respuesta se veria algo como:

{
    "error": "hola mundo",
    "errors": {
        "juan": "nombre invalido",
        "petro": "nombre no existe"
    },
    "debugCode": 15,
    "details": "Ya dije hola mundo?",
    "success": false
}

Si es una peticion es http normal se le mostrara una vista

ver

Ejemplo de logs

ver

Excepciones Personalizadas

Estilo Visual(view)

Solo es valido para excepciones que ocurran desde el navegador o que no sea una peticion JSON !!!!

Si usted necesita que su proyecto o paquete pueda tener un estilo unico de excepciones tanto de vista o tenga unas caracteristicas especiales.

Es decir si por ejemplo usted esta programando un paquete para laravel y probablemente su paquete lo utilicen otras personas que tambien podrian estar utilizando LaraException y quiere que su paquete tenga un estilo visual(view) unico de excepciones. O si esta programando un proyecto en Laravel y necesita un estilo visual(view) diferente al por defecto.

Para hacer eso posible es necesario que en la configuracion que tiene que estar en el proyecto en config/LaraException.php debe crear un estilo con el siguiente formato:

  'blog' => [
      'view' => 'blog.user.exceptions',
      'redirect' => true
  ]

Tenemos a blog como key queriendo decir que este estilo se llama blog, ahora dentro de este array existen dos claves la view que represanta la vista que se mostrara cuando ocurra una excepcion.

La clave redirect representa si quiere que cuando ocurra una excepcion se redireccione a la url de LaraException (/LaraException?errors=dsfdsfsdfsd).

📝 PD:

Yo recomiendo dejarlo en true ya que esto permite que cuando un usuario haga una solicitud de tipo POST y se lance una exception esta se redireccion para que el usuario no pueda dar F5 o recargar la pagina y evitar nuevamente un error.

Como ya usted tiene un estilo definido puede usar el LaraException de la siguiente manera

lara_exception("mensaje")
->style('blog')
->details('detalles de la excepcion')
->build(500);

De esa forma cuando ocurra la excepcion la vista que se mostrara al usuario sera la que usted especifico en la configuracion.

Nueva vista

Si quire crear una nueva vista es por que tiene un nuevo estilo de excepcion, pero si lo que quiere es no especificar cada vez que lanza un LaraExcepcion el estilo pero con una vista diferente a la por defecto le recomendamos que lea la siguiente seccion.

Para crear una vista compatible con LaraExeption la vista tiene que ser blade. Las variables a las que tendra acceso en su vista seran las siguientes:

  • $message
  • $errors
  • $debugCode
  • $details
  • $routeBack : Es la url de la ruta anterior

Editar Default

Para editar la vista por defecto es necesario publicala en su proyecto para ello ejecute en su consola lo siguiente

 $ php artisan vendor:publish --tag=views.lara_exception

de esa forma ahora tendra esta carpeta resources\views\vendor\LaraException, donde estara la vista llamada error.blade.php la cual es la que usted personalizara.

Captuara de otras excepciones y reglas 🙀

Suele suceder que se su proyecto tenga otro tipo de excepciones que no son precisamente lanzadas por LaraException.

Por ejemplo al entrar a una ruta que no existe se lanzara la excepcion NotFoundHttpException la cual por defecto Laravel mostrara una vista con el error "Sorry, the page you are looking for could not be found.".

Si usted lo desea puede hacer que LaraExcepcion tambien se encargue de este tipo de excepciones y retorne una vista que usted quiera o que simplemente ahora se lanzes una excepcion de LaraExcepcion, usted debe hacer lo siguiente:

Para el ejemplo se quiere que cuando se lance una excepcion de NotFoundHttpException y que ademas si en la url tiene el texto blog se ejecute es por una excepcion de LaraExcepcion.

Entonces para ello es necesario añadir en un servis provider; en el caso de estar trabajando en un proyecto se deberia registrar en el metodo register de App\Providers\AppServiceProvider si esta trabajando es en un paquete de laravel añadlo en el metodo register de su service provider.

        lara_exception_masterManager()->addExceptionCallBack(function($request, \Exception $exception){
            if(strpos($request->getPathInfo(),"/blog") !== FALSE){
                if($exception instanceof NotFoundHttpException){
                    lara_exception("Not Fount")->style('blog')->build(404);
                }
            }
        });

Con la ayuda del metodo addExceptionCallBack del MasterManager de LaraException usted puede indicar una funcion que contendra un logica que usted necesite pero que para el ejemplo es ejecutar una excepcion de LaraException cuando se lanaza una NotFoundHttpException y que ademas tenga en su url el texto blog

El la funcion que se añade recibe dos parametros, el $request que es el objeto de la solicitud y el parametro $exception que es la excepcion que se lanzo.

Siguiendo con el ejemplo verifico si en e la url esta la palabra blog url que se obtiene por medio del metodo getPathInfo que tiene el $request, al ser verdadero lo que hago es lanzar una excepcion de LaraExcepcion con su helper y adicionalmente indicando el estilo que quiero y finalizando con el codigo de error que quiero que entregue. :scream_cat: :scream_cat: :scream_cat: :scream_cat:

Sin embargo esto solo es una de las miles de cosas que se podrian hacer con un poco de imaginacion. 😏 😏 😏 💪

FIN