winglet / client
Generic HTTP client infrastructure for Winglet and compatible microservices.
v0.4
2026-04-02 08:43 UTC
Requires
- php: ^8.2
- psr/http-client: ^1.0
- psr/http-factory: ^1.0
- psr/http-message: ^2.0
- psr/log: ^3.0
Requires (Dev)
- phpstan/phpstan: ^1.12
- phpunit/phpunit: ^11.0
Suggests
- guzzlehttp/guzzle: PSR-18 HTTP client implementation
- http-interop/http-factory-guzzle: PSR-17 factories for Guzzle (alternatively nyholm/psr7)
README
winglet/client is the generic HTTP client infrastructure package for Winglet and compatible PHP microservice environments.
This package contains only the reusable technical client layer:
- target configuration loading
- authentication modes
- token caching
- retry and correlation-id middleware
- PSR-7 / PSR-17 / PSR-18 compatible HTTP handling
- optional Winglet bridge for reading config and inbound bearer tokens from a Winglet runtime
This package does not contain service-specific clients such as AuthClient or IdentityClient.
Those should live in their own packages and depend on winglet/client.
Included namespaces
Winglet\Client\Core\...Winglet\Client\Bridge\Winglet\...
Typical usage
Generic client outside Winglet
use Winglet\Client\Core\Config\ArrayTargetConfigRepository;
use Winglet\Client\Core\Factory\ClientFactory;
$repo = new ArrayTargetConfigRepository([
'billing' => [
'base_url' => 'https://billing.example.test',
'auth' => [
'mode' => 'static_bearer',
'static_bearer' => 'example-token',
],
],
]);
$factory = new ClientFactory($repo, __DIR__ . '/var/cache/clients');
$billing = $factory->create('billing');
$response = $billing->getJson('/status');
Generic client inside Winglet
use Winglet\Client\Bridge\Winglet\WingletClientFactory;
$factory = new WingletClientFactory($appContext);
$authClient = $factory->client('auth');
$result = $authClient->getJson('/authorization/effective?identityId=123');
Authentication modes
Supported auth.mode values:
nonestatic_bearerservice_tokenidentity_sessionapi_keymtls
Service-specific clients
Service-specific clients should be implemented in separate packages, for example:
winglet/auth-clientwinglet/identity-clientwinglet/subscription-client
A sample skeleton is included under examples/skeleton-client.
Development
composer install
composer run-script test