loophp / unaltered-psr-http-message-bridge-bundle
A drop-in replacement for symfony/psr-http-message-bridge, that does not alter query parameters.
Fund package maintenance!
drupol
www.paypal.me/drupol
Installs: 17 490
Dependents: 1
Suggesters: 1
Security: 0
Stars: 5
Watchers: 3
Forks: 1
Open Issues: 1
Type:symfony-bundle
Requires
- php: >= 7.3
- league/uri-components: ^2.4
- loophp/psr-http-message-bridge-bundle: ^1.0
Requires (Dev)
- drupol/php-conventions: ^5
- friends-of-phpspec/phpspec-code-coverage: ^6
- infection/infection: ^0.24
- infection/phpspec-adapter: ^0.1.1
- nyholm/psr7: ^1
- phpspec/phpspec: ^7.1
- symfony/http-kernel: ^5.1.6
README
Unaltered PSR HTTP Message Bridge Bundle
An opt-in and drop-in replacement bundle for symfony/psr-http-message-bridge that doesn't alter the query parameters.
This package register a decorator for the service PsrHttpFactory
in your Symfony application.
The only difference with the original class from symfony/psr-http-message-bridge is that it doesn't alter the query parameters when converting a Symfony request into a PSR7 request.
Context:
- https://3v4l.org/diaBU
- symfony/symfony#29664
- https://externals.io/message/106213
- https://bugs.php.net/bug.php?id=40000
- https://stackoverflow.com/questions/68651/get-php-to-stop-replacing-characters-in-get-or-post-arrays
- https://www.drupal.org/project/drupal/issues/2984272
- https://tracker.moodle.org/browse/MDL-29700
- https://laracasts.com/discuss/channels/laravel/any-way-to-stop-replacing-with
TL;DR
Symfony's Request class
uses parse_str() function to parse the
query string, but parse_str()
alter the parameter key if it contains .
and replaces them with _
.
This issue makes the Request object harder to work with when we some logic needs to heavily rely on query parameters
(API Platform, CAS, ... ).
Requirements
- PHP >= 7.1.3
- Symfony >= 4
Installation
composer require loophp/unaltered-psr-http-message-bridge-bundle
Usage
<?php declare(strict_types=1); namespace App\Controller; use Psr\Http\Message\RequestInterface; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Symfony\Bridge\PsrHttpMessage\HttpMessageFactoryInterface; final class MainController { /** * @Route("/api/offers", name="api_offers") * * @return \Symfony\Component\HttpFoundation\Response */ public function __invoke( Request $request, HttpMessageFactoryInterface $httpMessageFactory, RequestInterface $psrRequest ): Response { // Using Symfony's request object. $uri = $request->getUri(); // http://localhost:8000/api/offers?product_color=red $params = $request->query->all(); // [ 'product_color' => 'red' ] // Using PSR Request. $psrRequest = $httpMessageFactory->createRequest($request); $uri = (string) $psrRequest->getUri(); // http://localhost:8000/api/offers?product.color=red $params = $psrRequest->getUri()->getQuery(); // 'product.color=red' // Or directly by requesting the PSR request through RequestInterface parameter. return new Response(''); } }
Notice that the query string parameters has been altered, from field.filter
to field_filter
when using the
Symfony Request object.
Configuration
There is no configuration and you do not have to do anything besides requiring this package in your application.
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.