extends |
EventEmitter |
---|
A rudimentary HTTP client.
This object wraps PHP's curl extension and provides an easy way to send it a Request object, and return a Response object.
This is by no means intended as the next best HTTP client, but it does the job and provides a simple integration with the rest of sabre/http.
This client emits the following events: beforeRequest(RequestInterface $request) afterRequest(RequestInterface $request, ResponseInterface $response) error(RequestInterface $request, ResponseInterface $response, bool &$retry, int $retryCount) exception(RequestInterface $request, ClientException $e, bool &$retry, int $retryCount)
The beforeRequest event allows you to do some last minute changes to the request before it's done, such as adding authentication headers.
The afterRequest event will be emitted after the request is completed successfully.
If a HTTP error is returned (status code higher than 399) the error event is triggered. It's possible using this event to retry the request, by setting retry to true.
The amount of times a request has retried is passed as $retryCount, which can be used to avoid retrying indefinitely. The first time the event is called, this will be 0.
It's also possible to intercept specific http errors, by subscribing to for example 'error:401'.
Methods | ||
---|---|---|
public
|
__construct()
|
# |
public
|
send(RequestInterface $request): ResponseInterface
|
# |
public
|
sendAsync(RequestInterface $request, ?callable $success = null, ?callable $error = null)
|
# |
public
|
poll(): bool
|
# |
public
|
wait()
|
# |
public
|
setThrowExceptions(bool $throwExceptions)
|
# |
public
|
addCurlSetting(int $name, $value)
|
# |
Methods used from Sabre\Event\EmitterTrait |
---|
on(), once(), emit(), listeners(), removeListener(), removeAllListeners() |
Constants | ||
---|---|---|
public
|
STATUS_SUCCESS = 0
|
# |
public
|
STATUS_CURLERROR = 1
|
# |
public
|
STATUS_HTTPERROR = 2
|
# |