Skip to content
This repository has been archived by the owner on Oct 3, 2023. It is now read-only.
/ diciotto Public archive

✈️ A no-nonsense PHP Http client focused on DX (PSR 18 compliant)

License

Notifications You must be signed in to change notification settings

fain182/diciotto

Repository files navigation

Imgur

Latest Stable Version Build Status Coverage Status

Diciotto is a no-nonsense PSR-18 compliant HTTP client library for PHP 7.

Principles

  • Documentation should be unnecessary
  • Provide sensible defaults
  • Explicit is better than implicit
  • Prefer a good Developer eXperience over performance
  • No surprises

Install

    composer require fain182/diciotto

How to...

make a GET request

    $httpClient = new HttpClient();
    $response = $httpClient->sendRequest( new Request('http://www.google.com') );

make a POST request with body in JSON

    $httpClient = new HttpClient();
    $request = new JsonRequest('https://httpbin.org/put', 'POST', ['name' => 'value']);
    $response = $httpClient->sendRequest($request);

make a request with a different timeout

The default timeout is 15 seconds.

    $httpClient = (new HttpClient())->withTimeout(30);
    $response = $httpClient->sendRequest( new Request('http://www.google.com') );

make a request to a server with self-signed or invalid SSL certificate

    $httpClient = (new HttpClient())->withCheckSslCertificates(false);
    $response = $httpClient->sendRequest( new Request('http://www.google.com') );

make a request with a cookie

    $httpClient = new HttpClient();
    $request = (new Request('http://www.google.com'))->withAddedCookie('name', 'value');
    $response = $httpClient->sendRequest( $request );

Error handling

Diciotto raise exception if the request is invalid (RequestException), or if there are network problems (NetworkException). Response with status code 4xx or 5xx are treated the same way as the others, so no exception or error is raised.

About

Requirements

  • Diciotto works with PHP 7.1 or above.

License

Diciotto is licensed under the MIT License - see the LICENSE file for details

Acknowledgements

Diciotto is built on top of nyholm/psr7 that provides PSR-7 and PSR-17 implementation.

About

✈️ A no-nonsense PHP Http client focused on DX (PSR 18 compliant)

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages