PT-2025-45761 · Packagist · Openmage Magento Lts

Published

2025-11-03

·

Updated

2025-11-03

CVSS v4.0

4.6

Medium

VectorAV:N/AC:L/AT:N/PR:H/UI:A/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N

Summary

OpenMage versions v20.15.0 and earlier are affected by a stored Cross-Site Scripting (XSS) vulnerability that could be abused by an admin with direct database access or the admin notification feed source to inject malicious scripts into vulnerable fields. Malicious JavaScript may be executed in a victim’s browser when they browse to the page containing the vulnerable field.

Details

Unescaped translation strings and URLs are printed into contexts inside app/code/core/Mage/Adminhtml/Block/Notification/Grid/Renderer/Actions.php. A malicious translation or polluted data can inject script.
  • Link labels use () without escaping.
  • ’deleteConfirm()’ embeds a message without escaping.

PoC

  1. Add XSS to admin locale (e.g. app/locale/en US/local.csv):
"Read Details","<img src=x onerror=alert(123)>"
"Mark as Read","<script>alert(123)</script>"
  1. Flush Cache. Make sure locale is set to en US.
  2. Add any admin notification (e.g. via test.php)
setData([ 'severity' => Mage AdminNotification Model Inbox::SEVERITY NOTICE, 'date added' => now(), 'title' => 'XSS renderer test', 'description' => 'Testing actions renderer', 'url' => 'https://example.com', // makes the "Read Details" link appear 'is read' => 0, // makes the "Mark as Read" link appear 'is remove' => 0, ])->save(); ``` 4. Open Admin → System → Notifications → Inbox. 5. Profit. ### Impact The vulnerability is only exploitable by an attacker with administrative or translation privileges. Malicious JavaScript may be executed in a victim’s browser when they browse to the admin page containing the vulnerable fields.

Fix

XSS

Found an issue in the description? Have something to add? Feel free to write us 👾

Weakness Enumeration

Related Identifiers

GHSA-QV78-C8HC-438R

Affected Products

Openmage Magento Lts