Description
The Booking Package plugin for WordPress is vulnerable to Price Manipulation in versions up to, and including, 1.7.06 This is due to the intentForStripe() function passing user-controlled $_POST['amount'] directly to the Stripe PaymentIntent API without validation, and the commitStripe() function ignoring the server-calculated amount when confirming the payment. While the server correctly calculates the booking cost via getAmount() based on services, guests, taxes, and coupons, this calculated amount is never validated against or used to update the PaymentIntent because the critical code in CreditCard.php that would include the calculated amount in the PaymentIntent update is commented out. This makes it possible for unauthenticated attackers to book services at arbitrary prices (e.g., $0.01 instead of $500.00) by manipulating the amount parameter during PaymentIntent creation and completing the booking with the fraudulent payment.
Problem types
CWE-472 External Control of Assumed-Immutable Web Parameter
Product status
Any version
Timeline
| 2026-04-27: | Disclosed |
Credits
momopon1415
References
www.wordfence.com/...-6ca6-42d8-ab0a-152d9c95945c?source=cve
plugins.trac.wordpress.org/...package/trunk/lib/Schedule.php
plugins.trac.wordpress.org/...e/tags/1.7.04/lib/Schedule.php
plugins.trac.wordpress.org/...ckage/trunk/lib/CreditCard.php
plugins.trac.wordpress.org/...tags/1.7.04/lib/CreditCard.php
plugins.trac.wordpress.org/...ckage/trunk/lib/CreditCard.php
plugins.trac.wordpress.org/...tags/1.7.04/lib/CreditCard.php
plugins.trac.wordpress.org/...package/trunk/lib/Schedule.php
plugins.trac.wordpress.org/...e/tags/1.7.04/lib/Schedule.php
plugins.trac.wordpress.org/...%2Fbooking-package/tags/1.7.07