This repository has been archived by the owner on Jul 17, 2024. It is now read-only.
Update dependency fonttools to v4.43.0 [SECURITY] #404
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
==4.37.4
->==4.43.0
GitHub Vulnerability Alerts
CVE-2023-45139
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.
/etc/passwd
for our POC file to include and modified an existing subset integration test to build the POC font - see bellow.fonttools==4.42.1
andfonttools==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):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.
Possible Mitigations
There may be other ways to mitigate the issue, but some suggestions:
resolve_entities=False
flag on parsing methodsRelease Notes
fonttools/fonttools (fonttools)
v4.43.0
Compare Source
XMLParser(resolve_entities=False)
when parsing OT-SVG documents to prevent XML External Entity (XXE) attacks (9f61271
): https://codeql.github.com/codeql-query-help/python/py-xxe/iup_delta_optimize
that was leading to IUP tolerance being incorrectly initialised, resulting in sub-optimal deltas (6012643
, cython/cython#5732).fonttools varLib.avar
to add anavar
table to an existing VF from axes mappings in a .designspace file (0a3360e
).v4.42.1
Compare Source
457f11c
).addMultilingualName
andttFont
parameter was not passed on tofindMultilingualName
(#3253).v4.42.0
Compare Source
v4.41.1
Compare Source
NameRecordVisitor
only visit tables that do contain nameID references (#3213, #3214).CursivePos
masters (#3209).v4.41.0
Compare Source
removeUnusedNameRecords
in the user range (#3185)._add_avar()
call site (#3183).voltLib.voltToFea
submodule (originally Tiro Typeworks' "Volto") for converting VOLT OpenType Layout sources to FEA format (#3164).v4.40.0
Compare Source
pip install --no-binary=fonttools fonttools
to expliclity request pip to install from the pure-python source.avar2
table from those (#3123).Added
quantization
option (#3126).v4.39.4
Compare Source
v4.39.3
Compare Source
seekable
method was only added in python 3.11 (https://github.com/fonttools/fonttools/issues/3052).v4.39.2
Compare Source
NOTE: The 4.39.1 distribution was "yanked" from PyPI to prevent users from accidentally upgrading to it.
v4.39.1
Compare Source
https://github.com/harfbuzz/boring-expansion-spec/blob/main/avar2.md
STAT
table that was built with feaLib from FEA feature file. Also, added support for building multiple VFs defined in Designspace v5 fromfonttools varLib
script (https://github.com/fonttools/fonttools/pull/3024).Debg
table with lookup names whenFONTTOOLS_LOOKUP_DEBUGGING
env variable is set (https://github.com/fonttools/fonttools/pull/3023).v4.39.0
Compare Source
Debg
debug info for MTI feature builds (#3018).-
character, similar to existing-o -
option to write output to standard output (#3020).cython.compiled
raise AttributeError if cython not installed properly (#3017).debug
parameter to addOpenTypeFeatures method to add source debugging information to the font in theDebg
private table (#3008).__lt__
comparison not fail on Unicode encoding errors (#3006).overlayBox
(#3003, #3005).https://github.com/harfbuzz/boring-expansion-spec/blob/main/glyf1-cubicOutlines.md
https://github.com/harfbuzz/boring-expansion-spec/blob/main/glyf1-varComposites.md.
addVarComponent
method to pen protocols' base classes, which pens can implement to handle varcomponents (by default they get decomposed).__getstate__
for BaseTable so that a copied/pickled 'lazy' object gets its own OTTableReader to read from; incidentally fixes a bug while subsetting COLRv1 table containing ClipBoxes on python 3.11 (#2965, #2968).endPointsOfContours
field should be unsigned! Kudos to behdad for spotting one of the oldest bugs in FT. Probably nobody has ever dared to make glyphs with more than 32767 points... (#2957).ignore
statements with unmarked glyphs to match makeotf behavior, which assumes the first glyph is marked (#2950).black
and enforce new code style via CI check (#2925).v4.38.0
Compare Source
It's now also possible to restrict an axis min/max values beyond the current default value, e.g. a font wght has min=100, def=400, max=900 and you want a partial VF that only varies between 500 and 700, you can now do that. You can either specify two min/max values (wght=500:700), and the new default will be set to either the minimum or maximum, depending on which one is closer to the current default (e.g. 500 in this case). Or you can specify three values (e.g. wght=500:600:700) to set the new default value explicitly.
Add optional extrapolate=False to normalizeLocation() (#2847, #2849).
Configuration
📅 Schedule: Branch creation - "" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by Mend Renovate. View repository job log here.