PT-2026-47090 · Packagist · Shopper/Framework

Published

2026-06-05

·

Updated

2026-06-05

·

CVE-2026-47743

CVSS v3.1

8.7

High

VectorAV:N/AC:L/PR:L/UI:R/S:C/C:H/I:H/A:N

Impact

Three related defects on admin Livewire components allowed data tampering, sensitive data disclosure, and stored XSS:
  • IDOR via unlocked properties. Several Livewire components in the admin panel exposed Eloquent model identifiers as public properties without the #[Locked] attribute. An authenticated user could rewrite the wire payload from the browser to target any record id, bypassing the implicit scoping enforced by the page routing.
  • Sensitive data echoed back through Hidden form field. Customers/Create::store() re-passed a Hidden password form field straight into the create payload. The plaintext password was rendered into the HTML and transported through the Livewire snapshot in clear text, exposing credentials in the page DOM and in any logging that captures Livewire payloads.
  • Stored XSS on product barcode. The product barcode field was rendered through DNS1DFacade::getBarcodeHTML() with {!! !!}. An attacker with edit products permission could persist malicious payload in the barcode field that would execute in the browser of any admin user viewing that product, enabling session theft and privileged-action chaining.

Patches

Fixed in v2.8.0:
  • All vulnerable Livewire model identifiers are now marked #[Locked].
  • Customers/Create no longer round-trips the password through a Hidden form field; the plaintext password is hashed at action boundary and never returned to the client.
  • The product barcode rendering now escapes the value before passing it to the barcode generator and the output is wrapped in an <svg> context that does not interpret event handlers.
Upgrade via:
composer require shopper/admin:^2.8

Workarounds

None. Upgrade to v2.8.0.

Fix

XSS

Information Disclosure

IDOR

Weakness Enumeration

Related Identifiers

CVE-2026-47743
GHSA-HR9V-R8R2-HG7J

Affected Products

Shopper/Framework