Passed
Pull Request — master (#19)
by Frank
07:26
created

TransactionMiddleware::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 11

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 4
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 11
c 0
b 0
f 0
ccs 4
cts 4
cp 1
rs 9.9
cc 1
nc 1
nop 5
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\Client;
13
use TechDeCo\ElasticApmAgent\Convenience\HttplugHttpClient\HttpClientWrapper;
14
use TechDeCo\ElasticApmAgent\Convenience\OpenTransaction;
15
use TechDeCo\ElasticApmAgent\Exception\ClientException;
16
use TechDeCo\ElasticApmAgent\Message\Process;
17
use TechDeCo\ElasticApmAgent\Message\Service;
18
use TechDeCo\ElasticApmAgent\Message\System;
19
use TechDeCo\ElasticApmAgent\Message\Timestamp;
20
use TechDeCo\ElasticApmAgent\Request\Transaction;
21
use function sprintf;
22
23
final class TransactionMiddleware extends Middleware
24
{
25
    public const TRANSACTION_ATTRIBUTE = 'apm-transaction';
26
27
    /**
28
     * @var Capturer[]
29
     */
30
    private $capturerList = [];
31
32 15
    public function __construct(
33
        Client $client,
34
        Service $service,
35
        Process $process,
36
        System $system,
37
        Capturer ...$capturerList
38
    ) {
39 15
        parent::__construct($client, $service, $process, $system);
40
41 15
        $this->capturerList = $capturerList;
42 15
    }
43
44
    /**
45
     * @throws ClientException
46
     */
47 15
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
48
    {
49 15
        $openTransaction = new OpenTransaction(
50 15
            Uuid::uuid4(),
51 15
            sprintf('%s %s', $request->getMethod(), $request->getUri()->__toString()),
52 15
            new Timestamp(),
53 15
            'request',
54 15
            $this->getCorrelationId($request)
55
        );
56
57 15
        foreach ($this->capturerList as $capturer) {
58 15
            $capturer->captureFromRequest($openTransaction, $request);
59
        }
60
61
        try {
62 15
            $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...
63 15
            $response = $handler->handle($request);
64
65 14
            foreach ($this->capturerList as $capturer) {
66 14
                $capturer->captureFromResponse($openTransaction, $response);
67
            }
68
69 14
            return $response;
70
        } finally {
71 15
            $transaction = (new Transaction($this->service, $openTransaction->toTransaction()))
72 15
                ->onSystem($this->system)
73 15
                ->inProcess($this->process);
74
75 15
            $this->client->sendTransaction($transaction);
76
        }
77
    }
78
79 15
    private function getCorrelationId(ServerRequestInterface $request): UuidInterface
80
    {
81
        try {
82 15
            return Uuid::fromString($request->getHeaderLine(HttpClientWrapper::CORRELATION_ID_HEADER));
83 14
        } catch (InvalidUuidStringException $e) {
84 14
            return Uuid::uuid4();
85
        }
86
    }
87
}
88