• Tami Sanal POS

Taksit Sorgulama İşlemi Genel Açıklama

Tami üye işyerlerinin kart bilgisinin ilk 8 hanesi veya 6 hane ile query edip kartın bilgilerini ve taksit yapılabilirliğini öğrenecekleri servistir. Yapabileceği taksit seçeneklerini de response içerisinde görüntüleyebilir.

Test/Prod Ortamları API Kullanıcı Bilgisi

Tami üzerinden gerçekleştirilen Sanal POS işlemleri için üye işyerleri test ortamında gerçekleştirmek istedikleri kontrolleri aşağıdaki tabloda verilen üye işyeri bilgilerini kullanabilirler.

Üretim ortamında Tami üzerinden gerçekleştirilecek Sanal POS işlemleri için başvuru yapılarak üye işyeri numarası alınır ve bu bilgilerle işlem geçirilir.

Sandbox test portaline https://sandbox-portal.tami.com.tr adresinden ulaşabilirsiniz. Aşağıda iletilen kullanıcılar ile test portale giriş yapıldığında bu kullanıcıya bağlı işyeri tarafından gerçekleştirilen işlemleri görüntülenebilir. İşlemler iptal/iade edilebilir.

Kullanıcı Telefon Numarası Kullanıcı Şifre Sms / Email Otp İşyeri Numarası Terminal Numarası Secret Key
5346484700 147850 147852 77006950 84006953 0edad05a-7ea7-40f1-a80c-d600121ca51b
5346484709 147850 147852 77006951 84006954 c8581bb6-a4b2-4925-8c94-529fc651399e
5346484803 147850 147852 77006952 84006955 ff7d4895-0c32-4f48-86ab-fb9ecca9f3d7
5346484807 147850 147852 77006953 84006956 33124ff0-0b19-4cf9-b002-13a35eae865b
5346484800 147850 147852 77006954 84006957 7daf9631-e136-4164-9ddb-dd1c02df851d
5346484808 147850 147852 77006956 84006959 fe6f3fff-0434-4932-a27d-bb3dac9de49d

Hash Hesaplama

Bir çok işlem tipi için gönderilen isteğin header bilgisine PG-Auth-Token eklenmelidir. PG-Auth-Token değeri “MerchantNumber:TerminalNumber:Hash” değerlerinden oluşur.

Burada hash hesabı yapılırken üye işyerine ait merchantNumber, terminalNumber ve secretKey bilgileri sha256 ile hashleyip stringe çevrilerek elde edilir.

public class SHA256Example {\n public static String sha256(Long merchantNumber, Long terminalNumber, String secretKey) {\n String text = merchantNumber.toString() + terminalNumber.toString() + secretKey;\n try {\n MessageDigest digest = MessageDigest.getInstance(\"SHA-256\");\n byte[] hash = digest.digest(text.getBytes(StandardCharsets.UTF_8));\n String sha256Hex = DatatypeConverter.printBase64Binary(hash);\n return sha256Hex;\n } catch (NoSuchAlgorithmException e) {\n e.printStackTrace();\n return null;\n }\n }\n }

TAMİ Test Portalı Bilgileri

Tami test portalına https://sandbox-portal.tami.com.tr adresinden erişebilirsiniz. Bu adresten yukarıda iletilen kullanıcılar ile portal ekranını görüntüleyebilirsiniz. 

Üretim ortamı bilgileriniz için https://portal.tami.com.tr adresinden üye olabilir veya e-ticaret destek birimine başvurabilirsiniz.

Taksit Sorgulama İşlemi API Bilgileri

 Test ortamı için "https://sandbox-paymentapi.tami.com.tr/installment/installment-info" adresine istek atılır.

Üretim ortamında yapılacak çalışmalarda ise "https://paymentapi.tami.com.tr/installment/installment-info" url'i kullanılacaktı

İstek Parametreleri ve Açıklamaları

Alan Format Uzunluk (O)psiyonel / (Z)orunlu Açıklama
 binNumber Number 8 Z Detayları öğrenilmek istenen kart numarasının ilk 6 hanesi veya 8 hanesi gönderilmelidir.
securityHash String Z Dokumanda belirtilen şekilde hesaplanıp iletilmesi beklenen değerdir. Eksik veya hatalı iletilirse işlem bankaya yönlendirilmez, hata verilir.

API İstek Örneği

{\n \"binNumber\": \"45438877\",\n \"securityHash\": \"4djd40585YY95U8375wdkdT==\",\n}\n

API İstek Cevabı Örneği

{\n \"bankName\": \"T. GARANTİ BANKASI A.Ş.\",\n \"bankId\": \"62\",\n \"cardType\": \"CREDIT\",\n \"cardOrg\": \"VISA\",\n \"commercial\": false,\n \"rewardType\": \"Bonus\",\n \"force3ds\": false,\n \"forceCvc\": false,\n \"installments\": [\n 1,\n 3,\n 5\n ],\n \"success\": true,\n \"systemTime\": \"2023-09-15T14:05:06.422\",\n \"correlationId\": \"correlation5291\",\n \"isInstallment\": true,\n \"securityHash\": \"74hsjw84746eekro747463ye==\"\n}

İstek Cevabı Parametreleri ve Açıklamaları

Parametre Adı Format Açıklama
bankName String Bankanın adıdır
bankId String Banka EFT kodudur
cardType String Kart tipidir. Debit/Credit
cardOrg String Kart organizasyon bilgisidir. VISA/MASTERCARD/TROY/AMEX vb.
commercial Boolean Kartın kurumsal kart olup olmadığı bilgisidir. true ise kurumsal kart, false ise bireysel kart
rewardType String Kartın ödül grubudur. BONUS, AXESS, CHIP, WORLD vb.
force3ds Boolean Üye işyeri yetkisine bakarak işlemin 3d ile yapılma zorunluluğunu belirtir. true ise işlem 3dsiz gönderildiğinde hata alınacaktır.
forceCvc Boolean Üye işyeri yetkisine bakarak işlemin cvv ile yapılma zorunluluğunu belirtir. true ise işlem cvvsiz gönderildiğinde hata alınacaktır.
installments list Üye işyerinin sorguladı BIN numarasına göre yapılabilecek taksit seçeneklerini verir.
isInstallment Boolean Üye işyeri yetkisine bakarak işlemin taksit ile yapılabilirliğini belirtir. false ise işlem taksitli gönderildiğinde hata alınacaktır.
success Boolean Servisin başarılı cevap verip vermediği durumudur. true ise karta ait bir data bulunduğunu gösterir. false ise karta ait bir data bulunmadığını gösterir
systemTime dateTime Response zamanı
correlationId String Requestte gönderilen istek correlationid bilgisi
errorCode String success: false olması durumunda hata kodu
errorMessage String success: false olması durumunda dönen hatanın açıklaması
securityHash String İşlemin sonucunun doğru kaynaktan geldiğini belirlemek için kullanılacak değer. Belgeler bunun nasıl hesaplanması gerektiğini belirtir.

Security Hash Hesaplama

Yapılacak servis isteklerinde ve gelen servis cevaplarında securityHash alanının hesaplanması için buradaki dokümantasyondan yararlanabilirsiniz. 

Hata Kodları

Hata kodları listesine bu sayfadan ulaşabilirsiniz.

Test Kartları

Test kartları listesine bu sayfadan ulaşabilirsiniz.

Tüm soru ve destek taleplerinde yanındayız.

Soru Sor Soru Sor