CVE-2023-25571
Backstage has XSS Vulnerability in Software Catalog
Severity Score
Exploit Likelihood
Affected Versions
Public Exploits
0Exploited in Wild
-Decision
Descriptions
Backstage is an open platform for building developer portals. `@backstage/catalog-model` prior to version 1.2.0, `@backstage/core-components` prior to 0.12.4, and `@backstage/plugin-catalog-backend` prior to 1.7.2 are affected by a cross-site scripting vulnerability. This vulnerability allows a malicious actor with access to add or modify content in an instance of the Backstage software catalog to inject script URLs in the entities stored in the catalog. If users of the catalog then click on said URLs, that can lead to an XSS attack.
This vulnerability has been patched in both the frontend and backend implementations. The default `Link` component from `@backstage/core-components` version 1.2.0 and greater will now reject `javascript:` URLs, and there is a global override of `window.open` to do the same. In addition, the catalog model v0.12.4 and greater as well as the catalog backend v1.7.2 and greater now has additional validation built in that prevents `javascript:` URLs in known annotations. As a workaround, the general practice of limiting access to modifying catalog content and requiring code reviews greatly help mitigate this vulnerability.
CVSS Scores
SSVC
- Decision:-
Timeline
- 2023-02-07 CVE Reserved
- 2023-02-14 CVE Published
- 2024-08-02 CVE Updated
- 2024-09-06 EPSS Updated
- ---------- Exploited in Wild
- ---------- KEV Due Date
- ---------- First Exploit
CWE
- CWE-79: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')
- CWE-84: Improper Neutralization of Encoded URI Schemes in a Web Page
CAPEC
References (2)
URL | Tag | Source |
---|
URL | Date | SRC |
---|
URL | Date | SRC |
---|---|---|
https://github.com/backstage/backstage/commit/3d1371954512f7fa8bd0e2d357e00eada2c3e8a8 | 2023-11-07 |
URL | Date | SRC |
---|---|---|
https://github.com/backstage/backstage/security/advisories/GHSA-7hv8-3fr9-j2hv | 2023-11-07 |
Affected Vendors, Products, and Versions
Vendor | Product | Version | Other | Status | ||||||
---|---|---|---|---|---|---|---|---|---|---|
Vendor | Product | Version | Other | Status | <-- --> | Vendor | Product | Version | Other | Status |
Linuxfoundation Search vendor "Linuxfoundation" | Backstage Catalog-model Search vendor "Linuxfoundation" for product "Backstage Catalog-model" | < 1.2.0 Search vendor "Linuxfoundation" for product "Backstage Catalog-model" and version " < 1.2.0" | node.js |
Affected
| ||||||
Linuxfoundation Search vendor "Linuxfoundation" | Backstage Core-components Search vendor "Linuxfoundation" for product "Backstage Core-components" | < 0.12.4 Search vendor "Linuxfoundation" for product "Backstage Core-components" and version " < 0.12.4" | node.js |
Affected
| ||||||
Linuxfoundation Search vendor "Linuxfoundation" | Backstage Plugin-catalog-backend Search vendor "Linuxfoundation" for product "Backstage Plugin-catalog-backend" | < 1.7.2 Search vendor "Linuxfoundation" for product "Backstage Plugin-catalog-backend" and version " < 1.7.2" | node.js |
Affected
|