phpgt / fetch
Asynchronous HTTP client with promises.
Fund package maintenance!
PhpGt
Installs: 15 897
Dependents: 2
Suggesters: 0
Security: 0
Stars: 34
Watchers: 4
Forks: 9
Open Issues: 11
Requires
- php: >=8.1
- ext-curl: *
- ext-json: *
- phpgt/async: ^1.0
- phpgt/curl: ^3.1.1
- phpgt/http: ^1.3
- phpgt/json: ^1.2
- phpgt/promise: ^2.2.3
- phpgt/propfunc: ^1.0
Requires (Dev)
- phpmd/phpmd: ^2.13
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^10.2
- squizlabs/php_codesniffer: ^3.7
This package is auto-updated.
Last update: 2024-10-24 13:30:36 UTC
README
Asynchronous HTTP client, implementation of the Fetch Standard which defines requests, responses, and the process that binds them: fetching.
See also, the JavaScript implementation that ships as standard in all modern browsers.
Example usage: compute multiple HTTP requests in parallel, using fetch
<?php $http = new Gt\Fetch\Http(); // Rather than creating the request now, `fetch` returns a Promise, // for later resolution with the BodyResponse. $http->fetch("http://example.com/api/something.json") ->then(function(BodyResponse $response) { // The first Promise resolves as soon as a response is received, even before // the body's content has completed downloading. if(!$response->ok) { echo "Looks like there was a problem. Status code: " . $response->getStatusCode() . PHP_EOL; return null; } // Within this Promise callback, you have access to the body stream, but // to access the contents of the whole body, return a new Promise here: return $response->json(); }) ->then(function(Json $json) { // The second Promise resolves once the whole body has completed downloading. echo "Got JSON result length " . count($json->results) . PHP_EOL; // Notice that type-safe getters are available on all Json objects: echo "Name of first result: " . $json->results[0]->getString("name") . PHP_EOL; }); // A third request is made here to show a different type of body response: $http->fetch("http://example.com/something.jpg") ->then(function(BodyResponse $response) { return $response->blob(); }) ->then(function($blob) { echo "Got JPG blob. Saving file." . PHP_EOL; file_put_contents("/tmp/something.jpg", $blob); }); // Once all Promises are registered, all HTTP requests can be initiated in // parallel, with the callback function triggered when they are all complete. $http->all()->then(function() { echo "All HTTP calls have completed!" . PHP_EOL; });
For more extensive examples, check out the code in the example directory.