GHSA-46j8-vpx8-6p72

Suggest an improvement
Source
https://github.com/advisories/GHSA-46j8-vpx8-6p72
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/03/GHSA-46j8-vpx8-6p72/GHSA-46j8-vpx8-6p72.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-46j8-vpx8-6p72
Aliases
  • CVE-2026-33045
Published
2026-03-27T20:35:01Z
Modified
2026-03-27T22:12:34.544621Z
Severity
  • 1.1 (Low) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:P/PR:L/UI:A/VC:L/VI:L/VA:N/SC:N/SI:N/SA:N/E:P CVSS Calculator
Summary
Home Assistant has stored XSS in history-graphs
Details

Summary

The "remaining charge time"-sensor for mobile phones (imported/included from Android Auto it appears) is vulnerable to the same issue as CVE-2025-62172. <img width="431" height="334" alt="image" src="https://github.com/user-attachments/assets/84e0dfad-b986-4e84-ad0e-674c5da88582" /> This also indicates that any sensor showing their name in the history-graph, is likely to be vulnerable to this issue.

Details

Another entity was found which displays the same behavior as in this issue: CVE-2025-62172

The History-graph card will sometimes display the name of the entity it is displaying, when the graph is shown as a line with values on the x and y axis. This appears to be vulnerable to Cross-Site scripting (XSS) as it does not have any output escaping or sanitization.

The PoC in this instance only shows HTML-injection in the form of the <s> -tag being rendered as strike through, but the vulnerability also allows for injecting arbitrary tags which execute JavaScript, like the example given in the PoC description below.

PoC

  1. Register a new sensor (or device) or change the name of an existing one, which provides a location
  2. Change the name to something malicious, for example test <img src=x onerror=alert(document.domain) /> For a new entity, it should work when setting the name. For old entities, go here: <img width="1300" height="411" alt="image" src="https://github.com/user-attachments/assets/7dbd9afa-2f4b-4d03-9384-d57c53eaff5c" /> <img width="1383" height="885" alt="image" src="https://github.com/user-attachments/assets/c4cfba2e-e2d8-4817-92fe-f17ba7877e27" /> <img width="387" height="436" alt="image" src="https://github.com/user-attachments/assets/c40e986d-20ca-416e-bcdb-ca1d3afa77a4" /> <br> <img width="392" height="515" alt="image" src="https://github.com/user-attachments/assets/623fcf8c-eef1-4b17-853d-0ff5440aecaa" />

PS: the example pictures show changing the name of the device-tracker entity, which is wrong. Just change the name of the remaining charge time-sensor in order to validate this finding

  1. Add a history graph card with the malicious sensor <img width="696" height="474" alt="image" src="https://github.com/user-attachments/assets/3cda78e6-3db5-4075-8924-ab9fc5759082" />

  2. Hover the graph for payload execution <img width="343" height="196" alt="image" src="https://github.com/user-attachments/assets/99e56169-b06a-4c60-9343-510e5d74af12" />

Impact

The impact of this vulnerability is that a user can target other users of the system and perform account takeover through client side exploitation of XSS.

In the context of this system, I believe the vulnerability to be less impactful than the CVSS metric describes. It is not displayed anywhere by default, it is not natural to display this history graph, and it also has no potential for being imported through seemingly innocent integrations. It also appears to rely on having used/using Android Auto. Other devices which has the same sensor can trigger the same vulnerability, and I expect there to exists cloud-based devices that would enable a threat actor to deliver the payload remotely.

Credit: Robin Lunde - https://robinlunde.com

Database specific
{
    "github_reviewed": true,
    "github_reviewed_at": "2026-03-27T20:35:01Z",
    "nvd_published_at": "2026-03-27T20:16:31Z",
    "severity": "LOW",
    "cwe_ids": [
        "CWE-79"
    ]
}
References

Affected packages

PyPI / homeassistant

Package

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2025.02
Fixed
2026.01

Affected versions

2025.*
2025.2.0
2025.2.1
2025.2.2
2025.2.3
2025.2.4
2025.2.5
2025.3.0b0
2025.3.0b1
2025.3.0b2
2025.3.0b3
2025.3.0b4
2025.3.0b5
2025.3.0b6
2025.3.0b7
2025.3.0b8
2025.3.0
2025.3.1
2025.3.2
2025.3.3
2025.3.4
2025.4.0b0
2025.4.0b1
2025.4.0b2
2025.4.0b3
2025.4.0b4
2025.4.0b5
2025.4.0b6
2025.4.0b7
2025.4.0b8
2025.4.0b9
2025.4.0b10
2025.4.0b11
2025.4.0b12
2025.4.0b13
2025.4.0b14
2025.4.0b15
2025.4.0
2025.4.1
2025.4.2
2025.4.3
2025.4.4
2025.5.0b0
2025.5.0b1
2025.5.0b2
2025.5.0b3
2025.5.0b4
2025.5.0b5
2025.5.0b6
2025.5.0b7
2025.5.0b8
2025.5.0b9
2025.5.0b10
2025.5.0
2025.5.1
2025.5.2
2025.5.3
2025.6.0b0
2025.6.0b1
2025.6.0b2
2025.6.0b3
2025.6.0b4
2025.6.0b5
2025.6.0b6
2025.6.0b7
2025.6.0b8
2025.6.0b9
2025.6.0
2025.6.1
2025.6.2
2025.6.3
2025.7.0b0
2025.7.0b1
2025.7.0b2
2025.7.0b3
2025.7.0b4
2025.7.0b5
2025.7.0b6
2025.7.0b7
2025.7.0b8
2025.7.0b9
2025.7.0
2025.7.1
2025.7.2
2025.7.3
2025.7.4
2025.8.0b0
2025.8.0b1
2025.8.0b2
2025.8.0b3
2025.8.0b4
2025.8.0b5
2025.8.0
2025.8.1
2025.8.2
2025.8.3
2025.9.0b0
2025.9.0b1
2025.9.0b2
2025.9.0b3
2025.9.0b4
2025.9.0b5
2025.9.0b6
2025.9.0
2025.9.1
2025.9.2
2025.9.3
2025.9.4
2025.10.0b0
2025.10.0b1
2025.10.0b2
2025.10.0b4
2025.10.0b5
2025.10.0b6
2025.10.0b7
2025.10.0
2025.10.1
2025.10.2
2025.10.3
2025.10.4
2025.11.0b0
2025.11.0b1
2025.11.0b2
2025.11.0b3
2025.11.0b4
2025.11.0b5
2025.11.0b6
2025.11.0
2025.11.1
2025.11.2
2025.11.3
2025.12.0b0
2025.12.0b1
2025.12.0b2
2025.12.0b3
2025.12.0b4
2025.12.0b5
2025.12.0b6
2025.12.0b7
2025.12.0b8
2025.12.0b9
2025.12.0
2025.12.1
2025.12.2
2025.12.3
2025.12.4
2025.12.5
2026.*
2026.1.0b0
2026.1.0b1
2026.1.0b2
2026.1.0b3
2026.1.0b4
2026.1.0b5

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/03/GHSA-46j8-vpx8-6p72/GHSA-46j8-vpx8-6p72.json"