Security
Headlines
HeadlinesLatestCVEs

Headline

GHSA-4882-hxpr-hrvm: @udecode/plate-link does not sanitize URLs to prevent use of the `javascript:` scheme

Impact

Affected versions of the link plugin and link UI component do not sanitize URLs to prevent use of the javascript: scheme. As a result, links with JavaScript URLs can be inserted into the Plate editor through various means, including opening or pasting malicious content.

Patches

@udecode/plate-link 20.0.0 resolves this issue by introducing an allowedSchemes option to the link plugin, defaulting to ['http', 'https', 'mailto', 'tel']. URLs using a scheme that isn’t in this list will not be rendered to the DOM.

Workarounds

If you are unable to update @udecode/plate-link to version 20.0.0, we recommend overriding the LinkElement and PlateFloatingLink components with implementations that explicitly check the URL scheme before rendering any anchor elements.

ghsa
#java

Impact

Affected versions of the link plugin and link UI component do not sanitize URLs to prevent use of the javascript: scheme. As a result, links with JavaScript URLs can be inserted into the Plate editor through various means, including opening or pasting malicious content.

Patches

@udecode/plate-link 20.0.0 resolves this issue by introducing an allowedSchemes option to the link plugin, defaulting to ['http’, 'https’, 'mailto’, ‘tel’]. URLs using a scheme that isn’t in this list will not be rendered to the DOM.

Workarounds

If you are unable to update @udecode/plate-link to version 20.0.0, we recommend overriding the LinkElement and PlateFloatingLink components with implementations that explicitly check the URL scheme before rendering any anchor elements.

References

  • GHSA-4882-hxpr-hrvm
  • https://nvd.nist.gov/vuln/detail/CVE-2023-34245
  • udecode/plate#2240
  • udecode/plate@93dd571

Related news

CVE-2023-34245: Apply isUrl option to pasted links #2239 (#2240) · udecode/plate@93dd571

@udecode/plate-link is the link handler for the udecode/plate rich-text editor plugin system for Slate & React. Affected versions of the link plugin and link UI component do not sanitize URLs to prevent use of the `javascript:` scheme. As a result, links with JavaScript URLs can be inserted into the Plate editor through various means, including opening or pasting malicious content. `@udecode/plate-link` 20.0.0 resolves this issue by introducing an `allowedSchemes` option to the link plugin, defaulting to `['http', 'https', 'mailto', 'tel']`. URLs using a scheme that isn't in this list will not be rendered to the DOM. Users are advised to upgrade. Users unable to upgrade are advised to override the `LinkElement` and `PlateFloatingLink` components with implementations that explicitly check the URL scheme before rendering any anchor elements.