PT-2026-25427 · Packagist · Craftcms/Cms

Published

2026-03-03

·

Updated

2026-03-03

CVSS v4.0

2.1

Low

VectorAV:N/AC:L/AT:N/PR:N/UI:P/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N/E:P

Overview of all XSS Reports

Multiple stored XSS vulnerabilities were found in Craft CMS. They were split into 4 reports as follows:
ReportWhat's VulnerableWhy Separate
This Report (1)Multiple settings namesTwig Template: includes/forms/checkbox.twig
Report 2Entry Types NameTwig Template: includes/forms/editableTable.twig
Report 3Card Attributes in Field Layouthelpers/Cp.php
Report 4 (Commerce)Product Type NameSource in Commerce, sink in CMS - will report this one via Commerce GHSA
Reports 2, 3, and 4 are clearly distinct locations. For this report (Report 1), it was not clear whether to split or consolidate these 7 bugs. The bug report was consolidated and the final categorization should be left to the judgement of the user.
Note: This overview is only in this Report. Other reports only reference this one.

Summary

Stored XSS in multiple settings. Names/labels are rendered without sanitization via checkbox.twig template which uses {{ label|raw }}.

Affected Sources

#Source (injection point)Sink (where payload reflects)
1Section Name (/admin/settings/sections)Entries field -> Sources checklist
2Volume Name (/admin/settings/assets/volumes/{vol id})Assets field -> Sources checklist
3User Group Name (/admin/settings/users/groups)Users field -> Sources, User permissions page
4Global Set Name (/admin/settings/globals)User permissions page
5Generated Fields Name (Volumes, Users, etc.)Card Attributes checkboxes
6Checkboxes & Radio Buttons Field Option Label (/admin/settings/fields)User profile pages
7Custom Sources Label (/admin/users -> Customize Sources)Users field -> Sources checklist

Proof of Concept

Required Permissions (Attacker)

Bugs 1-3: Section, Volume, User Group Names

  1. Log in as admin.
  2. Inject payload in one of these:
  • Settings -> Sections -> Create/edit section -> Name
  • Settings -> Assets -> Volumes -> Create/edit volume -> Name
  • Settings -> Users -> User Groups -> Create/edit group -> Name
  1. Set Name to:
html
<img src=x onerror="alert('XSS')">
  1. Save.
  2. Go to Settings -> Fields -> Create new field.
  3. To trigger the XSS payload: Set Field Type to "Entries" (for Sections), "Assets" (for Volumes), or "Users" (for User Groups). The alert fires when the Sources checkbox list renders.
Note: User Group Name also reflects on User permissions page under User Groups section (/admin/users/{id}/permissions).

Bug 4: Global Set Name

  1. Go to Settings -> Globals (/admin/settings/globals).
  2. Create/edit a Global Set, set Name to payload.
  3. Save.
  4. Go to Users -> Edit any user -> Permissions tab (/admin/users/{id}/permissions).
  5. Alert fires because our payload got rendered in the "Global Sets" permissions section without encoding/sanitization.

Bug 5: Generated Fields Name

  1. Go to Settings -> Assets -> Volumes -> Create/Edit a volume.
  2. Scroll to Generated Fields section.
  3. Add a field, set Name to payload:
html
<img src=x onerror="alert('XSS')">
  1. Save & Notice the alert. The payload renders in the Card Attributes checkbox list below it.

Bug 6: Checkboxes/Radio Buttons Option Label

  1. Go to Settings -> Fields (/admin/settings/fields).
  2. Create new field, set Field Type to "Checkboxes" or "Radio Buttons".
  3. In Field Options, add an option with Label set to payload.
  4. Save the field.
  5. Go to Settings -> Users -> User Profile Fields (/admin/settings/users/fields).
  6. Add the created field to the layout and save.
  7. Alert fires on any user profile page (/admin/users/{id}).

Bug 7: Custom Sources Label

  1. Go to Users (/admin/users).
  2. Click the three dots icon -> Customize Sources.
  3. Create a new custom source, set Label to payload.
  4. Save.
  5. Go to Settings -> Fields -> Create new field.
  6. Set Field Type to "Users".
  7. Alert fires in the Sources checkbox list.

Resources

Fix

XSS

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

Weakness Enumeration

Related Identifiers

GHSA-4MGV-366X-QXVX

Affected Products

Craftcms/Cms