定制 oat-sa/lib-correlation-ids 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

oat-sa/lib-correlation-ids

最新稳定版本:v0.4.0

Composer 安装命令:

composer require oat-sa/lib-correlation-ids

包简介

OAT Correlation Ids Library

README 文档

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.

统计信息

  • 总下载量: 8.75k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 2
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 43
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: GPL-2.0-only
  • 更新时间: 2019-11-22