escode/larax

There is no license information available for the latest version (v1.0) of this package.

laravel exceptions logs package

v1.0 2021-01-04 21:49 UTC

This package is auto-updated.

Last update: 2025-01-07 02:51:55 UTC


README

Larax is laravel package help us to log exceptions happened in our laravel applications and notify us with all the data we need to find out the cause of the problem when exception happened such as (the data did user sent it in body, headers ,user ip , user id and his guard) .

Latest Version on Packagist Total Downloads

Installation

Add this package in composer.json.

    {
        "require": {
            "escode/larax": "1.*"
        }
    }

or run in terminal: composer require escode/larax

Add Larax Service Provider

open "/config/app.php" and append Escode\Larax\LaraxServiceProvider::class to providers array

Example

 'providers' => [
    Escode\Larax\LaraxServiceProvider::class,

Publish config file

php artisan vendor:publish --tag=larax-config

Migrate database tables

php artisan migrate

Make Larax Handle Exception

going to "/app/Exceptions/Handler.php" and make it extends from Escode\Larax\ExceptionHandler

Example

use Escode\Larax\ExceptionHandler;
class Handler extends ExceptionHandler
{

configration

open "/config/larax.php" this file help you to easily configure and control Larax.

You can set your middleware that’s allow to access exceptions pages on website.

You can set your middleware that’s allow to access exceptions pages over api.

You can control data will be saved when exception happened.

You can told Larax to detect user and save his id and his guard with exception data.

You can ignore some keys “remove it from headers data” from request headers such as “Authorization”.

You can ignore some fields “remove it from body data” from request body or query string such as “password , image , token”.

You can told larax to notify you by send email when exception happened or not.

return [
     //set your middleware that's allow to access exceptions pages on website
    'middleware'=>'auth',
    
    //api middleware
    'ApiMiddleware'=>'AuthLaraxApi',
    
    //exceptions data you want to store it
    'exception_data'=>[
        'ip'=>true,
        'url'=>true,
        'headers'=>true,
        'body'=>true,
    ],
    
    // Note: if you enable detect user in exception larax will push StartSession::class and EncryptCookies::class in $middleware Kernel.php
    // and you should be comment StartSession::class  from $middlewareGroups => web
   
    'detect_user'=>false,
    //array of guards names will use it for detect user id
    'guards'=>['auth'],
    
    //ignore fields in request headers (this fields not saved in db)
    'ignore_headers'=>[
        'Authorization','cookie'
    ],
    
    //ignore fields in request (this fields not saved in db)
    'ignore_inputs'=>[
        'image','password','password_confirmation'
    ],
    
    //send email when exception happened
    //enable send emails
    'enable_email'=>true,

    //email list you want send notify them with exception data
    'emails'=>[
       //example
        //'es.code@yahoo.com',
    ],

]

How to use

open "http://localhost:8000/larax/exceptions" to see the exceptions did happened in your application.

Larax

Larax exception info

Users

users in larax is used to allow users to read exceptions using Larax Api.

Api

you can read your application exceptions data over Api just do "GET" request to "http://localhost:8000/api/larax/exceptions" using user key as bearer token