A pretty simple event registration that allows multiple registrants fails on the final submission and returns this error:
Stripe This PaymentIntent's amount could not be updated because it has a status of requires_capture. You may only update the amount of a PaymentIntent with one of the following statuses: requires_payment_method, requires_confirmation, requires_action.
NOTE: In Test/preview mode.
The same form works with PayPal. A very similar registration form for a different event (single registration only) works as expected. Its frustrating that the general form architecture here requires pre-approval of the payment, but so it is.
Designs
Child items ...
Show closed items
Linked items 0
Link issues together to show that they're related.
Learn more.
I have also encountered this error. When a user selects the number of registrants from the dropdown menu at the top of the page, Civi then separates the ticketing section per registrants, e.g. the first page is only for the first registrant, and second for the second registrant, and so on. Stripe then creates a payment intent based on the number selected in the dropdown * the number of tickets entered on the first page.
Example: Someone misses the "Total for **this ** participant" on the first page and wants to buy tickets for 2 people at $50, and puts a 2 in the dropdown and a 2 in the box for $50 on that first page. When they hit "Continue", Stripe pre-authorizes a payment intent for the amount of $100. Then, on the second page, they see the ticket option again, so they enter another 2 tickets at $50 again, rather than 1 ticket for that second participant only. This results in a total of $200, not $100. When Stripe goes to complete this payment, it tries to update the initial payment intent and fails based on the amounts mismatching.
Example 2: Someone selects 2 from the dropdown menu, and correctly enters one ticket per registrant on each of the two pages. However, if they select a ticket for $50 on the first page, and $60 on the second page, the payment intent will again not match. Stripe will have pre-authorized $100 ($50*2), not $110 ($50+$60), and the payment will fail to complete.
Obviously, if a user selects 2 from the dropdown and only enters 1 ticket per page/registrant at the same price level, the amounts match up and it works, but this is not intuitive and has caused confusion for at least half a dozen people who want to register for our event.
Same setup of a simple multi-participant event. The card box appears on the first participant, and pre-authorises. Then after completing a second participant, which also has a fee, and clicking continue, we get the error:
After the card is authorized, the PaymentIntent status transitions to requires_capture. To capture the authorized funds, make a PaymentIntent capture request. The total authorized amount is captured by default—you can’t capture more than this.
So we can't pre-authorize for one amount, and then add charges for additional participants.
The card details entry form would have to be moved to the last participant page (which I think would be too complex, thinking about CiviCRM's workflow which allows you to move back and forth and skip participants) or the confirmation page?
However the release notes for the latest version of this extension suggest that it was working?
We'd be happy to support this fix with some $$'s ... do you have a rough estimate @mattwire ?
Or, perhaps disable the card pre-authorization per #381 (closed) (this would be our preferred route).
Thank you!
We'd be interested to know how to support this too, as it's causing some headaches for our events teams.
I do not feel confident enough in the code to make a PR to alter this; but would be happy to offer QA or know if there's anything else we can do to help? @mattwire
Sorry, I'm not sure this is fixed @mattwire , using 6.7.8 and shared payment 1.2.8
Using the same steps to reproduce, adding additional participants to a paid event, on the final step we are redirected back to the event page and the error message is now: