narrowspark / http-message-util
This repository holds utility classes and constants to facilitate common operations of PSR-7.
Fund package maintenance!
prisis
Installs: 23 205
Dependents: 4
Suggesters: 0
Security: 0
Stars: 4
Watchers: 2
Forks: 1
Open Issues: 5
Requires
- php: ^7.1
- ext-mbstring: *
- psr/http-message: ^1.0
Requires (Dev)
- guzzlehttp/psr7: 1.4
- narrowspark/php-cs-fixer-config: ^2.0
- phpstan/phpstan: ^0.9
- phpstan/phpstan-phpunit: ^0.9
- phpstan/phpstan-strict-rules: ^0.9.0
- phpunit/phpunit: ^6.0
Provides
This package is auto-updated.
Last update: 2023-03-26 10:07:45 UTC
README
This repository holds utility classes and constants to facilitate common operations of PSR-7.
Each header class is named after the specific http header and has the following functions for parsing and signing.
Installation
$ composer require narrowspark/http-message-util
Use
Here's an example using the InteractsWithAcceptLanguage class:
<?php declare(strict_types=1); use Narrowspark\Http\Message\Util\InteractsWithAcceptLanguage; $request = new Request(); $request = $request->withHeader('Accept-Language', 'zh, en-us; q=0.8, en; q=0.6'); return InteractsWithAcceptLanguage::getLanguages($request); // => ['zh', 'en', 'en_US']
Here's an example using the InteractsWithAuthorization class:
<?php declare(strict_types=1); use Narrowspark\Http\Message\Util\InteractsWithAuthorization; $request = new Request(); $request = $request->withHeader('Authorization', 'Basic QWxhZGRpbjpPcGVuU2VzYW1l'); return InteractsWithAuthorization::getAuthorization($request); // => ['Basic', 'QWxhZGRpbjpPcGVuU2VzYW1l']
Here's an example using the InteractsWithContentTypes class:
<?php declare(strict_types=1); use Narrowspark\Http\Message\Util\InteractsWithContentTypes; $request = new Request(); $request = $request->withHeader('Content-Type', 'application/json, */*'); return InteractsWithContentTypes::isJson($request); // => true $request = $request->withHeader('X-Pjax', 'true'); return InteractsWithContentTypes::isPjax($request); // => true $request = $request->withHeader('X-Requested-With', 'XMLHttpRequest'); return InteractsWithContentTypes::isAjax($request); // => true
Here's an example using the HeaderUtils class:
<?php declare(strict_types=1); use Narrowspark\Http\Message\Util\HeaderUtils; return HeaderUtils::split("da, en-gb;q=0.8", ",;"); // => array(array('da'), array('en-gb', 'q=0.8')) or return HeaderUtils::combine(array(array("foo", "abc"), array("bar"))); // => array("foo" => "abc", "bar" => true) or return HeaderUtils::toString(array("foo" => "abc", "bar" => true, "baz" => "a b c"), ","); // => 'foo=abc, bar, baz="a b c"' or return HeaderUtils::quote('foo bar'); // => "foo bar" or return HeaderUtils::unquote('"foo bar"'); // => foo bar
Here's an example using the InteractsWithDisposition class:
<?php declare(strict_types=1); use Narrowspark\Http\Message\Util\InteractsWithDisposition; $response = InteractsWithDisposition::appendDispositionHeader(new Response(), InteractsWithDisposition::DISPOSITION_ATTACHMENT, 'foo.html'); return $response->getHeaderLine('Content-Disposition'); // => attachment; filename=foo.html or return InteractsWithDisposition::makeDisposition(InteractsWithDisposition::DISPOSITION_ATTACHMENT, 'foo.html'); // => attachment; filename=foo.html
Testing
$ vendor/bin/phpunit
Contributing
If you would like to help take a look at the list of issues and check our Contributing guild.
Note: Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.
License
The Narrowspark http-emitter is open-sourced software licensed under the MIT license