2017 © Pedro Peláez
 

library http-request

A minimalistic http/curl request interface library

image

onoi/http-request

A minimalistic http/curl request interface library

  • Saturday, January 20, 2018
  • by mwjames
  • Repository
  • 1 Watchers
  • 4 Stars
  • 117,864 Installations
  • PHP
  • 5 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 7 Versions
  • 5 % Grown

The README.md

Http request

Build Status Code Coverage Scrutinizer Code Quality Latest Stable Version Packagist download count Dependency Status, (*1)

A minimalistic http/curl request interface that was part of the Semantic MediaWiki code base and is now being deployed as independent library., (*2)

This library provides:, (*3)

  • HttpRequest interface
  • CurlRequest as cURL implementation of the HttpRequest
  • CachedCurlRequest to support low-level caching on repeated CurlRequest requests
  • MultiCurlRequest to make use of the cURL multi stack feature
  • SocketRequest to create asynchronous socket connections

Requirements

  • PHP 5.3 or later

Installation

The recommended installation method for this library is by adding the dependency to your composer.json., (*4)

{
    "require": {
        "onoi/http-request": "~1.3"
    }
}

Usage

use Onoi\HttpRequest\CurlRequest;
use Onoi\HttpRequest\Exception\BadHttpResponseException;
use Onoi\HttpRequest\Exception\HttpConnectionException;

class Foo {

    private $curlRequest = null;

    public function __constructor( CurlRequest $curlRequest ) {
        $this->curlRequest = $curlRequest;
    }

    public function doMakeHttpRequestTo( $url ) {

        $this->curlRequest->setOption( CURLOPT_URL, $url );

        if ( !$this->curlRequest->ping() ) {
            throw new HttpConnectionException( "Couldn't connect" );
        }

        $this->curlRequest->setOption( CURLOPT_RETURNTRANSFER, true );

        $this->curlRequest->setOption( CURLOPT_HTTPHEADER, array(
            'Accept: application/x-turtle'
        ) );

        $response = $this->curlRequest->execute();

        if ( $this->curlRequest->getLastErrorCode() == 0 ) {
            return $response;
        }

        throw new BadHttpResponseException( $this->curlRequest );
    }
}
$httpRequestFactory = new HttpRequestFactory();

$instance = new Foo( $httpRequestFactory->newCurlRequest() );
$response = $instance->doMakeHttpRequestTo( 'http://example.org' );

OR

$cacheFactory = new CacheFactory();

$compositeCache = $cacheFactory->newCompositeCache( array(
    $cacheFactory->newFixedInMemoryLruCache( 500 ),
    $cacheFactory->newDoctrineCache( new \Doctrine\Common\Cache\RedisCache() )
) );

$httpRequestFactory = new HttpRequestFactory( $compositeCache );
$cachedCurlRequest = $httpRequestFactory->newCachedCurlRequest();

// Responses for a request with the same signature (== same endpoint and same query
// content) will be cached if the request was successful for a specified 1 h (3600 sec)
$cachedCurlRequest->setOption( ONOI_HTTP_REQUEST_RESPONSECACHE_TTL, 60 * 60 );

$instance = new Foo( $cachedCurlRequest );
$response = $instance->doMakeHttpRequestTo( 'http://example.org' );

Contribution and support

If you want to contribute work to the project please subscribe to the developers mailing list and have a look at the contribution guidelinee. A list of people who have made contributions in the past can be found here., (*5)

Tests

The library provides unit tests that covers the core-functionality normally run by the continues integration platform. Tests can also be executed manually using the PHPUnit configuration file found in the root directory., (*6)

Release notes

  • 1.3.1 (2016-01-14), (*7)

    • Extended SocketRequest to match a possible TLS port
  • 1.3.0 (2015-11-23), (*8)

    • Deprecated CachedCurlRequest::setCachePrefix and CachedCurlRequest::setExpiryInSeconds in favor of setting it via the option ONOI_HTTP_REQUEST_RESPONSECACHE_PREFIX and ONOI_HTTP_REQUEST_RESPONSECACHE_TTL (any change in the expiry will auto-invalidate existing items in cache)
    • Deprecated CachedCurlRequest::isCached in favor of CachedCurlRequest::isFromCache
  • 1.2.0 (2015-11-09), (*9)

    • Added "wasAccepted" to the SocketRequest response output
    • Added option ONOI_HTTP_REQUEST_FOLLOWLOCATION to support resetting the URL location in case of a 301 HTTP response during a SocketRequest::ping request
  • 1.1.0 (2015-09-12), (*10)

    • Renamed AsyncCurlRequest to MultiCurlRequest
    • Deprecated MultiCurlRequest::setCallback and to be replaced by MultiCurlRequest::setOption( ONOI_HTTP_REQUEST_ON_COMPLETED_CALLBACK, ... )
    • Added SocketRequest to create asynchronous socket connections
  • 1.0.0 (2015-07-22, initial release), (*11)

    • Added the HttpRequest interface
    • Added the CurlRequest implementation
    • Added the CachedCurlRequest to extend the CurlRequest implementation
    • Added the AsyncCurlRequest implementation

License

GNU General Public License 2.0 or later., (*12)

The Versions

20/01 2018

dev-master

9999999-dev https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+ GPL-2.0-or-later

The Requires

 

curl http request

14/01 2017

1.3.1

1.3.1.0 https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+

The Requires

 

curl http request

23/11 2015

1.3.0

1.3.0.0 https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+

The Requires

 

curl http request

09/11 2015

1.2.0

1.2.0.0 https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+

The Requires

 

curl http request

28/10 2015

1.1.1

1.1.1.0 https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+

The Requires

 

curl http request

12/09 2015

1.1.0

1.1.0.0 https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+

The Requires

 

curl http request

23/07 2015

1.0.0

1.0.0.0 https://github.com/onoi/http-request

A minimalistic http/curl request interface library

  Sources   Download

GPL-2.0+

The Requires

 

curl http request