| Titre | macrozheng mall latest master before fix Improper Authorization |
|---|
| Description | An improper authorization vulnerability exists in mall-portal order payment success handling.
The endpoint POST /order/paySuccess accepts user-controlled orderId and payType parameters and directly updates an unpaid order to paid status without verifying that the order belongs to the currently authenticated portal member and without validating a trusted payment-provider callback, transaction id, amount, or signature.
Source-level chain:
POST /order/paySuccess?orderId=<id>&payType=<type>
→ OmsPortalOrderController.paySuccess(orderId, payType)
→ OmsPortalOrderServiceImpl.paySuccess(orderId, payType)
→ update oms_order set status=1 where id=orderId and status=0 and delete_status=0
→ portalOrderDao.getDetail(orderId)
→ reduceSkuStock(...) for each order item
The missing ownership and payment-proof checks allow an authenticated portal member to force an unpaid order into paid/to-ship state and trigger inventory reduction. If the orderId belongs to another user, this also becomes a business-logic IDOR issue.
Impact includes unauthorized payment-state transition, order integrity compromise, and inventory reduction without verified payment. |
|---|
| La source | ⚠️ https://github.com/macrozheng/mall |
|---|
| Utilisateur | feng123123 (UID 95215) |
|---|
| Soumission | 26/04/2026 07:34 (il y a 2 mois) |
|---|
| Modérer | 23/05/2026 16:06 (27 days later) |
|---|
| Statut | Dupliqué |
|---|
| Entrée VulDB | 322183 [macrozheng mall jusqu’à 1.0.3 /order/paySuccess orderId élévation de privilèges] |
|---|
| Points | 0 |
|---|