Home

Description

CtrlPanel is open-source billing software for hosting providers. Versions 1.1.1 and prior contain a Stored Cross-Site Scripting (XSS) vulnerability exists in the admin role management interface. In app/Http/Controllers/Admin/RoleController.php, the datatable() method interpolates $role->name and $role->color directly into a <span> element's HTML and style attribute without sanitization, and the chained .rawColumns(['actions', 'name']) call instructs DataTables to render the name column as raw HTML, bypassing automatic output escaping. An admin with role creation or edit permissions can inject a payload such as <img src=x onerror="alert('XSS_POC')"> into the name or color fields, which is persisted to the database and executes in the browser of every admin who loads the /admin/roles page. This enables session hijacking via cookie theft, credential harvesting through fake login prompts or keyloggers, lateral privilege escalation by performing admin actions on behalf of victims, and a persistent backdoor that re-executes on every page load until the malicious role record is removed. This issue has been resolved in version 1.2.0.

PUBLISHED Reserved 2026-03-26 | Published 2026-05-19 | Updated 2026-05-20 | Assigner GitHub_M




MEDIUM: 4.8CVSS:3.1/AV:N/AC:L/PR:H/UI:R/S:C/C:L/I:L/A:N

Problem types

CWE-80: Improper Neutralization of Script-Related HTML Tags in a Web Page (Basic XSS)

CWE-116: Improper Encoding or Escaping of Output

Product status

< 1.2.0
affected

References

github.com/.../panel/security/advisories/GHSA-wpqj-xwhq-2mmh exploit

github.com/.../panel/security/advisories/GHSA-wpqj-xwhq-2mmh

github.com/Ctrlpanel-gg/panel/releases/tag/1.2.0

cve.org (CVE-2026-34246)

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

Download JSON