2017 © Pedro Peláez
 

library csob-gateway

CSOB payment gateway client

image

slevomat/csob-gateway

CSOB payment gateway client

  • Tuesday, November 28, 2017
  • by slevomat
  • Repository
  • 20 Watchers
  • 19 Stars
  • 26,555 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 4 Forks
  • 1 Open issues
  • 17 Versions
  • 11 % Grown

The README.md

CSOB gateway

Build status Code coverage Latest Stable Version Composer Downloads, (*1)

This repository provides a client library for ČSOB Payment Gateway., (*2)

Library supports all endpoints of eAPI 1.9 except NEJsplátku (loan@shop). Pull requests are welcome., (*3)

Older available versions (not actively maintained): - Version 5.* supports PHP 7.2 and eAPI 1.8 - Version 4.* supports PHP 7.2 and eAPI 1.7 - Version 3.* supports PHP 7 and eAPI 1.6. - Version 2.* supports PHP 7 and eAPI 1.5. - Version 1.* supports PHP 5.6 and eAPI 1.5., (*4)

Installation

The best way to install slevomat/csob-gateway is using Composer:, (*5)

> composer require slevomat/csob-gateway

Usage

First you have to initialize the payment in gateway and redirect customer to its interface., (*6)

WARNING: Please note, that all the prices are in hundredths of currency units. It means that when you wanna init a payment for 1.9 EUR, you should pass here the integer 190., (*7)

$apiClient = new ApiClient(
    new CurlDriver(),
    new CryptoService(
        $privateKeyFile,
        $bankPublicKeyFile
    ),
    'https://api.platebnibrana.csob.cz/api/v1.8'
);

$requestFactory = new RequestFactory('012345');

// cart has to have at least 1 but most of 2 items
$cart = new Cart(Currency::EUR);
$cart->addItem('Nákup', 1, 1.9 * 100);

$customer = new Customer(
    'Jan Novák',
    'jan.novak@example.com',
    mobilePhone: '+420.800300300',
    customerAccount: new CustomerAccount(
        new DateTimeImmutable('2022-01-12T12:10:37+01:00'),
        new DateTimeImmutable('2022-01-15T15:10:12+01:00'),
    ),
    customerLogin: new CustomerLogin(
        CustomerLoginAuth::ACCOUNT,
        new DateTimeImmutable('2022-01-25T13:10:03+01:00'),
    ),
);

$order = new Order(
    OrderType::PURCHASE,
    OrderAvailability::NOW,
    null,
    OrderDelivery::SHIPPING,
    OrderDeliveryMode::SAME_DAY,
    addressMatch: true,
    billing: new OrderAddress(
        'Karlova 1',
        null,
        null,
        'Praha',
        '11000',
        null,
        Country::CZE,
    ),
);

$paymentResponse = $requestFactory->createInitPayment(
    123,
    PayOperation::PAYMENT,
    PayMethod::CARD,
    true,
    $returnUrl,
    HttpMethod::POST,
    $cart,
    $customer,
    $order,
    'some-base64-encoded-merchant-data',
    '123',
    Language::CZ,
    1800,
    1,
    2,
)->send($apiClient);
$payId = $paymentResponse->getPayId();

$processPaymentResponse = $requestFactory->createProcessPayment($payId)->send($apiClient);

// redirect to gateway
header('Location: ' . $processPaymentResponse->getGatewayLocationUrl());

After customer returns from gateway, he is redirected to $returnUrl where you have to process the payment., (*8)

try {
    $receivePaymentResponse = $requestFactory->createReceivePaymentRequest()->send($apiClient, $_POST /* $_GET */);
    if ($receivePaymentResponse->getPaymentStatus() === PaymentStatus::S7_AWAITING_SETTLEMENT) {
        // payment was successful!
    }
} catch (VerificationFailedException | InvalidSignatureException $e) {
    // request was not send from csob api
}

Please refer to the CSOB documentation and learn what states you should to check, they are all available as PaymentStatus::S* constants., (*9)

Custom ApiClientDriver

API calls are made through ApiClientDriver interface. Library contains two default implementations of driver - CurlDriver and GuzzleDriver. You can also create your own driver by implementing the ApiClientDriver interface, and passing it to ApiClient constructor., (*10)

CurlDriver communicates via curl PHP extension, GuzzleDriver uses guzzlehttp/guzzle library. If you want to use GuzzleDriver you need to require guzzlehttp/guzzle package in your composer.json., (*11)

The Versions

27/07 2016

2.x-dev

2.9999999.9999999.9999999-dev

CSOB payment gateway client

  Sources   Download

MIT

The Requires

  • ext-openssl *
  • php ^7.0

 

The Development Requires

gateway card csob paymentgateway

14/07 2016
20/05 2016

1.x-dev

1.9999999.9999999.9999999-dev

CSOB payment gateway client

  Sources   Download

MIT

The Requires

  • ext-openssl *
  • php ^5.6.0|^7.0

 

The Development Requires

gateway card csob paymentgateway

23/02 2016
11/01 2016
21/12 2015

dev-honza-tests

dev-honza-tests

CSOB payment gateway client

  Sources   Download

MIT

The Requires

  • ext-openssl *
  • php ^5.6.0|^7.0

 

The Development Requires

gateway card csob paymentgateway