Omnipay v3 Release
v3.0.0 - 2018-05-14
Omnipay 3.0 focuses on separation of the HTTP Client, to be independent of Guzzle.
This release brings compatibility with the latest Symfony 3+4 and Laravel 5.
The breaking changes for applications using Omnipay are kept to a minimum.
Upgrading applications from Omnipay 2.x to 3.x
Breaking changes
- The
redirect()
method no callsexit()
after sending the content. This is up to the developer now. - An HTTP Client is required. Guzzle will be installed when using
omnipay/omnipay
,
but otherwise you need to required your own implementation (see PHP HTTP Clients)
Added
- It is now possible to use
setAmountInteger(integer $value)
to set the amount in the base units of the currency. - Support for Money for PHP objects are added, by using
setMoney(Money $money)
the Amount and Currency are set.
Upgrading Gateways from 2.x to 3.x
The primary difference is the HTTP Client. We are now using HTTPlug (http://httplug.io/) but rely on our own interface.
Breaking changes
- Change typehint from Guzzle ClientInterface to
Omnipay\Common\Http\ClientInterface
$client->get('..')
/$client->post('..')
etc are removed, you can call$client->request('GET', '')
.- No need to call
$request->send()
, requests are sent directly. - Instead of
$client->createRequest(..)
you can create+send the request directly with$client->request(..)
. - When sending a JSON body, convert the body to a string with
json_encode()
and set the correct Content-Type. - The response is a PSR-7 Response object. You can call
$response->getBody()->getContents()
to get the body as string. $response->json()
and$response->xml()
are gone, but you can implement the logic directly.- An HTTP Client is no longer added by default by
omnipay/common
, butomnipay/omnipay
will add Guzzle.
Gateways should not rely on Guzzle or other clients directly. $body
should be a string (eg.http_build_query($data)
orjson_encode($data)
instead of just$data
).- The
$headers
parameters should be anarray
(notnull
, but can be empty)
Examples:
// V2 XML:
$response = $this->httpClient->post($this->endpoint, null, $data)->send();
$result = $httpResponse->xml();
// V3 XML:
$response = $this->httpClient->request('POST', $this->endpoint, [], http_build_query($data));
$result = simplexml_load_string($httpResponse->getBody()->getContents());
// Example JSON request:
$response = $this->httpClient->request('POST', $this->endpoint, [
'Accept' => 'application/json',
'Content-Type' => 'application/json',
], json_encode($data));
$result = json_decode($response->getBody()->getContents(), true);
Testing changes
PHPUnit is upgraded to PHPUnit 6. Common issues:
setExpectedException()
is removed
// PHPUnit 5:
$this->setExpectedException($class, $message);
// PHPUnit 6:
$this->expectException($class);
$this->expectExceptionMessage($message);
- Tests that do not perform any assertions, will be marked as risky. This can be avoided by annotating them with
@doesNotPerformAssertions