TransactionMiddleware::process()   A
last analyzed

Complexity

Conditions 1
Paths 3

Size

Total Lines 22

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 13
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 22
c 0
b 0
f 0
ccs 13
cts 13
cp 1
rs 9.568
cc 1
nc 3
nop 2
crap 1
1
<?php
2
declare(strict_types=1);
3
4
namespace TechDeCo\ElasticApmAgent\Convenience\Middleware;
5
6
use Psr\Http\Message\ResponseInterface;
7
use Psr\Http\Message\ServerRequestInterface;
8
use Psr\Http\Server\RequestHandlerInterface;
9
use Ramsey\Uuid\Exception\InvalidUuidStringException;
10
use Ramsey\Uuid\Uuid;
11
use Ramsey\Uuid\UuidInterface;
12
use TechDeCo\ElasticApmAgent\Convenience\HttplugHttpClient\HttpClientWrapper;
13
use TechDeCo\ElasticApmAgent\Convenience\OpenTransaction;
14
use TechDeCo\ElasticApmAgent\Exception\ClientException;
15
use TechDeCo\ElasticApmAgent\Message\Timestamp;
16
use TechDeCo\ElasticApmAgent\Request\Transaction;
17
use function sprintf;
18
19
final class TransactionMiddleware extends Middleware
20
{
21
    public const TRANSACTION_ATTRIBUTE = 'apm-transaction';
22
23
    /**
24
     * @throws ClientException
25
     */
26 14
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
27
    {
28 14
        $openTransaction = new OpenTransaction(
29 14
            Uuid::uuid4(),
30 14
            sprintf('%s %s', $request->getMethod(), $request->getUri()->__toString()),
31 14
            new Timestamp(),
32 14
            'request',
33 14
            $this->getCorrelationId($request)
34
        );
35
36
        try {
37 14
            $request = $request->withAttribute(self::TRANSACTION_ATTRIBUTE, $openTransaction);
0 ignored issues
show
Coding Style introduced by
Consider using a different name than the parameter $request. This often makes code more readable.
Loading history...
38
39 14
            return $handler->handle($request);
40
        } finally {
41 14
            $transaction = (new Transaction($this->service, $openTransaction->toTransaction()))
42 14
                ->onSystem($this->system)
43 14
                ->inProcess($this->process);
44
45 14
            $this->client->sendTransaction($transaction);
46
        }
47
    }
48
49 14
    private function getCorrelationId(ServerRequestInterface $request): UuidInterface
50
    {
51
        try {
52 14
            return Uuid::fromString($request->getHeaderLine(HttpClientWrapper::CORRELATION_ID_HEADER));
53 13
        } catch (InvalidUuidStringException $e) {
54 13
            return Uuid::uuid4();
55
        }
56
    }
57
}
58