A major feature release adding a new options APIs and more consistent APIs for sending streaming requests. Includes a major documentation overhaul and deprecates a number of APIs.
-
Feature: Add new
request()
andrequestStreaming()
methods and deprecatesend()
method andstreaming
option. (#170 by @clue)// old: deprecated $browser->withOptions(['streaming' => true])->get($url); $browser->send(new Request('OPTIONS', $url)); // new $browser->requestStreaming('GET', $url); $browser->request('OPTIONS', $url);
-
Feature: Add dedicated methods to control options, deprecate
withOptions()
. (#172 by @clue)// old: deprecated $browser->withOptions(['timeout' => 10]); $browser->withOptions(['followRedirects' => false]); $browser->withOptions(['obeySuccessCode' => false]); // new $browser->withTimeout(10); $browser->withFollowRedirects(false); $browser->withRejectErrorResponse(false);
-
Feature: Add
withResponseBuffer()
method to limit maximum response buffer size (defaults to 16 MiB). (#175 by @clue)// new: download maximum of 100 MB $browser->withResponseBuffer(100 * 1000000)->get($url);
-
Feature: Improve
withBase()
method and deprecatewithoutBase()
method (#173 by @clue)// old: deprecated $browser = $browser->withoutBase(); // new $browser = $browser->withBase(null);
-
Deprecate
submit()
method, usepost()
instead. (#171 by @clue)// old: deprecated $browser->submit($url, $data); // new $browser->post($url, ['Content-Type' => 'application/x-www-form-urlencoded'], http_build_query($data));
-
Deprecate
UriInterface
for request methods, use URL strings instead (#174 by @clue) -
Fix: Fix unneeded timeout timer when request body closes and sender already rejected. (#169 by @clue)
-
Improve documentation structure, add documentation for all API methods and handling concurrency. (#167 and #176 by @clue)
-
Improve test suite to use ReactPHP-based webserver instead of httpbin and add forward compatibility with PHPUnit 9. (#168 by @clue)
- Fix: HTTP
HEAD
requests should not expect a response body. (#166 by @clue)
- Fix: Fix cancellation of pending requests with promise followers. (#164 by @clue)
-
Feature: Use HTTP/1.1 protocol version by default and add new
Browser::withProtocolVersion()
. (#162 by @clue)This is the preferred HTTP protocol version which also provides decent backwards-compatibility with legacy HTTP/1.0 servers. As such, there should rarely be a need to explicitly change this protocol version. You can revert to legacy HTTP/1.0 like this:
$browser->withProtocolVersion('1.0')->get($url)->then(…);
-
Feature / Fix: Explicitly close connection after response body ends. (#161 by @clue)
This improves support for servers ignoring the
Connection: close
request header that would otherwise keep the connection open and could eventually run into a timeout even though the transfer was completed. -
Fixed small issue in code example. (#160 by @mmoreram)
-
Clean up test suite and add
.gitattributes
to exclude dev files from exports. (#163 by @SimonFrings)
-
Feature: Add backpressure support and support throttling for streaming outgoing chunked request body. (#148 by @clue)
-
Feature: Start sending outgoing request even when streaming body doesn't emit any data yet. (#150 by @clue)
-
Feature: Only start request timeout timer after streaming request body has been sent (exclude upload time). (#151 and #152 by @clue)
-
Feature: Reject request when streaming request body emits error or closes unexpectedly. (#153 by @clue)
-
Improve download benchmarking script and add new upload benchmark. (#149 by @clue)
-
Improve test suite by testing against PHP 7.4 and simplify test setup and test matrix and fix testing redirected request when following relative redirect. (#145 and #147 by @clue)
-
Add support / sponsorship info and fix documentation typo. (#144 by @clue and #133 by @eislambey)
-
Feature / Fix: Add
Content-Length: 0
request header for emptyPOST
request etc. (#120 by @clue) -
Fix: Only try to follow redirects if
Location
response header is present. (#130 by @clue) -
Documentation and example for SSH proxy (SSH tunnel) and update SOCKS proxy example. (#116, #119 and #121 by @clue)
-
Improve test suite and also run tests on PHP 7.3. (#122 by @samnela)
-
Feature: Add HTTP timeout option. (#114 by @Rakdar and @clue)
This now respects PHP's
default_socket_timeout
setting (default 60s) as a timeout for sending the outgoing HTTP request and waiting for a successful response and will otherwise cancel the pending request and reject its value with an Exception. You can now use thetimeout
option to pass a custom timeout value in seconds like this:$browser = $browser->withOptions(array( 'timeout' => 10.0 )); $browser->get($uri)->then(function (ResponseInterface $response) { // response received within 10 seconds maximum var_dump($response->getHeaders()); });
Similarly, you can use a negative timeout value to not apply a timeout at all or use a
null
value to restore the default handling. -
Improve documentation for
withOptions()
and add documentation and example for HTTP CONNECT proxy. (#111 and #115 by @clue) -
Refactor
Browser
to reuse singleTransaction
instance internally which now accepts sending individual requests and their options. (#113 by @clue)
-
Feature / Fix: Support cancellation forwarding and cancelling redirected requests. (#110 by @clue)
-
Feature / Fix: Remove
Authorization
request header for redirected cross-origin requests and add documentation for HTTP redirects. (#108 by @clue) -
Improve API documentation and add documentation for HTTP authentication and
Authorization
header. (#104 and #109 by @clue) -
Update project homepage. (#100 by @clue)
-
Feature / Fix: Pass custom request headers when following redirects (#91 by @seregazhuk and #96 by @clue)
-
Support legacy PHP 5.3 through PHP 7.2 and HHVM (#95 by @clue)
-
Improve documentation (#87 by @holtkamp and #93 by @seregazhuk)
-
Improve test suite by adding forward compatibility with PHPUnit 5, PHPUnit 6 and PHPUnit 7 and explicitly test HTTP/1.1 protocol version. (#86 by @carusogabriel and #94 and #97 by @clue)
- Feature: Forward compatibility with freshly released react/promise-stream v1.0 (#85 by @WyriHaximus)
- Feature: Update minimum required Socket dependency version in order to support Unix Domain Sockets (UDS) again, support hosts file on all platforms and work around sending secure HTTPS requests with PHP < 7.1.4 (#84 by @clue)
A major compatibility release to update this component to support all latest ReactPHP components!
This update involves a minor BC break due to dropped support for legacy versions. We've tried hard to avoid BC breaks where possible and minimize impact otherwise. We expect that most consumers of this package will actually not be affected by any BC breaks, see below for more details.
-
BC break: Remove deprecated API and mark Sender as @internal only, remove all references to legacy SocketClient component and remove support for Unix domain sockets (UDS) for now (#77, #78, #81 and #83 by @clue)
All of this affects the
Sender
only, which was previously marked as "advanced usage" and is now marked@internal
only. If you've not used this class before, then this BC break will not affect you. If you've previously used this class, then it's recommended to first update to the intermediary v1.4.0 release, which allows you to use a standardConnectorInterface
instead of theSender
and then update to this version without causing a BC break. If you've previously used Unix domain sockets (UDS), then you're recommended to wait for the next version. -
Feature / BC break: Forward compatibility with future Stream v1.0 and strict stream semantics (#79 by @clue)
This component now follows strict stream semantics. This is marked as a BC break because this removes undocumented and untested excessive event arguments. If you've relied on proper stream semantics as documented before, then this BC break will not affect you.
-
Feature: Forward compatibility with future Socket and EventLoop components (#80 by @clue)
-
Feature:
Browser
acceptsConnectorInterface
and deprecate legacySender
(#76 by @clue)If you need custom connector settings (DNS resolution, TLS parameters, timeouts, proxy servers etc.), you can explicitly pass a custom instance of the
ConnectorInterface
:$connector = new \React\Socket\Connector($loop, array( 'dns' => '127.0.0.1', 'tcp' => array( 'bindto' => '192.168.10.1:0' ), 'tls' => array( 'verify_peer' => false, 'verify_peer_name' => false ) )); $browser = new Browser($loop, $connector);
-
Feature: Support request cancellation (#75 by @clue)
$promise = $browser->get($url); $loop->addTimer(2.0, function () use ($promise) { $promise->cancel(); });
-
Feature: Update react/http-client to v0.5, support react/stream v0.6 and react/socket-client v0.7 and drop legacy PHP 5.3 support (#74 by @clue)
-
Feature: Forward compatibility with react/http-client v0.5 (#72 and #73 by @clue)
Older HttpClient versions are still supported, but the new version is now preferred. Advanced usage with custom connectors now recommends setting up the
React\HttpClient\Client
instance explicitly.Accordingly, the
Sender::createFromLoopDns()
andSender::createFromLoopConnectors()
have been marked as deprecated and will be removed in future versions.
-
Restructure examples to ease getting started and fix online tests and add option to exclude tests against httpbin.org (#67 and #71 by @clue)
-
Improve test suite by fixing HHVM build for now again and ignore future HHVM build errors and lock Travis distro so new defaults will not break the build (#68 and #70 by @clue)
-
Feature: Obey explicitly set HTTP protocol version for outgoing requests (#58, #59 by @WyriHaximus, @clue)
$request = new Request('GET', $url); $request = $request->withProtocolVersion(1.1); $browser->send($request)->then(…);
- Fix: Explicitly define all minimum required package versions (#57 by @clue)
-
First stable release, now following SemVer
-
Improve documentation and usage examples
Contains no other changes, so it's actually fully compatible with the v0.5.0 release.
-
Feature / BC break: Implement PSR-7 http-message interfaces (#54 by @clue)
Replace custom
Message
,Request
,Response
andUri
classes with common PSR-7 interfaces:// old $browser->get($uri)->then(function (Response $response) { echo 'Test: ' . $response->getHeader('X-Test'); echo 'Body: ' . $response->getBody(); }); // new $browser->get($uri)->then(function (ResponseInterface $response) { if ($response->hasHeader('X-Test')) { echo 'Test: ' . $response->getHeaderLine('X-Test'); } echo 'Body: ' . $response->getBody(); });
-
Feature: Add streaming API (#56 by @clue)
$browser = $browser->withOptions(array('streaming' => true)); $browser->get($uri)->then(function (ResponseInterface $response) { $response->getBody()->on('data', function($chunk) { echo $chunk . PHP_EOL; }); });
-
Remove / BC break: Remove
Browser::resolve()
because it's now fully decoupled (#55 by @clue)If you need this feature, consider explicitly depending on rize/uri-template instead:
$ composer require rize/uri-template
-
Use clue/block-react and new Promise API in order to simplify tests (#53 by @clue)
-
Support advanced connection options with newest SocketClient (TLS/HTTPS and socket options) (#51 by @clue)
-
First class support for PHP 5.3 through PHP 7 and HHVM (#52 by @clue)
-
Fix: Replace URI placeholders before applying base URI, in order to avoid duplicate slashes introduced due to URI placeholders. (#48)
// now correctly returns "http://example.com/path" // instead of previous "http://example.com//path" $browser = $browser->withBase('http://example.com/'); echo $browser->resolve('{+path}', array('path' => '/path')); // now correctly returns "http://example.com/path?q=test" // instead of previous "http://example.com/path/?q=test" $browser = $browser->withBase('http://example.com/path'); echo $browser->resolve('{?q}', array('q' => 'test'));
-
Feature: Resolve relative URIs, add withBase() and resolve() (#41, #44)
$browser = $browser->withBase('http://example.com/'); $browser->post('/');
-
Feature: Resolve URI template placeholders according to RFC 6570 (#42, #44)
$browser->post($browser->resolve('/{+path}{?version}', array( 'path' => 'demo.json', 'version' => '4' )));
-
Feature: Resolve and follow redirects to relative URIs (#45)
-
Feature / BC break: Simplify Request and Response objects. Remove Browser::request(), use Browser::send() instead. (#37)
// old $browser->request('GET', 'http://www.example.com/'); // new $browser->send(new Request('GET', 'http://www.example.com/'));
-
Feature / Bc break: Enforce absolute URIs via new Uri class (#40, #44)
-
Feature: Add Browser::withSender() method (#38)
-
Feature: Add Sender::createFromLoopDns() function (#39)
-
Improve documentation and test suite
-
Feature: Expose Response object in case of HTTP errors (#35)
-
Feature: Add experimental
Transaction
options viaBrowser
(#25) -
Feature: Add experimental streaming API (#31)
-
Feature: Automatically assign a "Content-Length" header for outgoing
Request
s (#29) -
Feature: Add
Message::getHeader()
, it is now available on bothRequest
andResponse
(#28)
-
Feature: Support communication via UNIX domain sockets (#20)
-
Fix: Detect immediately failing connection attempt (#19)
- Fix: Strict warning when accessing a single header value (#18 by @masakielastic)
- Compatibility with React PHP v0.4 (compatibility with v0.3 preserved) (#11)
- First tagged release
- Initial concept