GHSA-5r3x-p7xx-x6q5

Suggest an improvement
Source
https://github.com/advisories/GHSA-5r3x-p7xx-x6q5
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/03/GHSA-5r3x-p7xx-x6q5/GHSA-5r3x-p7xx-x6q5.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-5r3x-p7xx-x6q5
Aliases
Published
2023-03-28T14:45:28Z
Modified
2023-11-08T04:12:12.683398Z
Severity
  • 5.3 (Medium) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L CVSS Calculator
Summary
Comrak AST node data is not validated (GHSL-2023-049)
Details

Impact

A Comrak AST can be constructed manually by a program instead of parsing a Markdown document with parse_document. This AST can then be converted to HTML via html::format_document_with_plugins. However, the HTML formatting code assumes that the AST is well-formed. For example, many AST notes contain [u8] fields which the formatting code assumes is valid UTF-8 data. Several bugs can be triggered if this is not the case.

Patches

0.17.0 contains adjustments to the AST, storing strings instead of unvalidated byte arrays.

Workarounds

  • Validate UTF-8 correctness of all data when assigning to &[u8] and Vec<u8> fields in the AST.

References

n/a

Database specific
{
    "nvd_published_at": "2023-03-28T21:15:00Z",
    "cwe_ids": [
        "CWE-755"
    ],
    "severity": "MODERATE",
    "github_reviewed": true,
    "github_reviewed_at": "2023-03-28T14:45:28Z"
}
References

Affected packages

crates.io / comrak

Package

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
0.17.0