w3/garanti-sanalpos
最新稳定版本:v1.0.0
Composer 安装命令:
composer require w3/garanti-sanalpos
包简介
Türkiye Cumhuriyeti Garanti Bankası Sanal POS entegrasyonu için PHP paketi
README 文档
README
Bu paket, Türkiye Cumhuriyeti Garanti Bankası Sanal POS sistemine entegrasyon sağlamak için geliştirilmiştir. 3D Secure ve normal ödeme işlemlerini destekler.
Kurulum
Paketi Composer ile kurabilirsiniz:
composer require w3/garanti-sanalpos
Kullanım
DEBUG mode varsayılan KAPALI dır ENV dosyasında yada Config içerisinde debugMode = true Yaparsanız garanti bankasının kendi debug sayfasına post işlemi gerçekleşir ve oradan aldığınız formu eticaretdestek@garantibbva.com.tr gönderirseniz destek olacaklardır.
Yapılandırma
use W3\GarantiSanalPos\Config; use W3\GarantiSanalPos\GarantiPosClient; // Yapılandırma oluşturma env dosyasında ayar yoksa buraya array olarak girilmeli $config = new Config([ 'merchantId' => 'MERCHANT_ID', 'terminalId' => 'TERMINAL_ID', 'userId' => 'USER_ID', // PROVAUTH 'password' => 'PASSWORD', 'mode' => 'TEST', // veya 'PROD' canlı ortam için 'debugMode' => false, 'storeKey' => 'STORE_KEY' ]); // Yada ENV dosyasnıza aşağıdaki ayarları ekleyin. config içerisinde sadece boş array bırakın yeterli. GARANTI_MERCHANT_ID="" GARANTI_TERMINAL_ID="" GARANTI_USER_ID="" GARANTI_USER_PASSWORD="" GARANTI_MODE="TEST" GARANTI_DEBUG_MODE=false GARANTI_STORE_KEY="" GARANTI_CALLBACK_URL="" // Client oluşturma $client = new GarantiPosClient($config);
3D Secure Ödeme
use W3\GarantiSanalPos\Model\PaymentRequest; use W3\GarantiSanalPos\Enum\Currency; // Ödeme isteği oluşturma $paymentRequest = new PaymentRequest(); $paymentRequest->setOrderId('ORDER_123456') ->setAmount(100.50) // TL cinsinden ->setCurrency(Currency::TRY) ->setCardNumber('4242424242424242') ->setCardExpireMonth('12') ->setCardExpireYear('2025') ->setCardCvv('123') ->setCardHolderName('John Doe') ->setCustomerEmail('john@example.com') ->setInstallment(0); // Tek çekim // 3D Secure başlatma $response = $client->initiate3DPayment($paymentRequest, 'https://example.com/callback'); // 3D Secure sayfasına yönlendirme echo $response->getHtmlContent();
3D Tekrarlı Ödeme / Abonelik
$config = new Config(['recurring' => true]); $client = new GarantiPosClient($config); $paymentRequest = new PaymentRequest(); $paymentRequest->setOrderId('ORDER_'.rand(0,999999999)) ->setAmount(100.50) // TL cinsinden ->setCurrency(Currency::TRY) ->setCardNumber('kart no') ->setCardExpireMonth('skt ay') ->setCardExpireYear('skt yıl 2 hanelı') ->setCardCvv('cvv') ->setCardHolderName('John Doe') ->setCustomerIp('127.0.0.1') ->setInstallment(null) ->setRecurringType('R') // Tekrarlı Ödeme Türü ->setRecurringFrequencyType('M') // Gün (D) - AY (M) - HAFTA (W) ->setRecurringFrequencyInterval(1) // Tekrar Süresi (Ayda 1 ise 1 yazılmalı, 3 ayda bir ise 3 yazılmalı. ) ->setRecurringTotalPaymentNum(12) // Ne kadar tekrar edecek ->setRecurringStartDate(now()->format('Ymd')) // Başlangıç tarihi 20250618 formatında olmalı ->setCustomerEmail('müşteri e posta'); // 3D BAŞLAT $response = $client->initiate3DPayment($paymentRequest,$config->getCallbackUrl()); // DOĞRULAMA SAYFASI GÖSTER echo $response->getHtmlContent();
3D Secure Callback İşleme
// 3D Secure işlemi sonrası callback $response = $client->complete3DPayment($_POST); if ($response->isSuccess()) { echo "Ödeme başarılı. İşlem No: " . $response->getTransactionId(); } else { echo "Ödeme başarısız. Hata: " . $response->getErrorMessage(); }
Normal Ödeme (3D Secure olmadan)
use W3\GarantiSanalPos\Model\PaymentRequest; use W3\GarantiSanalPos\Enum\Currency; // Ödeme isteği oluşturma $paymentRequest = new PaymentRequest(); $paymentRequest->setOrderId('ORDER_123456') ->setAmount(100.50) // TL cinsinden ->setCurrency(Currency::TRY) ->setCardNumber('4242424242424242') ->setCardExpireMonth('12') ->setCardExpireYear('2025') ->setCardCvv('123') ->setCardHolderName('John Doe') ->setInstallment(0); // Tek çekim // Ödeme işlemi $response = $client->makePayment($paymentRequest); if ($response->isSuccess()) { echo "Ödeme başarılı. İşlem No: " . $response->getTransactionId(); } else { echo "Ödeme başarısız. Hata: " . $response->getErrorMessage(); }
Lisans
Bu paket MIT lisansı altında lisanslanmıştır. Detaylar için LICENSE dosyasına bakınız.
统计信息
- 总下载量: 12
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 3
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-06-18