mirror of
https://github.com/bitinflow/expose.git
synced 2026-03-13 13:35:54 +00:00
85 lines
2.1 KiB
PHP
85 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace App\Logger;
|
|
|
|
use Clue\React\Buzz\Browser;
|
|
use GuzzleHttp\RequestOptions;
|
|
use Laminas\Http\Request;
|
|
use Laminas\Http\Response;
|
|
use function GuzzleHttp\Psr7\stream_for;
|
|
|
|
class RequestLogger
|
|
{
|
|
/** @var array */
|
|
protected $requests = [];
|
|
|
|
/** @var array */
|
|
protected $responses = [];
|
|
|
|
/** @var CliRequestLogger */
|
|
protected $cliRequestLogger;
|
|
|
|
public function __construct(Browser $browser, CliRequestLogger $cliRequestLogger)
|
|
{
|
|
$this->client = $browser;
|
|
$this->cliRequestLogger = $cliRequestLogger;
|
|
}
|
|
|
|
public function findLoggedRequest(string $id): ?LoggedRequest
|
|
{
|
|
return collect($this->requests)->first(function (LoggedRequest $loggedRequest) use ($id) {
|
|
return $loggedRequest->id() === $id;
|
|
});
|
|
}
|
|
|
|
public function logRequest(string $rawRequest, Request $request)
|
|
{
|
|
$loggedRequest = new LoggedRequest($rawRequest, $request);
|
|
|
|
array_unshift($this->requests, $loggedRequest);
|
|
|
|
$this->requests = array_slice($this->requests, 0, 10);
|
|
|
|
$this->cliRequestLogger->logRequest($loggedRequest);
|
|
|
|
$this->pushLogs();
|
|
}
|
|
|
|
public function logResponse(Request $request, string $rawResponse)
|
|
{
|
|
$loggedRequest = collect($this->requests)->first(function (LoggedRequest $loggedRequest) use ($request) {
|
|
return $loggedRequest->getRequest() === $request;
|
|
});
|
|
if ($loggedRequest) {
|
|
$loggedRequest->setResponse($rawResponse, Response::fromString($rawResponse));
|
|
|
|
$this->cliRequestLogger->logRequest($loggedRequest);
|
|
|
|
$this->pushLogs();
|
|
}
|
|
}
|
|
|
|
public function getData()
|
|
{
|
|
return $this->requests;
|
|
}
|
|
|
|
public function clear()
|
|
{
|
|
$this->requests = [];
|
|
|
|
$this->pushLogs();
|
|
}
|
|
|
|
public function pushLogs()
|
|
{
|
|
$this
|
|
->client
|
|
->post(
|
|
'http://127.0.0.1:4040/logs',
|
|
['Content-Type' => 'application/json'],
|
|
json_encode($this->getData(), JSON_INVALID_UTF8_IGNORE)
|
|
);
|
|
}
|
|
}
|