{"dataType":"CVE_RECORD","dataVersion":"5.2","cveMetadata":{"cveId":"CVE-2025-15022","assignerOrgId":"9e0f3122-90e9-42d5-93de-8c6b98deef7e","state":"PUBLISHED","assignerShortName":"Vaadin","dateReserved":"2025-12-22T07:12:40.732Z","datePublished":"2026-01-05T07:52:56.478Z","dateUpdated":"2026-01-05T21:11:31.883Z"},"containers":{"cna":{"affected":[{"collectionURL":"https://repo.maven.apache.org/maven2","defaultStatus":"unaffected","packageName":"com.vaadin:vaadin","product":"vaadin","repo":"https://github.com/vaadin/platform","vendor":"vaadin","versions":[{"lessThanOrEqual":"23.6.5","status":"affected","version":"23.1.0","versionType":"maven"},{"lessThanOrEqual":"24.8.13","status":"affected","version":"24.0.0","versionType":"maven"},{"lessThanOrEqual":"24.9.6","status":"affected","version":"24.9.0","versionType":"maven"}]},{"collectionURL":"https://repo.maven.apache.org/maven2","defaultStatus":"unaffected","packageName":"com.vaadin:vaadin-server","product":"framework","repo":"https://github.com/vaadin/framework","vendor":"vaadin","versions":[{"lessThanOrEqual":"7.7.49","status":"affected","version":"7.0.0","versionType":"maven"},{"lessThanOrEqual":"8.29.1","status":"affected","version":"8.0.0","versionType":"maven"}]},{"collectionURL":"https://repo.maven.apache.org/maven2","defaultStatus":"unaffected","packageName":"com.vaadin:vaadin-spreadsheet-flow","product":"vaadin-spreadsheet-flow","repo":"https://github.com/vaadin/flow-components","vendor":"vaadin","versions":[{"lessThanOrEqual":"23.6.5","status":"affected","version":"23.1.0","versionType":"maven"},{"lessThanOrEqual":"24.8.13","status":"affected","version":"24.0.0","versionType":"maven"},{"lessThanOrEqual":"24.9.6","status":"affected","version":"24.9.0","versionType":"maven"}]}],"descriptions":[{"lang":"en","supportingMedia":[{"base64":false,"type":"text/html","value":"<span style=\"background-color: rgba(232, 232, 232, 0.04);\">Action captions in Vaadin accept HTML by default but were not sanitized, potentially allowing Cross-site Scripting (XSS) if caption content is derived from user input.<br><br>In Vaadin Framework 7 and 8, the Action class is a general-purpose class that may be used by multiple components. The fixed versions sanitize captions by default and provide an API to explicitly enable HTML content mode for backwards compatibility.<br><br>In Vaadin 23 and newer, the Action class is only used by the Spreadsheet component. The fixed versions sanitize HTML using Jsoup with a relaxed safelist.<br><br>Vaadin 14 is not affected as Spreadsheet component was not supported.<br><br>Users of affected versions should apply the following mitigation or upgrade. Releases that have fixed this issue include:<br><br>Product version<br>Vaadin 7.0.0 - 7.7.49<br>Vaadin 8.0.0 - 8.29.1<br>Vaadin 23.1.0 - 23.6.5<br>Vaadin 24.0.0 - 24.8.13<br>Vaadin 24.9.0 - 24.9.6<br><br>Mitigation<br>Upgrade to 7.7.50<br>Upgrade to 8.30.0<br>Upgrade to 23.6.6<br>Upgrade to 24.8.14 or 24.9.7<br>Upgrade to 25.0.0 or newer<br><br>Artifacts&nbsp; &nbsp; &nbsp;<table><tbody><tr><td>Maven coordinates</td><td>Vulnerable versions</td><td>Fixed version</td></tr><tr><td>com.vaadin:vaadin-server<br></td><td>7.0.0 - 7.7.49<br></td><td>≥7.7.50<br></td></tr><tr><td>com.vaadin:vaadin-server<br></td><td>8.0.0 - 8.29.1<br></td><td>≥8.30.0<br></td></tr><tr><td>com.vaadin:vaadin<br></td><td>23.1.0 - 23.6.5<br></td><td>≥23.6.6<br></td></tr><tr><td>com.vaadin:vaadin</td><td>24.0.0 - 24.8.13<br></td><td>≥24.8.14<br></td></tr><tr><td>com.vaadin:vaadin</td><td>24.9.0 - 24.9.6<br></td><td>≥24.9.7<br></td></tr><tr><td>com.vaadin:vaadin-spreadsheet-flow<br></td><td>23.1.0 - 23.6.5<br></td><td>≥23.6.6<br></td></tr><tr><td>com.vaadin:vaadin-spreadsheet-flow<br></td><td>24.0.0 - 24.8.13<br></td><td>≥24.8.14<br></td></tr><tr><td>com.vaadin:vaadin-spreadsheet-flow<br></td><td>24.9.0 - 24.9.6<br></td><td>≥24.9.7<br></td></tr></tbody></table><br></span><p><br></p>"}],"value":"Action captions in Vaadin accept HTML by default but were not sanitized, potentially allowing Cross-site Scripting (XSS) if caption content is derived from user input.\n\nIn Vaadin Framework 7 and 8, the Action class is a general-purpose class that may be used by multiple components. The fixed versions sanitize captions by default and provide an API to explicitly enable HTML content mode for backwards compatibility.\n\nIn Vaadin 23 and newer, the Action class is only used by the Spreadsheet component. The fixed versions sanitize HTML using Jsoup with a relaxed safelist.\n\nVaadin 14 is not affected as Spreadsheet component was not supported.\n\nUsers of affected versions should apply the following mitigation or upgrade. Releases that have fixed this issue include:\n\nProduct version\nVaadin 7.0.0 - 7.7.49\nVaadin 8.0.0 - 8.29.1\nVaadin 23.1.0 - 23.6.5\nVaadin 24.0.0 - 24.8.13\nVaadin 24.9.0 - 24.9.6\n\nMitigation\nUpgrade to 7.7.50\nUpgrade to 8.30.0\nUpgrade to 23.6.6\nUpgrade to 24.8.14 or 24.9.7\nUpgrade to 25.0.0 or newer\n\nArtifacts     Maven coordinatesVulnerable versionsFixed versioncom.vaadin:vaadin-server\n7.0.0 - 7.7.49\n≥7.7.50\ncom.vaadin:vaadin-server\n8.0.0 - 8.29.1\n≥8.30.0\ncom.vaadin:vaadin\n23.1.0 - 23.6.5\n≥23.6.6\ncom.vaadin:vaadin24.0.0 - 24.8.13\n≥24.8.14\ncom.vaadin:vaadin24.9.0 - 24.9.6\n≥24.9.7\ncom.vaadin:vaadin-spreadsheet-flow\n23.1.0 - 23.6.5\n≥23.6.6\ncom.vaadin:vaadin-spreadsheet-flow\n24.0.0 - 24.8.13\n≥24.8.14\ncom.vaadin:vaadin-spreadsheet-flow\n24.9.0 - 24.9.6\n≥24.9.7"}],"impacts":[{"capecId":"CAPEC-86","descriptions":[{"lang":"en","value":"CAPEC-86 XSS Through HTTP Headers"}]}],"metrics":[{"cvssV4_0":{"Automatable":"NO","Recovery":"USER","Safety":"NEGLIGIBLE","attackComplexity":"LOW","attackRequirements":"NONE","attackVector":"NETWORK","baseScore":4.8,"baseSeverity":"MEDIUM","exploitMaturity":"NOT_DEFINED","privilegesRequired":"LOW","providerUrgency":"AMBER","subAvailabilityImpact":"NONE","subConfidentialityImpact":"LOW","subIntegrityImpact":"LOW","userInteraction":"ACTIVE","valueDensity":"DIFFUSE","vectorString":"CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:A/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N/S:N/AU:N/R:U/V:D/RE:L/U:Amber","version":"4.0","vulnAvailabilityImpact":"NONE","vulnConfidentialityImpact":"NONE","vulnIntegrityImpact":"NONE","vulnerabilityResponseEffort":"LOW"},"format":"CVSS","scenarios":[{"lang":"en","value":"GENERAL"}]}],"problemTypes":[{"descriptions":[{"cweId":"CWE-79","description":"CWE-79 Improper Neutralization of Input During Web Page Generation (Cross-site Scripting)","lang":"en","type":"CWE"}]}],"providerMetadata":{"orgId":"9e0f3122-90e9-42d5-93de-8c6b98deef7e","shortName":"Vaadin","dateUpdated":"2026-01-05T07:52:56.478Z"},"references":[{"url":"https://vaadin.com/security/cve-2025-15022"},{"url":"https://github.com/vaadin/flow-components/pull/8285"}],"solutions":[{"lang":"en","supportingMedia":[{"base64":false,"type":"text/html","value":"<b><span style=\"background-color: transparent;\">Users of affected versions should apply the following mitigation or upgrade.</span></b><br>"}],"value":"Users of affected versions should apply the following mitigation or upgrade."}],"source":{"discovery":"INTERNAL"},"title":"Cross-site scripting in Action caption","workarounds":[{"lang":"en","supportingMedia":[{"base64":false,"type":"text/html","value":"<b><span style=\"background-color: transparent;\">Ensure that Action captions are not derived from untrusted user input, or manually sanitize any user-provided content before using it as an Action caption.</span></b><br>"}],"value":"Ensure that Action captions are not derived from untrusted user input, or manually sanitize any user-provided content before using it as an Action caption."}],"x_generator":{"engine":"Vulnogram 0.2.0"}},"adp":[{"metrics":[{"other":{"type":"ssvc","content":{"timestamp":"2026-01-05T21:11:20.251254Z","id":"CVE-2025-15022","options":[{"Exploitation":"none"},{"Automatable":"no"},{"Technical Impact":"partial"}],"role":"CISA Coordinator","version":"2.0.3"}}}],"title":"CISA ADP Vulnrichment","providerMetadata":{"orgId":"134c704f-9b21-4f2e-91b3-4a467353bcc0","shortName":"CISA-ADP","dateUpdated":"2026-01-05T21:11:31.883Z"}}]}}