denismitr / net-call
Easy to use and mockable HTTP client, wraps most common http calls functionality around Guzzle.
v0.1
2018-01-20 20:10 UTC
Requires
- php: >=7.0
- guzzlehttp/guzzle: ^6.0
- tightenco/collect: ^5.4
Requires (Dev)
- laravel/lumen-framework: 5.5.*
- mockery/mockery: ^1.0
- phpunit/phpunit: ^6.0
This package is auto-updated.
Last update: 2024-10-23 09:14:09 UTC
README
NetCall is a convenient and easy to use HTTP client. It is a wrapper around Guzzle, made for most common use cases. And is designed to make development and testing easier and more pleasant.
Author
Denis Mitrofanov
Installation
composer require denismitr/net-call
Usage
$response = NetCall::new()->get('http://www.google.com?foo=bar'); // NetCallResponseInterface methods $response->body(); // : string $response->json(); // : array $response->header('some-key'); $response->headers(); // : array $response->status(); // : int $response->isSuccess(); // : bool $response->isOk(); // : bool $response->isRedirect(); // : bool $response->isServerError(); // : bool
// request params will be json encoded by default $response = NetCall::new()->post('http://test.com/post', [ 'foo' => 'bar', 'baz' => 'qux', ]); $response->json(); // array with json response data
From Params
$response = NetCall::new()->asFormData()->post('http://myurl.com/post', [ 'foo' => 'bar', 'baz' => 'qux', ]);
Multipart
$response = NetCall::new()->asMultipart()->post('http://myurl.com/multi-part', [ [ 'name' => 'foo', 'contents' => 'bar' ], [ 'name' => 'baz', 'contents' => 'qux', ], [ 'name' => 'test-file', 'contents' => 'test contents', 'filename' => 'test-file.txt', ], ]);
With Headers
$response = NetCall::new() ->withHeaders(['Custom' => 'Header']) ->get('http://myurl.com/get');
Set Accept header
$response = NetCall::new() ->accept('application/json') ->post('http://myurl.com/post');
Patch requests are supported
$response = NetCall::new()->patch('http://myurl.com/patch', [ 'foo' => 'bar', 'baz' => 'qux', ]);
Exceptions
Exceptions are not thrown on 4xx and 5xx: use response status method instead.
Redirects
Redirects are followed by default
To disable that:
$response = NetCall::new()->noRedirects()->get('http://myurl.com/get'); $response->status(); // 302 $response->header('Location'); // http://myurl.com/redirected
Auth
Basic auth
$response = NetCall::new() ->withBasicAuth('username', 'password') ->get('http://myurl.com/basic-auth');
Digest auth
$response = NetCall::new() ->withDigestAuth('username', 'password') ->get('http://myurl.com/digest-auth');
Timeout
Set timeout
NetCall::new()->timeout(1)->get('http://myurl.com/timeout'); // If more then a second passes // \Denismitr\NetCall\Exceptions\NetCallException is thrown