diff --git a/.gitignore b/.gitignore index 4f38912..157ff0c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,3 @@ .idea -vendor +vendor/ composer.lock diff --git a/README.md b/README.md index dc258d1..9af92c8 100644 --- a/README.md +++ b/README.md @@ -48,3 +48,8 @@ try { dump((string)$e); } ``` + +## Settings + + +If you would like to use `PLN` and `HUF` currencies, you need to send email to `akceptacekaret@csob.cz` with your MerchantIds (sandbox and production). This functionality will be available September 2016. diff --git a/composer.json b/composer.json index 43ebbc7..076d6c7 100644 --- a/composer.json +++ b/composer.json @@ -16,18 +16,22 @@ "authors": [ { "name": "Michal Sänger", - "email": "michal.sanger@bileto.cz" + "email": "michal.sanger@bileto.com" + }, + { + "name": "Jan Machala", + "email": "jan.machala@bileto.com" } ], "autoload": { "psr-4": { "Omnipay\\Csob\\" : "src/" } }, "require": { - "omnipay/common": "2.3.*" + "omnipay/common": "2.5.*" }, "require-dev": { - "omnipay/tests": "^2.0", - "symfony/var-dumper": "^2.7", - "mockery/mockery": "^0.9.4" + "omnipay/tests": "2.0.*", + "symfony/var-dumper": "3.1.*", + "mockery/mockery": "0.9.*" } } diff --git a/phpunit.xml b/phpunit.xml index fc6bb9d..6f00bcd 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -1,23 +1,19 @@ - - + stopOnFailure="false"> - + ./tests/ - - - - + diff --git a/src/Gateway.php b/src/Gateway.php index e1942cd..36a3554 100644 --- a/src/Gateway.php +++ b/src/Gateway.php @@ -16,12 +16,12 @@ * ČSOB payment gateway * * @package Omnipay\Csob - * @see https://github.com/csob/paymentgateway/wiki/eAPI-1.5-EN + * @see https://github.com/csob/paymentgateway/wiki/eAPI-v1.6-EN */ class Gateway extends AbstractGateway { - const URL_SANDBOX = 'https://iapi.iplatebnibrana.csob.cz/api/v1.5'; - const URL_PRODUCTION = 'https://api.platebnibrana.csob.cz/api/v1.5'; + const URL_SANDBOX = 'https://iapi.iplatebnibrana.csob.cz/api/v1.6'; + const URL_PRODUCTION = 'https://api.platebnibrana.csob.cz/api/v1.6'; /** @var DataSignator */ private $signator; diff --git a/src/Message/AbstractRequest.php b/src/Message/AbstractRequest.php index a019567..3869caa 100644 --- a/src/Message/AbstractRequest.php +++ b/src/Message/AbstractRequest.php @@ -2,10 +2,11 @@ namespace Omnipay\Csob\Message; +use Omnipay\Common\Message\AbstractRequest as OmnipayAbstractRequest; use Omnipay\Csob\Sign\DataSignator; use Omnipay\Csob\Sign\DataVerifier; -abstract class AbstractRequest extends \Omnipay\Common\Message\AbstractRequest +abstract class AbstractRequest extends OmnipayAbstractRequest { /** @var DataSignator */ private $signator; diff --git a/src/Message/AbstractResponse.php b/src/Message/AbstractResponse.php index 0859561..0cc17cc 100644 --- a/src/Message/AbstractResponse.php +++ b/src/Message/AbstractResponse.php @@ -2,9 +2,10 @@ namespace Omnipay\Csob\Message; +use Omnipay\Common\Message\AbstractResponse as OmnipayAbstractResponse; use Omnipay\Csob\Sign\DataVerifier; -class AbstractResponse extends \Omnipay\Common\Message\AbstractResponse +class AbstractResponse extends OmnipayAbstractResponse { /** @var DataVerifier */ private $verifier; diff --git a/src/Message/EchoRequest.php b/src/Message/EchoRequest.php index 56e4719..aee48c5 100644 --- a/src/Message/EchoRequest.php +++ b/src/Message/EchoRequest.php @@ -25,10 +25,7 @@ public function setDttm($value) */ public function getData() { - $data = [ - "merchantId" => $this->getParameter('merchantId'), - "dttm" => $this->getParameter('dttm'), - ]; + $data = $this->getParameters(); $data['signature'] = $this->signData($data); return $data; } diff --git a/src/Message/InitPaymentRequest.php b/src/Message/InitPaymentRequest.php index 6291b00..7253e18 100644 --- a/src/Message/InitPaymentRequest.php +++ b/src/Message/InitPaymentRequest.php @@ -96,23 +96,7 @@ public function setLanguage($value) */ public function getData() { - $data = [ - "merchantId" => $this->getParameter('merchantId'), - "orderNo" => $this->getParameter('orderNo'), - "dttm" => $this->getParameter('dttm'), - "payOperation" => $this->getParameter('payOperation'), - "payMethod" => $this->getParameter('payMethod'), - "totalAmount" => $this->getParameter('totalAmount'), - "currency" => $this->getParameter('currency'), - "closePayment" => $this->getParameter('closePayment'), - "returnUrl" => $this->getParameter('returnUrl'), - "returnMethod" => $this->getParameter('returnMethod'), - "cart" => $this->getParameter('cart'), - "description" => $this->getParameter('description'), - "merchantData" => $this->getParameter('merchantData'), - "customerId" => $this->getParameter('customerId'), - "language" => $this->getParameter('language'), - ]; + $data = $this->getParameters(); $data['signature'] = $this->signData($data); return $data; } diff --git a/src/Message/ProcessPaymentRequest.php b/src/Message/ProcessPaymentRequest.php index 6ad8665..cc0a554 100644 --- a/src/Message/ProcessPaymentRequest.php +++ b/src/Message/ProcessPaymentRequest.php @@ -28,12 +28,6 @@ public function setMerchantId($value) public function getData() { return $this->getParameters(); - $data = [ - "merchantId" => $this->getParameter('merchantId'), - "payId" => $this->getParameter('payId'), - "dttm" => $this->getParameter('dttm'), - ]; - return $data; } /** diff --git a/src/Purchase.php b/src/Purchase.php index 7dae23c..8b3f091 100644 --- a/src/Purchase.php +++ b/src/Purchase.php @@ -9,10 +9,12 @@ */ class Purchase { - const CURENCY_CZK = 'CZK'; - const CURENCY_EUR = 'EUR'; - const CURENCY_USD = 'USD'; - const CURENCY_GBP = 'GBP'; + const CURRENCY_CZK = 'CZK'; + const CURRENCY_EUR = 'EUR'; + const CURRENCY_USD = 'USD'; + const CURRENCY_GBP = 'GBP'; + const CURRENCY_HUF = 'HUF'; + const CURRENCY_PLN = 'PLN'; const LANG_CZ = 'CZ'; const LANG_EN = 'EN'; @@ -71,11 +73,11 @@ class Purchase /** * Currency code. - * Approved values: CZK, EUR, USD, GBP + * Approved values: CZK, EUR, USD, GBP, HUF, PLN * * @var string */ - private $currency = self::CURENCY_CZK; + private $currency = self::CURRENCY_CZK; /** * It indicates whether the payment should automatically be put in the queue @@ -143,7 +145,7 @@ class Purchase /** * Preferred language mutation to be displayed on the payment gateway. * Czech mutation is by default. - * Approved values: CZ, EN, DE, SK + * Approved values: CZ, EN, DE, FR, HU, IT, JP, PL, PT, RO, RU, SK, ES, TR, VN * * @var string */ diff --git a/tests/bootstrap.php b/tests/bootstrap.php deleted file mode 100644 index 0f47be9..0000000 --- a/tests/bootstrap.php +++ /dev/null @@ -1,5 +0,0 @@ -addCartItem($item); $purchase->setDttm('xyz'); $expected = [ diff --git a/tests/unit/Sign/DataSignatorTest.php b/tests/unit/Sign/DataSignatorTest.php index e051a09..b3ead7c 100644 --- a/tests/unit/Sign/DataSignatorTest.php +++ b/tests/unit/Sign/DataSignatorTest.php @@ -1,15 +1,20 @@ "A1029DTmM7", diff --git a/tests/unit/Sign/DataVerifierTest.php b/tests/unit/Sign/DataVerifierTest.php index baf1157..dfaa54e 100644 --- a/tests/unit/Sign/DataVerifierTest.php +++ b/tests/unit/Sign/DataVerifierTest.php @@ -1,13 +1,17 @@ "518778", diff --git a/tests/unit/Sign/SignatorTest.php b/tests/unit/Sign/SignatorTest.php index a376ea7..31b8de4 100644 --- a/tests/unit/Sign/SignatorTest.php +++ b/tests/unit/Sign/SignatorTest.php @@ -1,13 +1,16 @@ sign($text); diff --git a/tests/unit/Sign/VerifierTest.php b/tests/unit/Sign/VerifierTest.php index 7e3e721..7be0a1a 100644 --- a/tests/unit/Sign/VerifierTest.php +++ b/tests/unit/Sign/VerifierTest.php @@ -1,13 +1,16 @@ sign($text);