How to prevent shopping cart alterations in another tab when paymentintent is already created?
Has anyone figured out a solution to this? I seem to have gotten to the same conclusion with no solution.
If I were to go the my app's checkout page, the payintent is created in the backend (explained the process below). So no after the payIntent is created, if i open a new tab and go the menu and add a new menu item, Firestore will show the new (correct) total, but since the payment intent is created stripe charges the old (wrong) total.
What I am doing is
Every time the page loads, I send a GET request to my backend which verifies the identity of the user (using Firestore/Firebase).
Checks if there is a payment intent (payment intents are stored in Firestore corresponding to the user)
- A. if payIntent does not exist under user create one
- B. if payIntent does exist retrieve payintent from stripe and check if it has
status === succeeded
. IF it has succeeded create a new one and if it has not succeeded update the old one. The amount for all payIntents is calculated using total in Firestore in the backend
(and of course if the users cart is empty a payIntent is not created)
Send back to the frontend the
payIntent.clientSecret
and cart items to populate pageFrom the front end using stripe elements and
confirmPayment
confirm the payment
(using ngrok the page loads in about 800-1200ms so not too bad I think)
Possible solutions are using webhooks, when payIntent is processing check and update the pricing but that seems like a duct-taped solution (if it were to even work in the first place) OR using webhooks when payment has succeeded update the payment, again seems like a duct tape solution (if it were to even work...). Possible solution:
3 confirmPayment
s in the backend but according to documentation that takes away 3ds authentication which is the reason I am doing confirmPayment
in the frontend anyways..