loophp / psr-http-message-bridge-bundle
Register symfony/psr-http-message-bridge classes in your Symfony application.
Fund package maintenance!
drupol
Installs: 80 820
Dependents: 3
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 1
Open Issues: 7
Type:symfony-bundle
pkg:composer/loophp/psr-http-message-bridge-bundle
Requires
- php: >= 8.1
- symfony/psr-http-message-bridge: ^6.4 || ^7
Requires (Dev)
- ext-pcov: *
- drupol/php-conventions: ^6
- friends-of-phpspec/phpspec-code-coverage: ^6
- phpspec/phpspec: ^7
- symfony/framework-bundle: ^6.4 || ^7
- symfony/http-kernel: ^6.4 || ^7
This package is auto-updated.
Last update: 2025-10-26 14:17:02 UTC
README
PSR HTTP Message Bridge Bundle
This bundle will register in your Symfony application's container a couple of services.
Those services are from the symfony/psr-http-message-brige bridge package.
It provides:
-
An argument value resolver to be able to get the following objects through:
Psr\Http\Message\MessageInterfacePsr\Http\Message\RequestInterfacePsr\Http\Message\ServerRequestInterface
Those are directly derived from the current Symfony Request object.
It means that you can directly get a PSR7 Request in Symfony controllers through method parameters.
-
An event listener that let users return PSR7 Responses in Symfony controllers. Basically, this event will check if the return value of a Response is an instance of
Psr\Http\Message\ResponseInterfaceand only if it's the case, will convert it into a Symfony response. -
Factories:
- A
HttpFoundactionFactoryservice to convert PSR requests into Symfony requests. - A
PsrHttpFactoryservice to convert Symfony requests into PSR requests.
- A
Requirements
- PHP >= 7.3
- Symfony >= 4
Installation
composer require loophp/psr-http-message-bridge-bundle
Once the bundle installed in your application, it's ready to use, there is no configuration to set up.
Usage
<?php declare(strict_types=1); namespace App\Controller; use Psr\Http\Message\RequestInterface; use Psr\Http\Message\ResponseInterface; final class HelloWorldController { private ResponseFactoryInterface $responseFactory; private StreamFactoryInterface $streamFactory; public function __construct(ResponseFactoryInterface $responseFactory, StreamFactoryInterface $streamFactory) { $this->responseFactory = $responseFactory; $this->streamFactory = $streamFactory; } /** * @Route("/hello-world", name="hello_world") */ public function __invoke(RequestInterface $psrRequest): ResponseInterface { // You can do something with $psrRequest if needed. // Build the PSR response. $response = $this->responseFactory->createResponse(); // Return the new PSR response. return $response->withBody($this->streamFactory->createStream('Hello world!')); } }
Code quality, tests and benchmarks
Every time changes are introduced into the library, Github run the tests and the benchmarks.
The library has tests written with PHPSpec.
Feel free to check them out in the spec directory. Run composer phpspec to trigger the tests.
Before each commit some inspections are executed with GrumPHP, run ./vendor/bin/grumphp run to check manually.
PHPInfection is used to ensure that your code is properly tested, run composer infection to test your code.
Contributing
Feel free to contribute by sending Github pull requests. I'm quite responsive :-)
Changelog
See CHANGELOG.md for a changelog based on git commits.
For more detailed changelogs, please check the release changelogs.