Vulnerability description

Improper Neutralization of Input During Web Page Generation (XSS) vulnerability in leandrocp mdex allows cross-site scripting via unsanitized URL schemes in Quill Delta output.

'Elixir.MDEx':to_delta/2 converts Markdown into a Quill Delta. 'Elixir.MDEx.DeltaConverter':default_convert_node/3 in lib/mdex/delta_converter.ex copies the URL of a link, wikilink, or image node directly from the parsed Markdown into the Delta "link" or "image" attribute without applying a scheme allowlist or any normalization.

An attacker who controls the Markdown text can supply a javascript: URL (for example [click](javascript:alert(document.cookie))) that survives verbatim into the Delta attribute. When the Delta is rendered to HTML by a downstream renderer (such as quill-delta-to-html or the Quill client), the attribute becomes an <a href> or <img src>, and the javascript: scheme executes in the browser of anyone who views the rendered content. The link and wikilink cases are the strongest vectors because javascript: in an href executes on click; the image case is lower impact because javascript: in <img src> generally does not execute in modern browsers.

This issue affects mdex: from 0.8.3 before 0.13.2.

Affected

pkg:hex/mdex

Status Type Version Changes / Fixed in
affected semver 0.8.3 < 0.13.2

pkg:github/leandrocp/mdex

Module Source File Routine
MDEx lib/mdex.ex MDEx.to_delta/2
MDEx.DeltaConverter lib/mdex/delta_converter.ex MDEx.DeltaConverter.convert/2
MDEx.DeltaConverter.default_convert_node/3
Status Type Version Changes / Fixed in
affected git 9852db2456 < 2817147f5b

Configurations

The application must pass untrusted Markdown to 'Elixir.MDEx':to_delta/2 and then render the resulting Quill Delta to HTML with a renderer that maps the "link" and "image" attributes to href and src without applying its own URL scheme sanitization (for example quill-delta-to-html or the Quill client).

Workarounds

Sanitize the Quill Delta produced by 'Elixir.MDEx':to_delta/2 before rendering it: drop or blank any "link" or "image" value whose URL scheme is not in a safe allowlist (http, https, mailto, tel).

References

Credits

  • Finder: Peter Ullrich
  • Remediation developer: Leandro Pereira
  • Analyst: Jonatan Männchen / EEF

CVE record as JSON:  GET /cves/CVE-2026-54889.json
OSV record as JSON:  GET /osv/EEF-CVE-2026-54889.json