Bu dokümanda Garanti BBVA Fraud Modülü entegrasyonu yapacak işyerleri için gereksinimler detaylandırılmıştır.
Dokümandaki bilgilere ek olarak aşağıdaki link üzerinden de kullanılan endpointler, request/response alan isimleri ve tipleri hata kodları gibi bilgilere ulaşılabilir ve örnek post isteği gönderilebilir.
Başlık | Değer |
---|---|
MerchantId | 7000679 |
Password | 123qweASD/ |
MerchantId | 3424113 |
Password | 123qweASD/ |
Garanti Bankası Güvenlik Platformu Teknik Entegrasyon Dokümanı
Tam yetkili kullanıcı ekranda yer alan "Şifre" input alanlarına ilgili değerlerin giriş yapılması suretiyle işyeri sistemi ve Atalante servisleri arasındaki mesajlaşma esnasında encoded hash değeri oluşturulurken kullanılacak şifreyi belirler.
Tam yetkili kullanıcı Fraud Modülüne ilk eriştiğinde bu değer sistemde default olarak tutulmaktadır.
Kullanıcı belirlediği şifreyi "Şifre", "Şifre Tekrar" alanlarına girerek ve ekranda yer alan captchadaki değerleri ilgili alan yazarak KAYDET butonuna basar ve şifre resetlenir.
Garanti BBVA Fraud Modülü’nde istek mesajları "requestHeader" header tag’i ve içeriği ile gönderilir. "requestHeader" tag’i altında gönderilmesi gereken alanlar ve içerikleri aşağıdaki tabloda detaylandırılmıştır.
Veri Alanı | Zorunluluk | Açıklama | Uzunluk/Format/Değerler |
---|---|---|---|
gvpsMerchantNum | Zorunlu | İlişkilendirilmiş Garanti BBVA işyeri numarasının gönderildiği alandır. | İşyerine Garanti BBVA tarafından tahsis edilen işyeri numarası değeri bu alanda gönderilir. |
hashData | Zorunlu | Gönderilen isteğin güvenliğini sağlamak için kullanılacak bilgi olacaktır.Bu bilgi ile izin verilen işyeri dışında sisteme işlem gönderilmesi engellenecektir. | “hashData” değerinin hesaplanma yöntemi detaylandırılmıştır. |
orderId | Zorunlu | Gönderilecek işlemin sipariş numarasının gönderildiği alandır. | |
transactionType | Zorunlu | İşyerinin provizyon gerçekleştireceği işlem tipi bilgisi bu alanda gönderilmelidir. Tablo 6’da alanın alabileceği değerler yer almaktadır. | |
uniqueId | Zorunlu | Cihaz ID belirme sürecinde işyerine dönülen Unique ID değeridir. | PageLoad süreci bittiğinde elde edilen tekil değer bu alanda gönderilir. 24 karakter uzunluğunda, alfanumeriktir. |
Örnek request header mesaj parçası aşağıda verilmiştir.
Dokümanda yer alan hash hesaplamalarının nasıl yapılacağı bu başlık altında anlatılmaktadır. “hashData” değeri iki aşamalı olarak hesaplanmaktadır.
HashData= SHA1(MerchantNum&TransactionType&OrderID&UniqeuID&HashedPassword)
HashedPassword: UPPERCASE (SHA1 (Password&MerchantNum))
8 karakterden az olan isyeri numaraları için numaranın başına 8 haneye tamamlayacak şekilde 0 eklenmelidir.
Örnek 1;
İşyeri numarası: 123456
Hesaplamaya eklenecek işyeri numarası: 00123456
Örnek 2;
İşyeri numarası: 1234567
Hesaplamaya eklenecek işyeri numarası: 01234567
8 karakter olan isyeri numaraları için işyeri numarasının başına ekleme yapılmadan olduğu gibi yazılacaktır.
Örnek;
İşyeri numarası: 12345678
Hesaplamaya eklenecek işyeri numarası: 12345678
8 karakterden fazla olan isyeri numaraları için işyeri numarası 8 hane olacak şekilde, işyeri numarasının sağından 1 ya da daha fazla karakter kırpılarak hash hesabına dahil edilecektir.
Örnek 1;
İşyeri numarası: 123456780
Hesaplamaya eklenecek işyeri numarası: 12345678
Örnek 2;
İşyeri numarası: 1234567801
Hesaplamaya eklenecek işyeri numarası: 12345678
MerchantNum ve Password değerleri için E-Ticaret Destek ETicaretDestek@garantibbva.com.tr ekibimizden bilgi alabilirsiniz.
Garanti BBVA Fraud Modülü’nü kullanan işyerleri, skor sorgulama isteğinde aşağıda paylaşılan alanları göndererek her bir işlem için skor üretilmesini sağlayabilir.
İşyeri tarafından oluşturulacak mesaj yapısı JSON formatında olmalıdır.
Skor sorgulama isteği örnek mesaj yapısı aşağıda belirtilmiştir.
Skor sorgulama isteği içerisinde " billingDetails" tagı fatura detay bilgileri gönderilmelidir. Skor sorgulama isteği içerisinde gönderilecek alanlar aşağıdaki gibidir.
Veri Alanı | Zorunluluk | Açıklama | Uzunluk/Format/Değerler |
---|---|---|---|
address | Opsiyonel | Fatura açık adresbilgisinin gönderildiği alandır. | Format : Text |
city | Opsiyonel | Fatura şehir bilgisinin gönderildiği alandır. | Format: Tablolar başlığı altındaki Tablo 2 İl Kodları illere karşılık gelen numeric değerler gönderilmelidir. |
country | Opsiyonel | Faturanın ülke bilgisinin gönderildiği alandır. | Format: Tablolar başlığı altında yer alan Tablo 1 Ülke Kodları tablosunda belirtilen 3 haneli digit kodlar şeklindegönderilmelidir. |
district | Opsiyonel | Fatura mahalle/sokak bilsinin gönderildiği alandır. | Format: Tablolar başlığı altındaki Tablo 3 İlçe Kodları ilçelere karşılık gelen numeric değerlergönderilmelidir. |
latitude | Opsiyonel | Enlem bilgisinin gönderildiği alandır. | Format: Numeric |
longitude | Opsiyonel | Boylam bilgisinin gönderildiği alandır. | Format: Numeric |
zipCode | Opsiyonel | Faturanıngönderileceği adresin posta kodu bilgisidir. | Format: Numeric |
Örnek request header mesaj parçacığı aşağıda verilmiştir.
Skorlama isteği sonucunda işyerine aşağıdaki dataları içeren bir cevap yollanacaktır.
Veri Alanı | Açıklama | Uzunluk/Format/Değerler |
---|---|---|
errorType | Error tipi bilgisinin iletildiği alandır. | |
returnCode | İstek cevabına ait sonuç kodunun dönüleceği alandır. | “00” – Success“99” – General Error“01” – Authentication Error “04” – Input Data Error |
responseMsg | Hatalı geri dönüşlerde hata koduna ait cevap metninin dönüleceği alandır. | “00” – Success“99” – General Error“01” – Authentication Error “04” – Input Data Error |
riskScore | Üretilen risk skorunun değeri bu alanda yer alacaktır. | 0 - 10000 arasında bir değer dönecektir. |
riskScoreCutoff | Risk skorunun risk seviyesi bu alanda işyerineİletilecektir. | HR – Yüksek Risk MR – Medium RiskLR – Low Risk |
isInBlacklist | İşyerine işlemin blacklistten dolayı risklendirildiği bilgisi bu alanda iletilecektir. | Blacklistten dolayı risklendirildi ise bu alanda “Y” değeri bulunacaktır. Aksi durumda bu alanda “N” değeri ile dönüş sağlanacaktır. |
tdsInd | İşlem yapılan kartın E-Ticaret izni ve limit yeterlilik durumunu bilgilerini dönen alandır. Bu alanda dönen bilgiler yorumlanarak işlemin 3DS yapılıp yapılmayacağına karar verilebilir.3DS akış üzerinden limit yetersiz kartlar için limit arttırımı, E- Ticaret izni kapalı kartlar için iznin açılması ödeme doğrulama transactionı üzerinden tekseferde yapılabilmektedir. Bu nedenle tdsInd alanı 1 döndüğü durumlarda üye işyeri işlemi 3DS akışa yönlendirerekişlemingerçekleşmesi sağlanabilir. | 0 Limit yeterli, E-Ticaret izniaçık1 Limit yetersiz ya da E-Ticaret izni kapalı durumlarından en az biri |
Başarılı skor sorgulama cevabı örneği aşağıda verilmiştir.
İşlem Blacklist içerisinde yer alan bir işlemse bu durumda işlem için hiç skorlama yapılmadan işlem riskli olarak iletilecektir.
İşlem blackliste takıldı ise işlem için skorlama yapılmaz ve işyerine skor dönmez. Blackliste takılan işlem için işyerine aşağıdaki datayı içeren bir cevap gönderilir.
Veri Alanı | Açıklama | Uzunluk/Format/Değerler |
---|---|---|
isInBlacklist | İşlemin blackliste takılıp takılmadığı bilgisi bu alanda işyerine iletilir. | “Y” – işlem blackliste takılmıştır.“N” – işlem blackliste takılmamıştır. |
blacklistType | İşlem blackliste takıldı ise hangi blaclist tipine takıldığı bilgisi işyerine bu alanda iletilir. | "C"//card number "I"//ip address "D"//deviceid"E"//email"P" //phone number "ID" //national number "NS" //name surname |
Blackliste takılan skor sorgulama cevabı örneği aşağıda verilmiştir.
İşlem işyeri tarafından tanımlanan kurala takıldı ise "ruleEngineResults" tagı altında ilgili kuralın detayları ile aşağıdaki dataları içeren bir cevap mesajı dönecektir.
Veri Alanı | Açıklama | Uzunluk/Format/Değerler |
---|---|---|
catchedRuleMasterId | İşyerinin tanımladığı kural id bilgisidir. | Format : String |
actionCode | İşlem kurala yakalandıktan sonra işyeri tarafından tanımlanan ve ilgili işlem için alınması istenen aksiyon kodudur. | "00";//işlemtemiz"01";//işlemiengelle"02"; //uyarı oluştur |
additionalActionCode | Eğer action code = 02 seçildi ise işyeri tarafından tanımlanan ek aksiyon kodlarıdır. | "01";//3D secure zorunlu "02"; //Şifreli işlemzorunlu"03"; //Ön otorizasyon ile devam "04"; //İşlemi doğrula |
catched | İşlemin kurala yakalanıp yakalanmadığı bilgisi bu alanda iletilir. | true – İşlem kurala yakalandıfalse – İşlem kurala yakalanmadı |
Aşağıda, çeşitli yazılım dilleri kullanılarak yazılmış özel kod örneklerinin linkleri verilmiştir. Tercih ettiğiniz programlama diline ait link üzerinden, önceden belirlenmiş değerlerle yazılmış olan kodları detaylı bir şekilde inceleyebilirsiniz.
Bu örnekler, ilgili işlem tipini içeren kodları içermektedir ve farklı dillerde yazıldığı için çeşitli yaklaşımları ve pratikleri de gözlemleyebilirsiniz. Bu sayede tercih ettiğiniz programlama diline dair daha iyi anlaşılır ve özgün örneklerle çalışma imkanı bulabilirsiniz.
C# Kod Örnekleri için tıklayınız.
VB.Net Kod Örnekleri için tıklayınız.
Java Kod Örnekleri için tıklayınız.
PHP Kod Örnekleri için tıklayınız.
Unutmayın ki bu örnekler ön tanımlı değerlerle yazılmıştır ve gerçek projelerde kullanımı için gerekli uyarlama ve güvenlik önlemleri almanız gerekebilir.
Ülke kodları listesine bu sayfadan ulaşabilirsiniz.
İl kodları listesine bu sayfadan ulaşabilirsiniz.
İlçe kodları listesine bu sayfadan ulaşabilirsiniz.
Ürün kategori kodları listesine bu sayfadan ulaşabilirsiniz.
Transaction type değerleri listesine bu sayfadan ulaşabilirsiniz.
Test kartları listesine bu sayfadan ulaşabilirsiniz.
Sizden haber almak isteriz. Hizmetlerle ilgili sorunlarınız/sorunuz mu var? Bize bununla ilgili ayrıntılı bir e-posta gönderir misiniz?
Bize Soru Gönderin Bize Soru Gönderin