Update dependency Jinja2 to v3.1.5 [SECURITY] #1751
Merged
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:
==3.1.4
->==3.1.5
Warning
Some dependencies could not be looked up. Check the Dependency Dashboard for more information.
Jinja has a sandbox breakout through malicious filenames
CVE-2024-56201 / GHSA-gmj6-6f8f-6699
More information
Details
A bug in the Jinja compiler allows an attacker that controls both the content and filename of a template to execute arbitrary Python code, regardless of if Jinja's sandbox is used.
To exploit the vulnerability, an attacker needs to control both the filename and the contents of a template. Whether that is the case depends on the type of application using Jinja. This vulnerability impacts users of applications which execute untrusted templates where the template author can also choose the template filename.
Severity
CVSS:4.0/AV:L/AC:L/AT:P/PR:L/UI:P/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N
References
This data is provided by OSV and the GitHub Advisory Database (CC-BY 4.0).
Jinja has a sandbox breakout through indirect reference to format method
CVE-2024-56326 / GHSA-q2x7-8rv6-6q7h
More information
Details
An oversight in how the Jinja sandboxed environment detects calls to
str.format
allows an attacker that controls the content of a template to execute arbitrary Python code.To exploit the vulnerability, an attacker needs to control the content of a template. Whether that is the case depends on the type of application using Jinja. This vulnerability impacts users of applications which execute untrusted templates.
Jinja's sandbox does catch calls to
str.format
and ensures they don't escape the sandbox. However, it's possible to store a reference to a malicious string'sformat
method, then pass that to a filter that calls it. No such filters are built-in to Jinja, but could be present through custom filters in an application. After the fix, such indirect calls are also handled by the sandbox.Severity
CVSS:4.0/AV:L/AC:L/AT:P/PR:L/UI:P/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N
References
This data is provided by OSV and the GitHub Advisory Database (CC-BY 4.0).
Release Notes
pallets/jinja (Jinja2)
v3.1.5
Compare Source
Released 2024-12-21
str.format
, such asby passing a stored reference to a filter that calls its argument.
:ghsa:
q2x7-8rv6-6q7h
issues with names that contain f-string syntax.
:issue:
1792
, :ghsa:gmj6-6f8f-6699
clear
andpop
on known mutable sequencetypes. :issue:
2032
render
for an async template usesasyncio.run
.:pr:
1952
auto_aiter
warnings. :pr:1960
aclose
-ableAsyncGenerator
fromTemplate.generate_async
. :pr:1960
root_render_func()
unclosed inTemplate.generate_async
. :pr:1960
:pr:
1960
concat
function for the current environmentwhen calling block references. :issue:
1701
|unique
async-aware, allowing it to be used after anotherasync-aware filter. :issue:
1781
|int
filter handlesOverflowError
from scientific notation.:issue:
1921
{% set ... %}
call. :issue:
2021
copy
/pickle
/etc) interaction withUndefined
objects. :issue:
2025
copy
/pickle
support for the internalmissing
object.:issue:
2027
Environment.overlay(enable_async)
is applied correctly. :pr:2061
FileSystemLoader
includes the paths that weresearched. :issue:
1661
PackageLoader
shows a clearer error message when the package does notcontain the templates directory. :issue:
1705
1880
urlize
does not addmailto:
to values like@a@b
. :pr:1870
@pass_context`` can be used with the ``|select`` filter. :issue:
1624`set
for multiple assignment (a, b = 1, 2
) does not fail when thetarget is a namespace attribute. :issue:
1413
set
in all branches of{% if %}{% elif %}{% else %}
blocksdoes not cause the variable to be considered initially undefined.
:issue:
1253
Configuration
📅 Schedule: Branch creation - "" (UTC), Automerge - "every weekday" (UTC).
🚦 Automerge: Enabled.
♻ 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 Renovate Bot.