oat-sa / lib-correlation-ids
OAT Correlation Ids Library
Installs: 6 572
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 45
Forks: 0
Open Issues: 0
Requires
- php: ^7.1.3 || ^8.0
- ramsey/uuid: ^3.8
Requires (Dev)
- phpunit/phpunit: ^8.3
This package is auto-updated.
Last update: 2024-11-17 14:32:57 UTC
README
PHP library for correlation ids management.
Table of contents
Installation
$ composer require oat-sa/lib-correlation-ids
Principles
This library provides an interface that will allow access to 3 kind of correlation ids:
getCurrentCorrelationId()
: for the current application process.getParentCorrelationId()
: for the parent application that calls your application, if any.getRootCorrelationId()
: for the root application from which all the calls originate in the first place.
Example:
Request
|
v
+---------------+ current: xxx
| Application A | parent: NULL
+---+-----------+ root: NULL
|
v
+---------------+ current: yyy
| Application B | parent: xxx
+---+-----------+ root: xxx
|
v
+---------------+ current: zzz
| Application C | parent: yyy
+---------------+ root: xxx
Usage
From HTTP context
<?php declare(strict_types=1); use Psr\Http\Message\RequestInterface; use OAT\Library\CorrelationIds\Builder\CorrelationIdsRegistryBuilder; use OAT\Library\CorrelationIds\Generator\CorrelationIdGenerator; $builder = new CorrelationIdsRegistryBuilder(new CorrelationIdGenerator()); /** @var RequestInterface $request */ $registry = $builder->buildFromRequestHeaders($request->getHeaders()); ... $registry->getCurrentCorrelationId(); // current correlation id $registry->getParentCorrelationId(); // parent correlation id (nullable) $registry->getRootCorrelationId(); // root correlation id (nullable)
Note: you can customize the used HTTP headers names by providing you own CorrelationIdsHeaderNamesProviderInterface implementation and pass it to the CorrelationIdsRegistryBuilder
constructor.
Manually
<?php declare(strict_types=1); use OAT\Library\CorrelationIds\Builder\CorrelationIdsRegistryBuilder; use OAT\Library\CorrelationIds\Generator\CorrelationIdGenerator; $builder = new CorrelationIdsRegistryBuilder(new CorrelationIdGenerator()); $registry = $builder->build( 'parentCorrelationId', // optional 'rootCorrelationId' // optional );
Tests
To run tests:
$ vendor/bin/phpunit
Note: see phpunit.xml.dist for available test suites.