Home

Description

Typebot is a chatbot builder tool. In versions 3.15.2 and prior, the RatingButton component in the embed package renders the user-controlled customIcon.svg field directly via Solid's innerHTML directive without any sanitization, even though DOMPurify is already a dependency and is used elsewhere in the codebase (e.g., StreamingBubble.tsx). Because rating blocks are not flagged as isUnsafe by the import sanitizer and the builder preview renders bots inline on the builder's own origin (builder.typebot.io) under a CSP permitting 'unsafe-inline', a malicious imported or collaborator-crafted typebot can execute arbitrary HTML/JS in the builder's authenticated context, bypassing the Web Worker sandbox that protects Script blocks during preview. This allows session hijacking and privilege escalation within the builder application. This issue has been fixed in version 3.16.0.

PUBLISHED Reserved 2026-02-27 | Published 2026-05-22 | Updated 2026-05-22 | Assigner GitHub_M




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

Problem types

CWE-79: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

Product status

< 3.16.0
affected

References

github.com/...bot.io/security/advisories/GHSA-6m7c-xfhp-p9fh exploit

github.com/...bot.io/security/advisories/GHSA-6m7c-xfhp-p9fh

github.com/...ommit/474ecbf46bc47a75265bada2599f12b2179de375

github.com/baptisteArno/typebot.io/releases/tag/v3.16.0

cve.org (CVE-2026-28445)

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

Download JSON