2017 © Pedro Peláez
 

library guzzle-services

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

image

guzzlehttp/guzzle-services

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  • Tuesday, November 21, 2017
  • by mtdowling
  • Repository
  • 26 Watchers
  • 180 Stars
  • 1,125,083 Installations
  • PHP
  • 149 Dependents
  • 2 Suggesters
  • 65 Forks
  • 29 Open issues
  • 14 Versions
  • 10 % Grown

The README.md

Guzzle Services

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures., (*1)

use GuzzleHttp\Client;
use GuzzleHttp\Command\Guzzle\GuzzleClient;
use GuzzleHttp\Command\Guzzle\Description;

$client = new Client();
$description = new Description([
    'baseUri' => 'http://httpbin.org/',
    'operations' => [
        'testing' => [
            'httpMethod' => 'GET',
            'uri' => '/get{?foo}',
            'responseModel' => 'getResponse',
            'parameters' => [
                'foo' => [
                    'type' => 'string',
                    'location' => 'uri'
                ],
                'bar' => [
                    'type' => 'string',
                    'location' => 'query'
                ]
            ]
        ]
    ],
    'models' => [
        'getResponse' => [
            'type' => 'object',
            'additionalProperties' => [
                'location' => 'json'
            ]
        ]
    ]
]);

$guzzleClient = new GuzzleClient($client, $description);

$result = $guzzleClient->testing(['foo' => 'bar']);
echo $result['args']['foo'];
// bar

Installing

This project can be installed using Composer:, (*2)

composer require guzzlehttp/guzzle-services, (*3)

For Guzzle 5, use composer require guzzlehttp/guzzle-services:0.6., (*4)

Note: If Composer is not installed globally then you may need to run the preceding Composer commands using php composer.phar (where composer.phar is the path to your copy of Composer), instead of just composer., (*5)

Plugins

  • Load Service description from file [https://github.com/gimler/guzzle-description-loader]

Transition guide from Guzzle 5.0 to 6.0

Change regarding PostField and PostFile

The request locations postField and postFile were removed in favor of formParam and multipart. If your description looks like, (*6)

[
    'baseUri' => 'http://httpbin.org/',
    'operations' => [
        'testing' => [
            'httpMethod' => 'GET',
            'uri' => '/get{?foo}',
            'responseModel' => 'getResponse',
            'parameters' => [
                'foo' => [
                    'type' => 'string',
                    'location' => 'postField'
                ],
                'bar' => [
                    'type' => 'string',
                    'location' => 'postFile'
                ]
            ]
        ]
    ],
]

you need to change postField to formParam and postFile to multipart., (*7)

More documentation coming soon., (*8)

Cookbook

Changing the way query params are serialized

By default, query params are serialized using strict RFC3986 rules, using http_build_query method. With this, array params are serialized this way:, (*9)

$client->myMethod(['foo' => ['bar', 'baz']]);

// Query params will be foo[0]=bar&foo[1]=baz

However, a lot of APIs in the wild require the numeric indices to be removed, so that the query params end up being foo[]=bar&foo[]=baz. You can easily change the behaviour by creating your own serializer and overriding the "query" request location:, (*10)

use GuzzleHttp\Command\Guzzle\GuzzleClient;
use GuzzleHttp\Command\Guzzle\RequestLocation\QueryLocation;
use GuzzleHttp\Command\Guzzle\QuerySerializer\Rfc3986Serializer;
use GuzzleHttp\Command\Guzzle\Serializer;

$queryLocation = new QueryLocation('query', new Rfc3986Serializer(true));
$serializer = new Serializer($description, ['query' => $queryLocation]);
$guzzleClient = new GuzzleClient($client, $description, $serializer);

You can also create your own serializer if you have specific needs., (*11)

Security

If you discover a security vulnerability within this package, please send an email to security@tidelift.com. All security vulnerabilities will be promptly addressed. Please do not disclose security-related issues publicly until a fix has been announced. Please see Security Policy for more information., (*12)

License

Guzzle is made available under the MIT License (MIT). Please see License File for more information., (*13)

For Enterprise

Available as part of the Tidelift Subscription, (*14)

The maintainers of Guzzle and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. Learn more., (*15)

The Versions

21/11 2017

dev-develop

dev-develop

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

06/10 2017

dev-master

9999999-dev

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

06/10 2017

1.1.3

1.1.3.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

19/05 2017

1.1.2

1.1.2.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

15/05 2017

1.1.1

1.1.1.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

31/01 2017

1.1.0

1.1.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

13/01 2017

1.0.1

1.0.1.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

24/11 2016

1.0.0

1.0.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

21/10 2016

0.6.0

0.6.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

23/12 2014

0.5.0

0.5.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

03/11 2014

0.4.0

0.4.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

01/06 2014

0.3.0

0.3.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

31/03 2014

0.2.0

0.2.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires

15/03 2014

0.1.0

0.1.0.0

Provides an implementation of the Guzzle Command library that uses Guzzle service descriptions to describe web services, serialize requests, and parse responses into easy to use model structures.

  Sources   Download

MIT

The Requires

 

The Development Requires