placetopay / guzzle-logger
Requires
- php: ^8.2
- ext-json: *
- guzzlehttp/guzzle: ^7.7
- psr/log: ^3.0
Requires (Dev)
- eduarguz/shift-php-cs: ^3.0
- fig/log-test: ^1.1
- friendsofphp/php-cs-fixer: ^3.6
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^9.5
- rector/rector: ^0.17.0
- squizlabs/php_codesniffer: 3.*
- symfony/var-dumper: ^4.2
This package is auto-updated.
Last update: 2024-10-26 18:38:56 UTC
README
This is a middleware for guzzle that will help you automatically log every request and response using a PSR-3 logger.
The middleware is functional with version 7 of Guzzle.
Usage
Simple usage
From now on each request and response you execute using $client
object will be logged.
By default, the middleware logs every activity with level INFO
.
use PlacetoPay\GuzzleLogger\Middleware\HttpLogMiddleware; use GuzzleHttp\HandlerStack; $logger = new Logger(); //A new PSR-3 Logger like Monolog $stack = HandlerStack::create(); // will create a stack with middlewares of guzzle already pushed inside of it. $stack->push(new HttpLogMiddleware($logger)); $client = new GuzzleHttp\Client([ 'handler' => $stack, ]);
With Sanitizer
With the LoggerWithSanitizer class you can obfuscate or sanitize sensitive data when logging.
fieldsToSanitize is a key-value array, with which you can determine the level of data to sanitize and the value with which to obfuscate the value.
If you do not send a value and the value is found it will be sanitized with a default value ValueSanitizer::DEFAULT
.
use PlacetoPay\GuzzleLogger\Middleware\HttpLogMiddleware; use PlacetoPay\GuzzleLogger\LoggerWithSanitizer; use PlacetoPay\GuzzleLogger\ValueSanitizer; use GuzzleHttp\HandlerStack; use GuzzleLogger\ValueSanitizer; $fieldsToSanitize = [ 'request.body.instrument.card.cvv', 'request.body.instrument.card.number' => ValueSanitizer::CARD_NUMBER->value, 'request.body.instrument.card.expiration' => ValueSanitizer::DEFAULT->value, 'response.body.instrument.card.number' => fn ($value) => preg_replace('/(\d{6})(\d{3,9})(\d{4})/', '$1ยทยทยทยท$3', (string) $value) ]; $stack = HandlerStack::create(); $logger = new LoggerWithSanitizer(new Logger(), $fieldsToSanitize) $stack->push(new HttpLogMiddleware($logger)); $client = new GuzzleHttp\Client([ 'handler' => $stack, ]);
Using options on each request
You can set on each request options about your log.
$client->get('/', [ 'log' => [ 'statistics' => true, ] ]);
Change log
Please see CHANGELOG for more information what has changed recently.
Testing
$ composer test
License
The MIT License (MIT). Please see License File for more information.