alexminza/victoriabank-sdk

PHP SDK for Victoriabank API

Installs: 0

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/alexminza/victoriabank-sdk

v1.0.0 2026-01-14 10:39 UTC

This package is not auto-updated.

Last update: 2026-01-14 17:14:37 UTC


README

Victoriabank

Installation

To easily install or upgrade to the latest release, use composer:

composer require alexminza/victoriabank-sdk

To enable logging add the monolog package:

composer require monolog/monolog

Getting started

Import SDK:

require_once __DIR__ . '/vendor/autoload.php';

use Victoriabank\Victoriabank\VictoriabankClient;

Add project configuration:

$DEBUG = getenv('DEBUG');

$VB_BASE_URI = getenv('VB_BASE_URI') ?: VictoriabankClient::TEST_BASE_URL;
$VB_MERCHANT_ID = getenv('VB_MERCHANT_ID');
$VB_TERMINAL_ID = getenv('VB_TERMINAL_ID');
$VB_MERCHANT_PRIVATE_KEY  = getenv('VB_MERCHANT_PRIVATE_KEY') ?: 'file://key.pem';
$VB_MERCHANT_PRIVATE_KEY_PASSPHRASE = getenv('VB_MERCHANT_PRIVATE_KEY_PASSPHRASE');
$VB_MERCHANT_PUBLIC_KEY = getenv('VB_MERCHANT_PUBLIC_KEY') ?: 'file://pubkey.pem';
$VB_BANK_PUBLIC_KEY = getenv('VB_BANK_PUBLIC_KEY') ?: 'file://victoria_pub.pem';

Initialize client:

$options = [
    'base_uri' => $VB_BASE_URI,
    'timeout' => 30
];

if ($DEBUG) {
    $logName = 'victoriabank_guzzle';
    $logFileName = "$logName.log";

    $log = new \Monolog\Logger($logName);
    $log->pushHandler(new \Monolog\Handler\StreamHandler($logFileName, \Monolog\Logger::DEBUG));

    $stack = \GuzzleHttp\HandlerStack::create();
    $stack->push(\GuzzleHttp\Middleware::log($log, new \GuzzleHttp\MessageFormatter(\GuzzleHttp\MessageFormatter::DEBUG)));

    $options['handler'] = $stack;
}

$guzzleClient = new \GuzzleHttp\Client($options);
$vbClient = new VictoriabankClient($guzzleClient);

$vbClient
    ->setMerchantId($VB_MERCHANT_ID)
    ->setTerminalId($VB_TERMINAL_ID)
    ->setLanguage('en')
    ->setTimezone('Europe/Chisinau')
    ->setMerchantPrivateKey($VB_MERCHANT_PRIVATE_KEY, $VB_MERCHANT_PRIVATE_KEY_PASSPHRASE)
    ->setBankPublicKey($VB_BANK_PUBLIC_KEY)
    ->setSignatureAlgo(VictoriabankClient::P_SIGN_HASH_ALGO_SHA256)
    ->setBackRefUrl('https://www.example.com');

SDK usage examples

Generate payment authorization request form

$authorizeRequest = $vbClient->generateOrderAuthorizeRequest(
    '123',
    123.45,
    'MDL',
    'Order #123',
    'TEST COMPANY SRL',
    'https://www.example.com',
    'Chisinau, Moldova',
    'example@example.com'
);

$html = $vbClient->generateHtmlForm($VB_BASE_URI, $authorizeRequest);
echo $html;

Validate bank notification callback signature

try {
    $isValid = $vbClient->validateResponse($_POST);
    if ($isValid) {
        // Payment authorized/completed successfully
        // Process the order (e.g. update status)

        $rrn     = $_POST['RRN'];
        $int_ref = $_POST['INT_REF'];
    } else {
        // Handle invalid signature or response data
        echo 'Error: Invalid response';
    }
} catch (\Exception $e) {
    // Handle other errors (e.g. log error, invalid data, duplicate transaction, declined)
    echo 'Error: ' . $e->getMessage();
}

Complete authorized payment

$completeResponse = $vbClient->orderComplete(
    '123',
    123.45,
    'MDL',
    $rrn,
    $int_ref
);

Refund payment

$reverseResponse = $vbClient->orderReverse(
    '123',
    123.45,
    'MDL',
    $rrn,
    $int_ref
);

Check order payment status

$checkResponse = $vbClient->orderCheck('123', VictoriabankClient::TRTYPE_AUTHORIZATION);