kaspi / psr7-wizard
Make PSR-7 ServerRequest from global variables
Installs: 5
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kaspi/psr7-wizard
Requires
- php: ^8.1 || ^8.2 || ^8.3 || ^8.4
- psr/http-factory: ^1.0
- psr/http-message: 1.1 || ^2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.46
- kaspi/http-message: ^1.1
- mikey179/vfsstream: ^1.6
- pestphp/pest: ^2.31
- phan/phan: ^5.4
README
Building ServerRequest class which implement PSR-7 ServerRequestInterface from global PHP variables.
Require PHP 8.1 or newest.
additional links: PSR-7, PSR-17
Installation
composer kaspi/psr7-wizard
Usage
// Example build ServerRequest class with package kaspi/http-message $httpFactory = new \Kaspi\HttpMessage\HttpFactory(); $wizard = new \Kaspi\Psr7Wizard\ServerRequestWizard( serverRequestFactory: $httpFactory, streamFactory: $httpFactory, uploadedFileFactory: $httpFactory, uriFactory: $httpFactory, ); /** @var \Psr\Http\Message\ServerRequestInterface $serverRequest */ $serverRequest = $wizard->fromGlobals(); // ✋🏻 Or create by params 👇🏻 $serverEnv = [ 'REMOTE_ADDR' => '127.0.0.1', 'REMOTE_PORT' => '35096', 'SERVER_SOFTWARE' => 'PHP 8.2.14 Development Server', 'SERVER_PROTOCOL' => 'HTTP/1.1', 'SERVER_NAME' => '127.0.0.1', 'SERVER_PORT' => '8080', 'REQUEST_URI' => '/', 'REQUEST_METHOD' => 'POST', 'SCRIPT_NAME' => '/index.php', 'CONTENT_LENGTH' => '53', 'HTTP_CONTENT_LENGTH' => '53' ]; $queryStringParams = [ 'search' => 'php%', ]; $cookie = [ 'save' => 'no' ]; $uploadedFiles = [ $httpFactory->createUploadedFile('/tmp/file1'); ]; $parsedBody = [ 'form' => [ 'name' => 'Joe', 'contact' => '+555-36-89' ], ]; $body = 'form%5Bname%5D=Joe&form%5Bcontact%5D=%2B555-36-89'; $wizard->fromParams( serverParams: $serverEnv, queryParams: $queryStringParams, cookieParams: $cookie, files: $uploadedFiles, parsedBody: $parsedBody, body: $body );
Development environment
- Local development (without Docker)
- With Docker images (WSL, Linux)
Local development
Required PHP 8.1, php Composer 2.x
Testing
Run test without code coverage
composer test
Running tests with checking code coverage by tests with a report in html format
./vendor/bin/pest
Requires installed PCOV driver
⛑ the results will be in the folder .coverage-html
Static code analysis
For static analysis we use the package Phan.
Running without PHP extension PHP AST
./vendor/bin/phan --allow-polyfill-parser
Code style
To bring the code to standards, we use php-cs-fixer which is declared in composer's dev dependencies.
composer fixer
Using Docker image with PHP 8.1, 8.2, 8.3
You can specify the image with the PHP version in the .env file in the PHP_IMAGE key.
By default, the container is built with the php:8.1-cli-alpine image.
Build docker container
docker-compose build
Install php composer dependencies:
docker-compose run --rm php composer install
Run tests with a code coverage report and a report in html format
docker-compose run --rm php vendor/bin/pest --compact
⛑ the results will be in the folder .coverage-html
Phan (static analyzer for PHP)
docker-compose run --rm php vendor/bin/phan
You can work in a shell into a docker container:
docker-compose run --rm php sh
Using Makefile commands.
Check and correct code style:
make fix
Run the static code analyzer:
make stat
Run tests:
make test
Run all stages of checks:
make all