Easily capture every incoming request and the corresponding outgoing response in your Laravel app.
mtownsend/laravel-request-response-logger is a Laravel package for easily capture every incoming request and the corresponding outgoing response in your laravel app..
It currently has 25 GitHub stars and 11.853 downloads on Packagist (latest version 2.0.0).
Install it with composer require mtownsend/laravel-request-response-logger.
Discover more Laravel packages by mtownsend
or browse all Laravel packages to compare alternatives.
Last updated
Easily capture every incoming request and the corresponding outgoing response in your Laravel app.
This package is designed to work only with the Laravel framework.
Install via composer:
composer require mtownsend/laravel-request-response-logger
Please see the release notes here.
For Laravel 5.4 and lower, add the following line to your config/app.php:
/*
* Package Service Providers...
*/
Mtownsend\RequestResponseLogger\Providers\RequestResponseLoggerServiceProvider::class,
For Laravel 5.5 and greater, the package will auto register the provider for you.
You will need to publish the migration and configuration file before you can begin using the package. To do so run the following in your console:
php artisan vendor:publish --provider="Mtownsend\RequestResponseLogger\Providers\RequestResponseLoggerServiceProvider"
Next, you need to run the migration for the new database table. Run the following in your console:
php artisan migrate
In order to begin logging requests and responses you will have to attach the middleware to the routes you want to log. The package does not make this assumption for you, since not everyone may want to log every route.
Now, navigate to your /app/Http/Kernel.php
You can choose which method you would like to use. We've provided a few different options below:
protected $routeMiddleware = [
...
'log.requests.responses' => \Mtownsend\RequestResponseLogger\Middleware\LogRequestsAndResponses::class,
];
Then apply the named middleware to whatever routes you want:
Route::post('/some/route', SomeController::class)->middleware(['log.requests.responses']);
protected $middlewareGroups = [
...
'api' => [
...
\Mtownsend\RequestResponseLogger\Middleware\LogRequestsAndResponses::class,
],
];
protected $middleware = [
...
\Mtownsend\RequestResponseLogger\Middleware\LogRequestsAndResponses::class,
];
That's it! The middleware will log every incoming request it receives!
This package provides a few customizations you can make.
When you navigation to app/config you will see a log-requests-and-responses.php file. It will contain the following:
return [
/**
* The model used to manage the database table for storing request and response logs.
*/
'logging_model' => \Mtownsend\RequestResponseLogger\Models\RequestResponseLog::class,
/**
* When logging requests and responses, should the logging action be
* passed off to the queue (true) or run synchronously (false)?
*/
'logging_should_queue' => false,
/**
* If stored json should be transformed into an array when retrieved from the database.
* Set to `false` to receive as a regular php object.
*/
'get_json_values_as_array' => true,
/**
* The class responsible for determining if a request should be logged.
*
* Out of the box options are:
* Mtownsend\RequestResponseLogger\Support\Logging\LogAll::class,
* Mtownsend\RequestResponseLogger\Support\Logging\LogClientErrorsOnly::class,
* Mtownsend\RequestResponseLogger\Support\Logging\LogSuccessOnly::class,
*/
'should_log_handler' => \Mtownsend\RequestResponseLogger\Support\Logging\LogAll::class,
];
You may want to utilize some housekeeping to prevent your logs table from getting too large. This package supplies a preregistered command for wiping the table clean. You may run it manually
php artisan request-response-logger:clean
You may also schedule it to be run automatically in app/Console/Kernel.php:
protected function schedule(Schedule $schedule)
{
...
$schedule->command('request-response-logger:clean')->quarterly();
}
This package provides support for specifying custom conditions before a request/response is logged to the database.
It comes with 3 default options out of the box:
Creating your own conditional logic is pretty straightforward and can be done in 2 simple steps:
<?php
namespace App\Support\Logging;
use Illuminate\Http\Request;
use Mtownsend\RequestResponseLogger\Support\Logging\Contracts\ShouldLogContract;
class LogExternalRequests implements ShouldLogContract
{
public $request;
public $response;
public function __construct(Request $request, $response)
{
$this->request = $request;
$this->response = $response;
}
/**
* Return a truth-y value to log the request and response.
* Return false-y value to skip logging.
*
* @return bool
*/
public function shouldLog(): bool
{
// Custom logic goes here...
}
}
config/log-requests-and-responses.php and set the should_log_handler key to your class.[
//...
'should_log_handler' => \App\Support\Logging\LogExternalRequests::class,
]
...and that's it! Your custom logging logic will now be used any time the middleware is executed.
If you would like to work with the data you've logged, you may want to retrieve data based on the http code your app returned for that request.
use Mtownsend\RequestResponseLogger\Models\RequestResponseLog;
// Get every logged item with an http response code of 2XX:
RequestResponseLog::successful()->get();
// Get every logged item with an http response code that ISN'T 2XX:
RequestResponseLog::failed()->get();
RequestResponseLog model with your ownYou may want to extend the base RequestResponseLog model with your own. This is entirely possible.
First, create your own model
php artisan make:model RequestResponseLog
Then in your model, extend the base model:
<?php
namespace App\Models;
use Mtownsend\RequestResponseLogger\Models\RequestResponseLog as BaseRequestResponseLog;
class RequestResponseLog extends BaseRequestResponseLog
{
//
}
Then in your app/config/log-requests-and-responses.php:
'logging_model' => \App\Models\RequestResponseLog::class,
Now the package will utilize your model instead of the default one.
You can run the tests with:
vendor/bin/phpunit
The MIT License (MIT). Please see License File for more information.