ebln/guzzle-openapi-middleware

A Guzzle middleware validating against openapi schema using league/openapi-psr7-validator

Maintainers

Package info

github.com/ebln/guzzle-openapi-middleware

pkg:composer/ebln/guzzle-openapi-middleware

Statistics

Installs: 16

Dependents: 0

Suggesters: 0

Stars: 2

Open Issues: 0

v1.0.0 2022-08-20 13:33 UTC

This package is not auto-updated.

Last update: 2026-03-02 04:53:24 UTC


README

This middleware only adapts league/openapi-psr7-validator for Guzzle, please see their project for documentation

Installation

composer require ebln/guzzle-openapi-middleware

Usage

use GuzzleHttp\Client;
use GuzzleHttp\HandlerStack;
use League\OpenAPIValidation\PSR7\ValidatorBuilder;

$builder = new ValidatorBuilder();
// call either setSchemaFactory() or one of the from*() methods optionally add a PSR6 cache
// @see https://github.com/thephpleague/openapi-psr7-validator#readme

$middleware = new Middleware($builder->getRequestValidator(), $builder->getResponseValidator());

// @see https://docs.guzzlephp.org/en/stable/handlers-and-middleware.html#middleware
$stack = HandlerStack::create();
$stack->push($middleware, 'openapi_validation');
$client = new Client(['handler' => $stack]);