-
Notifications
You must be signed in to change notification settings - Fork 9
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Approved payments erroneously cancelled #44
Comments
Hi Simon, I can't able to replicate the issue. I am able to place the order .please see the below log file.
|
@mahbub-zip It seems that you processed a payment for the same checkout ID that you cancelled. You need to cancel the one checkout and process the other. Your logs show these two requests with the same checkout ID
Whereas my logs showed the two different checkout IDs
|
@simonworkhouse yes i can see the same checkout id for cancelled and approved. But whatever steps you mentioned i have followed those steps. please have a look on the below video link 09-19-26.mp4 |
@mahbub-zip That's an incomplete video of the process, and your logs indicate that it's fetching the same checkout ID from the database as what's in the request parameters. In our logs we received Which branch are you running these tests on? |
Using master branch. I followed same steps whatever you mentioned. I attached another video. 15-14-04.mp4 |
@mahbub-zip It would be helpful to have the logs tailed at the same time as that order was being placed, but probably not necessary as I think that I may be able to guess what the issue is based on the previous logs that you supplied. As I highlighted previously, your logs indicate that the cancelled order checkout ID is what's provided in the redirect query parameters:
This leads to the question as to why you are being redirected back to Magento with a different checkout ID ( My guess is that it's due to the fact that you are already logged in to your Zip account, so retry all tests in an incognito/private session and only log in once you are about to process the payment. This is just a guess, but if it's incorrect, then we would need to determine why the redirect back to Magento uses the incorrect checkout ID. |
@simonworkhouse I have checked this in an incognito. I cannot replicate the issue. Before redirect to merchant from zip, zip can able to map with latest checkout id. When it is redirect to merchant that time URL has the latest checkout id. In this video i am not showing login process for security reason. I believe this video make you more clear. 17-53-18.mp4 |
@mahbub-zip What mechanism is Zip supposedly using to map the user to the latest checkout ID? Session based? Mapped by order reference? Linked to a Zip account? Or something else? You can clearly see from the logs that I have provided that we are not being redirected to the latest checkout ID. Is there a setting on a merchant account that prevents cancelled orders from being approved? Regardless of this mechanism, the module requires a fix to address situations where multiple payments have been created for an order. |
@simonworkhouse could you please apply this https://github.com/zipMoney/zip.magento2/pull/45/files change on top our latest plugin and let me know is this resolve the issue? |
@mahbub-zip Yes, that fix does appear to resolve the issue. However; it still doesn't necessarily handle multiple checkout IDs/payments in the ideal way. |
@simonworkhouse and @mahbub-zip I am having an identical issue but something I noticed isn't being discussed is the failed requests to the Zip API right before the order is cancelled (your logs are the same as mine in this regard). All our cases are identical with the logs looking like:
Does the extension need a way to handle these errors, possibly with some retry logic instead of simply canceling the order? |
@mahbub-zip as per my comment above - this issue happened again today even after applying the suggested code change above. It happens rarely but it still happens. Any idea? You never replied to my comment above. |
Hey @Swiftless , |
Approved payments erroneously cancelled
An approved payment will be erroneously cancelled if a user has two tabs open on the Zip pay hosted page and chooses to return to the store in one of those tabs and then completes the payment process in the other tab.
Steps to reproduce
This issue is easiest to replicate using two browser tabs and these steps assume that the user is at the payment step of the checkout.
/zippayment/complete/?result=cancelled...
).After completing the payment and returning to the store, logs will first show a call to
/zippayment/complete/?result=approved...
, then a charge request is attempted with loggedCharge Payload:- {"authority":{...
which will receive a 403 with the messageAuthority request - xxxxxxx is not approved.
Upon receiving the 403, the approved order is then erroneously cancelled and the user is shown a generic error page, which likely states something along the lines of "General Error An error occurred while processing your request.".
The cause
The charge request uses the incorrect Zip checkout ID due to
Zip\ZipPayment\Helper\Payload::getAuthority()
fetching this from theadditional_information
field in the quote payment object, which may have changed since the user initially proceeded to the Zip hosted payment page.This incorrect Zip checkout ID is used in the charge payload and results in an error after which the module cancels the order.
The fix
Either use the checkout ID returned by the Zip hosted payment page instead of fetching it from the quote payment, or alternatively, track multiple payments against a quote instead of assuming that there will be only one.
Example logs
The text was updated successfully, but these errors were encountered: