mirror of
https://github.com/mewebstudio/pos.git
synced 2026-04-26 09:55:52 +03:00
[GH-ISSUE #227] Deniz Bank 3d çekim hatası #123
Labels
No labels
PayFlexV4
TROY
akbankpos
bug
duplicate
enhancement
garanti
help wanted
isbank
kuveyt
payten
posnet
pull-request
vakifbank
ziraat
No milestone
No project
No assignees
1 participant
Notifications
Due date
No due date set.
Dependencies
No dependencies set.
Reference
starred/pos#123
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @sekizlipenguen on GitHub (Aug 9, 2024).
Original GitHub issue: https://github.com/mewebstudio/pos/issues/227
Selamlar,
@nuryagdym deniz bank entegrasyonunda ödeme başarılı olmasına rağmen declined dönüşü alıyorum. Bu arada tek tek yeni versiyonda kontrol etmeye başladım.
iş bankası çalışıyor.
ak bank çalışıyor.
deniz bank başarısız diyor ancak çekiyor loglar aşağıda;
'class' => Mews\Pos\Gateways\InterPos::class,
raw datayı kontrol ettiğimde 3d sonrasın dönüşte şu değerler geliyor.
array:39 [▼ // vendor/mews/pos/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php:337
"Version" => ""
"MerchantID" => ""
"ShopCode" => "gizlendi"
"TxnStat" => "Y"
"MD" => "gizlendi"
"RetCode" => ""
"RetDet" => ""
"VenderCode" => ""
"Eci" => "02"
"PayerAuthenticationCode" => "gizlendi="
"PayerTxnId" => ""
"CavvAlg" => ""
"PAResVerified" => "True"
"PAResSyntaxOK" => "True"
"Expiry" => ""
"Pan" => "gizlendi**gizlendi"
"OrderId" => "gizlendi"
"PurchAmount" => "1"
"Exponent" => ""
"Description" => ""
"Description2" => ""
"Currency" => "949"
"OkUrl" => "gizlendi"
"FailUrl" => "gizlendi"
"3DStatus" => "1"
"AuthCode" => ""
"HostRefNum" => "hostid"
"TransId" => ""
"TRXDATE" => ""
"CardHolderName" => ""
"mdStatus" => "1"
"ProcReturnCode" => ""
"TxnResult" => ""
"ErrorMessage" => ""
"ErrorCode" => ""
"Response" => ""
"HASH" => "gizlendi="
"HASHPARAMS" => "Version:PurchAmount:Exponent:Currency:OkUrl:FailUrl:MD:OrderId:ProcReturnCode:Response:mdStatus:"
"HASHPARAMSVAL" => "gizlendi"
]
geçici çözüm için şunu yaptım sanıyorum ki şu 2 değer 1 geldiğinde çekim başarılı da demek.
if ($payment->isSuccess() || ($response['all']['mdStatus'] == 1 && $response['all']['3DStatus'] == 1))
ek olarak banka ile iletişime geçtik aşağıdaki gibi dönüş sağlandı.
şu şekilde yazdım dönüş beklemekteyim.
@sekizlipenguen commented on GitHub (Aug 9, 2024):
ek olarak bankadan gelen cevap;
Merhaba,
3d doğrulamadan sonra dönen cevaptaki proctretrun parametresini değil, doğrulamadan sonra yaptığınız provizyon istek cevabındaki proctretrun değerini kontrol eder misiniz ?
3d pay olarak işlem yapmış olsaydınız tek bir cevap dönerdi.
3dmodel işlemlerinde ise iki istek yapılıyor ve iki cevap dönüyor biri doğrulamanın cevabı diğeri provizyon cevabı.
3d doğrulama sonrası aşağıdaki cevap dönüyor.
1
Sonrasında siz aşağıdaki provizyon isteğini yapıyorsunuz
Auth
Provizyon cevabı da aşağıdaki gibi iletilmiş.
ProcReturnCode=00;;HostRefNum=hostid;;AuthCode=
@nuryagdym commented on GitHub (Aug 9, 2024):
Sorun buyuk ihtimalle kutuphanede, bankayla ilgili degil.
Banktan gelen cevaba gore ve
"3DStatus" => "1"ve"mdStatus" => "1", kutuphane zaten"3DStatus" => "1"kontrolu yapiyor. Bu sekilde kontrol etmen hatali, cunku($response['all']['mdStatus'] == 1 && $response['all']['3DStatus'] == 1)odemenin basarili oldugu anlamina gelmez. 3D otorizasyonun basarili oldugu anlamina gelir. Basarili ise provizyon/para cekme islemi yapiyoruz.Yani sorun ya provizyon sonucunu islerken olur diye tahmin ediyorum.
Bu satirda
github.com/mewebstudio/pos@164aa33c8d/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php (L337)bu$raw3DAuthResponseData, $rawPaymentResponseDataiki array parameterlinin dump'ni paylasir misin@sekizlipenguen commented on GitHub (Aug 9, 2024):
selamlar,
şu aşamada yaptım ancak bunlar da sorunlu galiba.
$raw3DAuthResponseData =
array:39 [▼ // vendor/mews/pos/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php:337
"Version" => ""
"MerchantID" => ""
"ShopCode" => "gizlendi"
"TxnStat" => "Y"
"MD" => "gizlendi"
"RetCode" => ""
"RetDet" => ""
"VenderCode" => ""
"Eci" => "02"
"PayerAuthenticationCode" => "gizlendi="
"PayerTxnId" => ""
"CavvAlg" => ""
"PAResVerified" => "True"
"PAResSyntaxOK" => "True"
"Expiry" => "gizlendi"
"Pan" => "gizlendi*****gizlendi"
"OrderId" => "gizlendi"
"PurchAmount" => "1"
"Exponent" => ""
"Description" => ""
"Description2" => ""
"Currency" => "949"
"OkUrl" => "gizlendi"
"FailUrl" => "gizlendi"
"3DStatus" => "1"
"AuthCode" => ""
"HostRefNum" => "hostid"
"TransId" => ""
"TRXDATE" => ""
"CardHolderName" => ""
"mdStatus" => "1"
"ProcReturnCode" => ""
"TxnResult" => ""
"ErrorMessage" => ""
"ErrorCode" => ""
"Response" => ""
"HASH" => "gizlendi/gizlendi="
"HASHPARAMS" => "Version:PurchAmount:Exponent:Currency:OkUrl:FailUrl:MD:OrderId:ProcReturnCode:Response:mdStatus:"
"HASHPARAMSVAL" => "gizlendi"
]
$rawPaymentResponseData
array:39 [▼ // vendor/mews/pos/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php:337
"Version" => ""
"MerchantID" => ""
"ShopCode" => "gizlendi"
"TxnStat" => "Y"
"MD" => "gizlendi"
"RetCode" => ""
"RetDet" => ""
"VenderCode" => ""
"Eci" => "02"
"PayerAuthenticationCode" => "gizlendi="
"PayerTxnId" => ""
"CavvAlg" => ""
"PAResVerified" => "True"
"PAResSyntaxOK" => "True"
"Expiry" => ""
"Pan" => "gizlendi**gizlendi"
"OrderId" => "gizlendi"
"PurchAmount" => "1"
"Exponent" => ""
"Description" => ""
"Description2" => ""
"Currency" => "949"
"OkUrl" => "gizlendi"
"FailUrl" => "gizlendi"
"3DStatus" => "1"
"AuthCode" => ""
"HostRefNum" => "hostid"
"TransId" => ""
"TRXDATE" => ""
"CardHolderName" => ""
"mdStatus" => "1"
"ProcReturnCode" => ""
"TxnResult" => ""
"ErrorMessage" => ""
"ErrorCode" => ""
"Response" => ""
"HASH" => "gizlendi/gizlendi="
"HASHPARAMS" => "Version:PurchAmount:Exponent:Currency:OkUrl:FailUrl:MD:OrderId:ProcReturnCode:Response:mdStatus:"
"HASHPARAMSVAL" => "gizlendi"
]
$txType
"pay" // vendor/mews/pos/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php:337
$paymentModel
"3d" // vendor/mews/pos/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php:337
@nuryagdym commented on GitHub (Aug 9, 2024):
Interpos'un test ortami hesap bilgileri ve test kartlari varsa epostama gonderir misin. IP kisitlamasi yoksa ben kendim test ortamda deneyebilirim. Elimde calisan hesap bilgileri olmadigindan hic basarili odeme deneme sansim olmadi.
Burda anlamadigim:
ProcReturnCodeveAuthCodedegerleri, bankanin da dedigi gibi, bosh olmamasi gerekiyor. Basarili odemedeProcReturnCode="00"olmasi gerekiyor.Eger bu odeme basarili bir odeme ise (yani cekim yapildiysa) bankanin gonderdigi response'da sorun var.
Sen istersen, basarili odeme olduguna emin olup bankaya provizyon odeme sunucu "ProcReturnCode" => "" olan cevap aliyorum diye yaz. emaile
$rawPaymentResponseDataicerigini de eklersen iyi olur.@sekizlipenguen commented on GitHub (Aug 9, 2024):
Bize provizyon cevabını aşağıdaki gibi ilettiklerini söylüyorlar senden çıkan her şeyi baya göstermişler acaba sen onlardan dönen şu değeri cevirirken mi hata yapıyorsun bu değeri nerede yolluyorsun ve alıyorsun tam olarak ona göre oraya bir dd yapayım istersen?
[20240809 10:40:33:987]
@sekizlipenguen commented on GitHub (Aug 9, 2024):
Selam,
Mesela şurada veriler doğru geliyor.
interpos.php - 123 satırda
dd($request->request->all()); yazdırdığımda
@sekizlipenguen commented on GitHub (Aug 9, 2024):
Bunlar galiba bir şeyleri değiştirdiler @nuryagdym şu an doğru gelmeye başladı. Bir problem kalmadı gibi bu nasıl olabilir sence?
@nuryagdym commented on GitHub (Aug 9, 2024):
kutuphanede hata varmis:
burasini
github.com/mewebstudio/pos@164aa33c8d/src/DataMapper/ResponseDataMapper/InterPosResponseDataMapper.php (L71-L75)burdaki kodu su sekilde degistirerek:
dener misin.
denemeden once senin ekledigin if checkleri'de kaldirman gerekiyor, sadece su sekilde olacak if check
Eger sorun cozulurse epostama bu koddan bastigin responselari json olarak rice edecegim:
Istersen gizli bilgileri arasindan silebilirsin.
Birde bu satirin ustune
github.com/mewebstudio/pos@164aa33c8d/src/Gateways/InterPos.php (L188)ekleyerek sonucunu rica ederim.
Bunlardan unit testler olusturup, bir sonraki guncellemelerde bu tarz regression sorunu olmayacak sekilde guncellerim.
@sekizlipenguen commented on GitHub (Aug 10, 2024):
Selamlar,
aşağıdaki kod sorunu çözdü. gerekli dataları sana mail olarak gönderdim.