developertugrul / paytr-laravel-client
Laravel için güncel, güvenli ve kapsamlı PayTR ödeme entegrasyon paketi. Güncel PayTR API dokümantasyonuna tam uyumlu.
Installs: 40
Dependents: 0
Suggesters: 0
Security: 0
Stars: 12
Watchers: 0
Forks: 2
Open Issues: 0
Language:HTML
Requires
- php: >=8.0
- guzzlehttp/guzzle: ^7.0
- illuminate/support: >=8.0|^9.0|^10.0|^11.0
Requires (Dev)
- orchestra/testbench: ^7.0|^8.0
- phpunit/phpunit: ^9.0|^10.0
README
ℹ️ Kapsamlı Türkçe Dokümantasyon:
Bu paketin tüm fonksiyonlarını, kullanım senaryolarını ve testlerini detaylıca incelemek için modern, interaktif HTML dokümantasyonunu kullanabilirsiniz:
html/index.html
dosyasını tarayıcınızda açın.- Veya çevrimiçi olarak: https://tugrulyildirim.com/opensource/paytr-laravel-client
Not: Bu paket MIT lisansı ile yayınlanmıştır ve tamamen açık kaynaklıdır (opensource). Dilediğiniz gibi kullanabilir, dağıtabilir ve geliştirebilirsiniz.
PayTR Laravel Client
Laravel için güncel, güvenli ve kapsamlı PayTR ödeme entegrasyon paketi. Güncel PayTR API dokümantasyonuna tam uyumlu.
🚀 Özellikler
✅ Temel Özellikler
- Ödeme Yapma: Direct API, iFrame API desteği
- Ödeme Durumu Sorgulama: Gerçek zamanlı ödeme durumu
- İptaller: Tam ve kısmi iptal işlemleri
- İadeler: Tam ve kısmi iade işlemleri
- Kart Saklama: PCI-DSS uyumlu kart saklama ve yönetimi
🔥 Gelişmiş Özellikler
- Webhook Desteği: Otomatik bildirim sistemi
- Test/Sandbox Modu: Geliştirme ortamı desteği
- Güvenlik: HMAC imzalama, IP kontrolü, SSL doğrulama
- Hata Yönetimi: Kapsamlı exception handling
🛡️ Güvenlik Özellikleri
- Tüm hassas veriler .env ve config ile yönetilir
- Tüm API çağrıları HMAC/Hash ile imzalanır
- Güçlü input validation ve sanitizasyon
- Sensitive data asla loglanmaz
- Webhooks için IP ve signature doğrulama
- SSL sertifika doğrulama
- User-Agent header ile güvenlik
📦 Kurulum
composer require developertugrul/paytr-laravel-client php artisan vendor:publish --tag=paytr-config
⚙️ Konfigürasyon
.env
dosyanıza aşağıdaki satırları ekleyin:
PAYTR_MERCHANT_ID=xxxx PAYTR_MERCHANT_KEY=xxxx PAYTR_MERCHANT_SALT=xxxx PAYTR_DEBUG=false PAYTR_SANDBOX=true PAYTR_WEBHOOK_SECRET=your_webhook_secret PAYTR_ALLOWED_IPS=192.168.1.1,192.168.1.2 PAYTR_TIMEOUT=30 PAYTR_DEFAULT_TIMEOUT=0 PAYTR_VERIFY_SSL=true PAYTR_DIRECT_API_URL=https://www.paytr.com/odeme
PAYTR_SANDBOX
ayarı Direct API taleplerinde test_mode
değerini otomatik olarak belirler.
Not: PayTR,
user_ip
değerinin gerçek IP adresi olmasını bekler ve bu bilgiyi doğrular. Lokal geliştirme yaparkenrequest()->ip()
sonucu (örn.127.0.0.1
) geçersiz sayılır. Bu nedenle test ortamındauser_ip
parametresini makinenizin public IP adresiyle (örneğin.env
içindePAYTR_USER_IP
tanımlayarak) göndermelisiniz. Bu uyarı PayTR dokümantasyonunda da belirtilmektedir.
PAYTR_WEBHOOK_SECRET
mutlaka tanımlanmalıdır, aksi halde gelen webhook
istekleri imza doğrulamasından geçmeyecek ve reddedilecektir.
🔄 Versiyon Yönetimi
Bu paket için versiyon yönetimi otomatik olarak yapılmaktadır. Yeni bir versiyon yayınlamak için:
Otomatik Versiyon Güncelleme
# Patch versiyonu (hata düzeltmeleri) - 1.0.0 -> 1.0.1 php version-update.php patch # Minor versiyonu (yeni özellikler) - 1.0.0 -> 1.1.0 php version-update.php minor # Major versiyonu (büyük değişiklikler) - 1.0.0 -> 2.0.0 php version-update.php major
Manuel Versiyon Güncelleme
composer.json
dosyasındakiversion
alanını güncelleyin- Git tag oluşturun:
git add composer.json git commit -m "Bump version to 1.0.1" git tag -a v1.0.1 -m "Version 1.0.1" git push origin main --tags
Versiyon Semantik Anlamları
- Patch (1.0.0 -> 1.0.1): Hata düzeltmeleri, güvenlik yamaları
- Minor (1.0.0 -> 1.1.0): Yeni özellikler, geriye uyumlu değişiklikler
- Major (1.0.0 -> 2.0.0): Büyük değişiklikler, geriye uyumsuz güncellemeler
🎯 Kullanım Örnekleri
📦 Sepet Formatı
PayTR API'de sepet verisi özel formatta gönderilmelidir:
// PayTR Sepet Formatı: [['Ürün Adı', 'Fiyat', 'Adet'], ...] $basket = [ ['Test Ürün 1', '100.00', 1], // [ürün_adı, fiyat, adet] ['Test Ürün 2', '50.50', 2], // [ürün_adı, fiyat, adet] ['Test Ürün 3', '25.25', 3], // [ürün_adı, fiyat, adet] ]; // Paket otomatik olarak sepeti base64_encode(json_encode(...)) ile kodlar
Temel Ödeme İşlemleri
use Paytr\Facades\Paytr; // Direct API ile ödeme $response = Paytr::payment()->pay([ // Zorunlu parametreler (otomatik alınır: merchant_id, user_ip, test_mode, debug_on, client_lang) 'merchant_oid' => 'TEST_' . time(), // Benzersiz sipariş numarası 'email' => 'customer@example.com', 'payment_amount' => 100.00, // PayTR'de ondalık nokta kullanılır 'payment_type' => 'card', 'installment_count' => 0, 'currency' => 'TL', 'non_3d' => 0, 'request_exp_date' => date('Y-m-d H:i:s', strtotime('+1 hour')), // Müşteri bilgileri 'user_name' => 'John Doe', 'user_address' => 'İstanbul, Türkiye', 'user_phone' => '5551234567', // URL'ler (doğru isimlendirme) 'merchant_ok_url' => 'https://example.com/success', 'merchant_fail_url' => 'https://example.com/fail', // Sepet (PayTR formatında) 'basket' => [ ['Test Ürün', '100.00', 1], // [ürün_adı, fiyat, adet] ], // Direct API için zorunlu kart bilgileri 'cc_owner' => 'John Doe', 'card_number' => '4355084355084358', 'expiry_month' => '12', 'expiry_year' => '25', 'cvv' => '000', // Opsiyonel parametreler 'lang' => 'tr', 'sync_mode' => 0, // 0: async, 1: sync 'non3d_test_failed' => 0, 'card_type' => '', // Boş bırakılabilir ]); // iFrame API ile token oluşturma $token = Paytr::payment()->createIframeToken([ 'merchant_oid' => 'TEST_' . time(), 'email' => 'customer@example.com', 'payment_amount' => 100.00, 'user_name' => 'John Doe', 'user_address' => 'İstanbul, Türkiye', 'user_phone' => '5551234567', 'merchant_ok_url' => 'https://example.com/success', 'merchant_fail_url' => 'https://example.com/fail', 'basket' => [ ['Test Ürün', '100.00', 1], // [ürün_adı, fiyat, adet] ], ]); // Ödeme durumu sorgulama $status = Paytr::payment()->getPaymentStatus('ORDER123');
İptal İşlemleri
// Tam iptal Paytr::cancel()->cancel('ORDER123'); // Kısmi iptal Paytr::cancel()->partialCancel('ORDER123', 5000); // 50 TL
Kart Saklama
// Yeni kart kaydetme $cardToken = Paytr::card()->storeCard([ 'customer_id' => 'CUST123', 'cc_owner' => 'John Doe', 'card_number' => '4111111111111111', 'expiry_month' => '12', 'expiry_year' => '2025', 'cvv' => '123', ]); // Kayıtlı kartla ödeme Paytr::card()->payWithCard($cardToken, [ 'amount' => 10000, 'merchant_oid' => 'ORDER123', 'installment_count' => 0, ]); // Kartları listeleme $cards = Paytr::card()->listCards('CUST123'); // Kart silme Paytr::card()->deleteCard($cardToken);
Webhook İşleme
PayTR webhook'larının doğruluğunu kontrol etmek için paytr.signature
middleware'ini kullanın. Middleware, gelen isteğin gövdesi ile X-PayTR-Signature
başlığını karşılaştırarak imzayı doğrular.
// routes/paytr.php dosyasında Route::post('/paytr/webhook', [WebhookController::class, 'handle']) ->middleware('paytr.signature');
Gelişmiş PayTR API Özellikleri
use Paytr\Facades\Paytr; // 1. Link ile ödeme oluşturma $link = Paytr::link()->createLink([ 'email' => 'customer@example.com', 'amount' => 10000, 'user_name' => 'John Doe', 'user_address' => 'İstanbul', 'user_phone' => '5551234567', 'basket' => [ ['name' => 'Ürün 1', 'price' => 10000, 'quantity' => 1], ], ]); // Link silme Paytr::link()->deleteLink($link['link_id']); // Link SMS/Email bildirimi Paytr::link()->sendLinkNotification($link['link_id'], 'sms'); // 2. Ön Provizyon (Pre-Provision) Paytr::payment()->preProvision([ 'merchant_oid' => 'ORDER123', 'email' => 'customer@example.com', 'amount' => 10000, 'user_name' => 'John Doe', 'user_address' => 'İstanbul', 'user_phone' => '5551234567', 'basket' => [ ['name' => 'Ürün 1', 'price' => 10000, 'quantity' => 1], ], ]); // 3. EFT/Havale iFrame ile ödeme Paytr::payment()->createEftIframe([ 'merchant_oid' => 'ORDER123', 'email' => 'customer@example.com', 'amount' => 10000, 'user_name' => 'John Doe', 'user_address' => 'İstanbul', 'user_phone' => '5551234567', 'basket' => [ ['name' => 'Ürün 1', 'price' => 10000, 'quantity' => 1], ], ]); // 4. Platform Transfer işlemleri Paytr::platform()->createTransfer([ 'amount' => 10000, 'iban' => 'TR000000000000000000000000', 'description' => 'Alt bayi ödemesi', ]); Paytr::platform()->getTransferResult('TRANSFER_ID'); Paytr::platform()->getReturningPayments([ 'date_start' => '2024-01-01', 'date_end' => '2024-01-31', ]); Paytr::platform()->sendReturningPayment([ 'trans_id' => '123456', 'amount' => 5000, 'iban' => 'TR000000000000000000000000', 'name' => 'John Doe', ]); // 5. BKM Express ile ödeme Paytr::payment()->payWithBkmExpress([ 'merchant_oid' => 'ORDER123', 'email' => 'customer@example.com', 'amount' => 10000, 'user_name' => 'John Doe', 'user_address' => 'İstanbul', 'user_phone' => '5551234567', 'basket' => [ ['name' => 'Ürün 1', 'price' => 10000, 'quantity' => 1], ], ]); // 6. Taksit oranı sorgulama Paytr::payment()->getInstallmentRates('411111'); // 7. BIN sorgulama Paytr::payment()->lookupBin('411111'); // 8. İşlem detayı sorgulama Paytr::payment()->getTransactionDetail('ORDER123'); // 9. Ödeme raporu (statement) Paytr::payment()->getPaymentStatement([ 'date_start' => '2024-01-01', 'date_end' => '2024-01-31', ]); // 10. Ödeme detayı sorgulama Paytr::payment()->getPaymentDetail('PAYMENT_ID'); // 11. İade durumu sorgulama Paytr::refund()->getRefundStatus('ORDER123'); // 12. Tekrarlayan ödeme (recurring) Paytr::card()->recurringPayment($cardToken, [ 'amount' => 10000, 'merchant_oid' => 'ORDER123', 'installment_count' => 0, ]);
🔧 Piyasadaki Diğer Kütüphanelerden Farklar
Özellik | Bu Paket | Diğer Kütüphaneler |
---|---|---|
Direct API | ✅ | ✅ |
iFrame API | ✅ | ✅ |
Kart Saklama | ✅ | ❌ |
Webhook Güvenliği | ✅ | ❌ |
SSL Doğrulama | ✅ | ❌ |
User-Agent Header | ✅ | ❌ |
Tam Yorumlu Kod | ✅ | ❌ |
Kapsamlı Testler | ✅ | ❌ |
Güncel API Uyumluluğu | ✅ | ❌ |
🧪 Test
./vendor/bin/phpunit
📚 API Dokümantasyonu
Detaylı API dokümantasyonu için PayTR Developer Portal adresini ziyaret edin.
🤝 Katkıda Bulunma
- Fork edin
- Feature branch oluşturun (
git checkout -b feature/amazing-feature
) - Commit edin (
git commit -m 'Add amazing feature'
) - Push edin (
git push origin feature/amazing-feature
) - Pull Request oluşturun
📄 Lisans
Bu proje MIT lisansı altında lisanslanmıştır. Detaylar için LICENSE
dosyasına bakın.
🆘 Destek
- GitHub Issues: GitHub Issues
- Email: iletisim@tugrulyildirim.com
- PayTR Destek: PayTR Destek Merkezi
- Whatsapp Destek: Whatsapp İletişim
🔄 Changelog
v1.0.0
- İlk sürüm
- Güncel PayTR API uyumluluğu
- Direct API ve iFrame API desteği
- Kart saklama ve yönetimi
- Webhook güvenliği
- SSL doğrulama
- Kapsamlı hata yönetimi