You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
payment/app/Middleware/RequestLogMiddleware.php

53 lines
1.7 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Middleware;
use App\Service\RequestService;
use Hyperf\Context\Context;
use Hyperf\HttpServer\Contract\RequestInterface;
use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
use Hyperf\Contract\ContainerInterface;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\MiddlewareInterface;
use Psr\Http\Server\RequestHandlerInterface;
class RequestLogMiddleware implements MiddlewareInterface
{
protected ContainerInterface $container;
protected RequestInterface $request;
protected HttpResponse $response;
public function __construct(ContainerInterface $container, HttpResponse $response, RequestInterface $request)
{
$this->container = $container;
$this->response = $response;
$this->request = $request;
}
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
$params = $this->request->all();
/**
* @var RequestService $requestService
*/
$requestService = $this->container->make(RequestService::class);
$requestLog = $requestService->createRequestLog($this->request->getRequestUri(), $params);
$ctxResponse = Context::get(ResponseInterface::class);
$ctxResponse = $ctxResponse->withHeader('X-Request-Id', $requestLog->request_id);
Context::set(ResponseInterface::class, $ctxResponse);
Context::set('requestLog', $requestLog);
$response = $handler->handle($request);
$requestLog->response_data = (string)$response->getBody();
$requestLog->response_time = date('Y-m-d H:i:s');
return $response;
}
}