Jinja is an extensible templating engine. Prior to 3.1.5, 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. Jinjas sandbox does catch calls to str.format and ensures they dont escape the sandbox. However, its possible to store a reference to a malicious strings format 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. This vulnerability is fixed in 3.1.5.
The product does not use or incorrectly uses a protection mechanism that provides sufficient defense against directed attacks against the product.
Name | Vendor | Start Version | End Version |
---|---|---|---|
Jinja2 | Ubuntu | devel | * |
Jinja2 | Ubuntu | esm-infra-legacy/trusty | * |
Jinja2 | Ubuntu | esm-infra/bionic | * |
Jinja2 | Ubuntu | esm-infra/xenial | * |
Jinja2 | Ubuntu | focal | * |
Jinja2 | Ubuntu | jammy | * |
Jinja2 | Ubuntu | noble | * |
Jinja2 | Ubuntu | oracular | * |
Jinja2 | Ubuntu | upstream | * |