Home

Description

Shopper is a Headless e-commerce Admin Panel. Prior to 2.8.0, CreateOrderFromCartAction::execute previously created the Order row before checking and incrementing the discount's total_use counter. Under concurrent checkout pressure (Black Friday, flash sale, viral coupon), the global usage_limit was silently exceeded: orders were committed with the discount fully applied to price_amount while the counter blocked at usage_limit. The merchant had no signal that an over-redemption had occurred. This vulnerability is fixed in 2.8.0.

PUBLISHED Reserved 2026-05-19 | Published 2026-05-29 | Updated 2026-05-29 | Assigner GitHub_M




MEDIUM: 5.9CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:H/A:N

Problem types

CWE-362: Concurrent Execution using Shared Resource with Improper Synchronization ('Race Condition')

Product status

< 2.8.0
affected

References

github.com/shopperlabs/shopper/issues/510 exploit

github.com/...hopper/security/advisories/GHSA-9rh9-hf3w-9fgg

github.com/shopperlabs/shopper/issues/510

github.com/shopperlabs/shopper/pull/511

cve.org (CVE-2026-47741)

nvd.nist.gov (CVE-2026-47741)

Download JSON