tcgunel / omnipay-qnbfinansbank
Omnipay extension for QNB Finansbank
v2.0.0
2026-03-23 11:37 UTC
Requires
- php: ^8.3
- league/omnipay: ^3
Requires (Dev)
- brianium/paratest: *
- fzaninotto/faker: *
- http-interop/http-factory-guzzle: ^1.2
- laravel/pint: ^1.0
- omnipay/tests: ^4
- phpstan/phpstan: ^1.0
- phpunit/phpunit: ^9
README
QNB Finansbank sanal pos gateway for the Omnipay PHP payment processing library
Omnipay is a framework agnostic, multi-gateway payment processing library for PHP. This package implements QNB Finansbank support for Omnipay.
Installation
composer require tcgunel/omnipay-qnbfinansbank
Available Methods
| Method | Description |
|---|---|
purchase() |
Direct (non-3D) sale or 3D Secure redirect |
completePurchase() |
Complete 3D Secure payment after bank callback |
void() |
Cancel/void a transaction |
refund() |
Refund a transaction (full or partial) |
Supported Features
| Feature | Supported |
|---|---|
| 3D Secure | Yes |
| Non-3D (direct) | Yes |
| Cancel (void) | Yes |
| Refund | Yes |
| BIN lookup | No |
| Installment query | No |
| Sale query | No |
Usage
Gateway Initialization
use Omnipay\Omnipay; $gateway = Omnipay::create('QnbFinansbank'); $gateway->setMerchantId('your_merchant_id'); $gateway->setMerchantUser('your_user_code'); $gateway->setMerchantPassword('your_user_password'); $gateway->setMerchantStorekey('your_store_key'); // Required for 3D Secure $gateway->setTestMode(true); // Use test endpoint
Non-3D Purchase (Direct Sale)
$response = $gateway->purchase([ 'amount' => '100.00', 'currency' => 'TRY', 'transactionId' => 'ORDER-12345', 'secure' => false, 'card' => [ 'number' => '4508034508034509', 'expiryMonth' => '12', 'expiryYear' => '2030', 'cvv' => '000', ], ])->send(); if ($response->isSuccessful()) { echo 'Transaction ID: ' . $response->getTransactionReference(); } else { echo 'Error: ' . $response->getMessage(); }
3D Secure Purchase
$response = $gateway->purchase([ 'amount' => '100.00', 'currency' => 'TRY', 'transactionId' => 'ORDER-12345', 'secure' => true, 'returnUrl' => 'https://yoursite.com/payment/success', 'cancelUrl' => 'https://yoursite.com/payment/fail', 'card' => [ 'number' => '4508034508034509', 'expiryMonth' => '12', 'expiryYear' => '2030', 'cvv' => '000', ], ])->send(); if ($response->isRedirect()) { $response->redirect(); // POSTs card data to the bank 3D Secure page }
Complete 3D Secure Purchase (Callback Handler)
After the bank posts back to your returnUrl:
$response = $gateway->completePurchase([])->send(); if ($response->isSuccessful()) { echo 'Payment confirmed! Transaction: ' . $response->getTransactionReference(); } else { echo 'Payment failed: ' . $response->getMessage(); }
The callback POST fields (ProcReturnCode, AuthCode, OrderId, ErrMsg) are read
directly from $_POST by the request internally.
Void (Cancel)
$response = $gateway->void([ 'orderNumber' => 'ORDER-12345', 'currency' => 'TRY', ])->send(); if ($response->isSuccessful()) { echo 'Transaction voided.'; } else { echo 'Error: ' . $response->getMessage(); }
Refund
$response = $gateway->refund([ 'orderNumber' => 'ORDER-12345', 'amount' => '50.00', 'currency' => 'TRY', ])->send(); if ($response->isSuccessful()) { echo 'Refund processed.'; } else { echo 'Error: ' . $response->getMessage(); }
Hash Algorithm (3D Secure)
SHA1Base64(MbrId + OrderId + PurchAmount + OkUrl + FailUrl + TxnType + InstallmentCount + Rnd + MerchantPass)
Note: MbrId is always 5 for QNB Finansbank.
Endpoints
| Environment | URL |
|---|---|
| Test | https://vpostest.qnbfinansbank.com/Gateway/Default.aspx |
| Production | https://vpos.qnbfinansbank.com/Gateway/Default.aspx |
Key Differences from Denizbank
- Uses
MbrId: 5field in all requests - Uses
ErrMsginstead ofErrorMessagefor error messages - Different endpoint URLs (qnbfinansbank.com vs inter-vpos.com.tr)
Running Tests
composer test
Static Analysis
composer analyse
Code Style
composer lint
License
MIT License. See LICENSE for details.