The package is based on https://github.com/Nyholm/psr7/. The package is mutable. If you need immutable implementation please to see nyholm/psr7.
A super lightweight PSR-7 implementation. Very strict and very fast.
composer require alexpts/mutable-psr7If you are using Symfony Flex then you get all message factories registered as services.
The PSR-7 objects do not contain any other public methods than those defined in the PSR-7 specification.
Use the PSR-17 factory to create requests, streams, URIs etc.
$psr17Factory = new \PTS\Psr7\Factory\Psr17Factory();
$request = $psr17Factory->createRequest('GET', 'http://some.com');
$stream = $psr17Factory->createStream('foobar');With HTTPlug or any other PSR-18 (HTTP client) you may send requests like:
composer require kriswallsmith/buzz$psr17Factory = new \PTS\Psr7\Factory\Psr17Factory();
$psr18Client = new \Buzz\Client\Curl($psr17Factory);
$request = $psr17Factory->createRequest('GET', 'http://some.com');
$response = $psr18Client->sendRequest($request);The nyholm/psr7-server package can be used
to create server requests from PHP superglobals.
composer require nyholm/psr7-server$psr17Factory = new \PTS\Psr7\Factory\Psr17Factory();
$creator = new \Nyholm\Psr7Server\ServerRequestCreator(
$psr17Factory, // ServerRequestFactory
$psr17Factory, // UriFactory
$psr17Factory, // UploadedFileFactory
$psr17Factory // StreamFactory
);
$serverRequest = $creator->fromGlobals();composer require laminas/laminas-httphandlerrunner$psr17Factory = new \PTS\Psr7\Factory\Psr17Factory();
$responseBody = $psr17Factory->createStream('Hello world');
$response = $psr17Factory->createResponse(200)->withBody($responseBody);
(new \Laminas\HttpHandlerRunner\Emitter\SapiEmitter())->emit($response);composer bench

