-
-
Notifications
You must be signed in to change notification settings - Fork 748
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
DOMPurify 3.1.7 breaks Mermaid diagrams using foreignObject
#1002
Comments
Heya, thanks for filing the issue 🙂 The good news is, you will be fine using 3.1.6 and the resolution you mention works. For 3.1.7 we needed a fix - but as the issue only becomes impactful when a specific set of config options are being used, users relying on 3.1.6 are likely gonna be fine as well. Please keep in mind that our priority is to prevent XSS and that is what we do. If something breaks for someone along the lines, we need to accept that as what it is and can always discuss that matter here.
I see your point here but frankly, as long as we don't break our own API or alike, we will keep doing releases as we do because nothing else makes sense. We're offering a sanitizer and with several billion sanitizations per day, there will always be one that is so specific that something will break. As long as our tests don't break, we need to assume low collateral and that is what we do. If nevertheless something breaks somewhere on the planet, well - so be it. We can neither predict nor prevent this. And weaving our version strategy around that would not make any sense. So, summed up, with 3.1.6, you are perfectly fine and all is good. Maybe we will make HTML entry points configurable in later versions, let's see how things go. The issue we did the change for is not yet fully researched so things might get adjusted in future releases. We'll see 😄 Until then, unless there is an actual security release, rest assured that you can stay on the version you are not having issues with. And once there is an actual need to upgrade because of a bypass, then there will likely be some way to work around any breakage if any. |
Thanks for the explanation, I understand your point of view, that "freezing behavior" would somehow tie your hands and prevent library evolution, and that this is not considered as a public API surface. We'll stick to 3.1.6, but it's appreciable to have the option to restore former behavior on v3.1.7+ because as you said, in case of a security issue in older versions it could be problematic to not have the ability to upgrade and benefit from a security patch. |
Cool, thanks - then let's conclude that for now, 3.1.6 is best to use in your case and very likely, for 3.1.8, we will add a config option enabling you to define the HTML entry-points in SVG - addressing this and potentially future problems as well 🙂 |
Thanks 🙏 |
@cure53 in hindsight, should |
@souldzin Nope, we didn't break anything knowingly. Our tests were green, our API unchanged - so no breakage we can observe. If anything with some markup somewhere in some setup changes after all, we cannot foresee this and judging by that, technically any release might be "breaking" 🙂 |
[DOMPurify v3.1.7][1] forbids the use of `<foreignElement>` for HTML inside of an `<svg>` element, which breaks many mermaid diagrams. It is likely that v3.1.8 will add a new option that will allow us to re-enable this behaviour, but v3.1.7 definitely does not work. [1]: https://github.com/cure53/DOMPurify/releases/tag/3.1.7 See: cure53/DOMPurify#1002 Fix: mermaid-js#5904
[DOMPurify v3.1.7][1] forbids the use of `<foreignElement>` for HTML inside of an `<svg>` element, which breaks many mermaid diagrams. It is likely that v3.1.8 will add a new option that will allow us to re-enable this behaviour, but v3.1.7 definitely does not work. [1]: https://github.com/cure53/DOMPurify/releases/tag/3.1.7 See: cure53/DOMPurify#1002 Fix: mermaid-js#5904
[DOMPurify v3.1.7][1] forbids the use of `<foreignElement>` for HTML inside of an `<svg>` element, which breaks many mermaid diagrams. It is likely that v3.1.8 will add a new option that will allow us to re-enable this behaviour, but v3.1.7 definitely does not work. (cherry picked from commit de2c05c) [1]: https://github.com/cure53/DOMPurify/releases/tag/3.1.7 See: cure53/DOMPurify#1002 Fix: #5904
@slorber Heya 🙂 We have a commit on main that should fix your problem. You can now do this: DOMPurify.sanitize(
'<svg><foreignObject><h1>HELLO</h1></foreignObject></svg>',
{
ADD_TAGS: ['foreignObject'],
HTML_INTEGRATION_POINTS: {'foreignobject': true}
}
); Does this address the issue and allows you to get the sanitization output you need for Mermaid? |
Thanks I'm not a Mermaid dev but I guess @aloisklink @sidharthv96 will be able to upgrade and unpin the lib dependency |
Hi @cure53, sorry for the late reply! e4caa67 seems to work fine if we add I did have some issues with eb7b40d, but it's due to TypeScript issues, the JavaScript code seems to be fine! I've made #1008 to fix it. I also got some type errors like:
However, according to #1006, this is expected behaviour:
|
Background & Context
I'm the maintainer of [Docusaurus], which uses Mermaid diagrams, which uses DOMPurify.
Example: https://docusaurus.io/docs/markdown-features/diagrams
Bug
DOMPurify 3.1.7 breaks retrocompatibility due to a recent
foreignObject
-related change from @masatokinugawaThis breaks Mermaid diagrams on all our newly initialized sites and is likely to affect other Memaid users very soon (800k dl/week).
Excuse me for not respecting your issue template because the only thing I know is that DOMPurify is causing the problem. I'm not sure how Mermaid uses the lib exactly, and not even sure if they are aware (yet) of the problem.
What I can say is that Mermaid uses DOMPurify, v3.1.6 worked and v3.1.7 doesn't, with
foreignObject
tags in SVGs being empty:A temporary fix I'll advise to our users is to force a downgrade with package manager features, for example Yarn resolution
I'm also unsure what's the versioning policy of the lib, but I assume it implicitly respects semver and not release breaking changes on patch releases right? If you plan to release breaking changes on patch releases, it's better to say so explicitly so that users can pin the dependency to a given version.
In the meantime I'd suggest to revert the change to restore retro-compatibility, and postpone this change to v4 to avoid disrupting the Mermaid and Docusaurus ecosystems.
Thanks
Related issues:
<foreignObject
) mermaid-js/mermaid#5904foreignObject
) facebook/docusaurus#10526The text was updated successfully, but these errors were encountered: