wucdbm/mongodb-http-logger
最新稳定版本:v0.4.0
Composer 安装命令:
composer require wucdbm/mongodb-http-logger
包简介
A collection of Doctrine ODM Documents and a base Logger class implementation to log your HTTP Request/Response pairs & associated errors in a more convenient way
README 文档
README
composer require doctrine/mongodb-odm-bundle
doctrine_mongodb: connections: default: server: "mongodb://localhost:27017" options: {} default_database: someDB document_managers: default: auto_mapping: true mappings: # ... wucdbm_http_logger: type: annotation dir: "%kernel.project_dir%/vendor/wucdbm/http-logger/src/Document" prefix: Wucdbm\Component\MongoDBHttpLogger\Document\
Create a Document
<?php namespace App\Document; use Doctrine\ODM\MongoDB\Mapping\Annotations as ODM; use Wucdbm\Component\MongoDBHttpLogger\Document\Log; /** * @ODM\Document(collection="some_collection") */ class SomeLog extends Log { // Feel free to add any custom fields }
Create a logger
<?php namespace App\Logger; use App\Document\SomeLog; use Doctrine\Bundle\MongoDBBundle\ManagerRegistry; use Wucdbm\Component\MongoDBHttpLogger\Logger\Logger; class SomeLogger extends Logger { public function __construct(ManagerRegistry $registry) { parent::__construct($registry, SomeLog::class); } }
Example
<?php /** @var \Wucdbm\Component\MongoDBHttpLogger\Logger\Logger $logger */ $logger = $this->container->get(SomeLogger::class); $log = new \Wucdbm\Component\MongoDBHttpLogger\Document\Log(); $log->setExtraData('whatever'); try { $client = new \GuzzleHttp\Client(); $request = new \GuzzleHttp\Psr7\Request('GET', 'http://some-website.com/'); $logger->logRequest($log, $request, \Wucdbm\Component\MongoDBHttpLogger\Document\HttpMessage::ID_TEXT_PLAIN); // Logs are not saved automatically. You can override logRequest, response and Exception methods and implement it yourself. $logger->save($log); $response = $client->send($request); $logger->logResponse($log, $response, \Wucdbm\Component\MongoDBHttpLogger\Document\HttpMessage::ID_HTML); $logger->save($log); $ex = new \Exception('First Exception'); throw new \Exception('Second Exception', 0, $ex); } catch (\Throwable $e) { $logger->logException($log, $e); $logger->save($log); }
Guzzle Middleware
class MiddlewareFactory { /** @var \ArrayIterator|\Wucdbm\Component\MongoDBHttpLogger\Document\Log[] */ private $logCollection; /** @var \Wucdbm\Component\MongoDBHttpLogger\Logger\Logger */ private $logger; public function createSearchLogger() { return function (callable $handler) { return function ( \Psr\Http\Message\RequestInterface $request, array $options ) use ($handler) { $log = new \Wucdbm\Component\MongoDBHttpLogger\Document\Log(); // Those may be your extra fields // $log->setMethod($options['method']); // $log->setSomeFieldId($this->someUnrelatedEntity->getId()); $this->logCollection->append($log); $this->logger->logRequest( $log, $request, $options['requestMessageType'] ?? \Wucdbm\Component\MongoDBHttpLogger\Document\HttpMessage::ID_TEXT_PLAIN ); /** @var \GuzzleHttp\Promise\PromiseInterface $promise */ $promise = $handler($request, $options); return $promise->then( function (\Psr\Http\Message\ResponseInterface $response) use ($log, $options) { $this->logger->logResponse( $log, $response, $options['responseMessageType'] ?? \Wucdbm\Component\MongoDBHttpLogger\Document\HttpMessage::ID_TEXT_PLAIN ); return $response; } )->otherwise(function ($e) use ($log, $options) { if ($e instanceof \GuzzleHttp\Exception\RequestException) { $response = $e->getResponse(); if ($response) { $this->logger->logResponse( $log, $response, $options['responseMessageType'] ?? \Wucdbm\Component\MongoDBHttpLogger\Document\HttpMessage::ID_TEXT_PLAIN ); } } $this->logger->logException($log, $e); throw $e; }); }; }; } }
统计信息
- 总下载量: 1.82k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-01-16