Another +1 for Guzzle Kevin On Tue, Sep 3, 2013 at 11:32 AM, Kevin Reiss <[log in to unmask]> wrote: > I can second Guzzle. We have been using it for our our in-house PHP > applications that require HTTP interactions for about six months and it has > worked out very well. Guzzle has also been incorporated as the new default > HTTP client in the next version of Drupal. > > > ________________________________ > From: Ross Singer <[log in to unmask]> > To: [log in to unmask] > Sent: Tuesday, September 3, 2013 10:59 AM > Subject: Re: [CODE4LIB] PHP HTTP Client preference > > > Hey Karen, > > We use Guzzle: http://guzzlephp.org/ > > It's nice, seems to work well for our needs, is available in packagist, > and is the HTTP client library in the official AWS SDK libraries (which was > a big endorsement, in our view). > > We're still in the process of moving all of our clients over to it (we > built a homegrown HTTP client on top of CURL first), but have been really > impressed with it so far. > > -Ross. > > On Sep 3, 2013, at 10:49 AM, "Coombs,Karen" <[log in to unmask]> wrote: > > > One project I'm working on for OCLC right now is building a set of > object-oriented client libraries in PHP that will assist developers with > interacting with our web services. The first of these libraries we'd like > to release provides classes for authentication and authorization to our web > services. You can read more about Authentication/Authorization and our web > services on the Developer Network site<http://oc.lc/devnet> > > > > The purpose of this project is to make a simple and easy to use object > oriented library that supports our various authentication methods. > > > > This library need to make HTTP requests and I've looked at a number of > potential libraries and HTTP clients in PHP. > > > > Why am I not just considering using CURL natively? > > > > The standard CURL functions in PHP are not object-oriented. All of our > code libraries (both our authentication/authorization library and future > libraries for interacting with the REST services themselves) need to > perform a robust set of HTTP interactions. Using the standard CURL > functions would very likely increase the size of the code libraries and the > potential for errors and inconsistencies within the code base because of > how much we use HTTP. > > > > Given this, I believe there are three possible options and would like to > get the community's feedback on which option you would prefer. > > > > Option 1. - Write my own HTTP Client on top of the standard PHP CURL > implementation. This means people using the code library can only download > it and now worry about any dependencies. However, that means adding extra > code to our library which, although essential, isn't at the core of what > we're trying to support. My fear is that my client will never be as good as > an existing client. > > > > Option 2. - Use HTTPful code library (http://phphttpclient.com/). This > is a well developed and supported code base which is designed specifically > to support REST interactions. It is easy to install via Composer or Phar, > or manually. It is slim and trim and only does the HTTP Client functions. > It does create a dependency on an external (but small) library. > > > > Option 3. - Use the Zend 2 HTTPClient. This is a well developed and > supported code base. The biggest downside is that Zend is a massive code > library to require. A developer could choose to download only the specific > set of classes that we are dependent on, but asking people to do this may > prove confusing to some developers. > > > > I'd appreciate your feedback so we can provide the most useful set of > libraries to the community. > > > > Karen > > > > Karen A. Coombs > > Senior Product Analyst > > WorldShare Platform > > [log in to unmask]<mailto:[log in to unmask]> > > 614-764-4068 > > Skype: librarywebchic >