placetopay/guzzle-logger
最新稳定版本:2.0.5
Composer 安装命令:
composer require placetopay/guzzle-logger
包简介
README 文档
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.
| name | Type value | description |
|---|---|---|
statistics |
boolean | option is true the middleware will log statistics about the HTTP call. |
$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.
统计信息
- 总下载量: 2.72k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 4
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-06-29