Ansible fails to properly mark lookup-plugin results as unsafe
Critical severity
GitHub Reviewed
Published
Sep 6, 2018
to the GitHub Advisory Database
•
Updated May 29, 2025
Package
Affected versions
>= 2.3.0.0, < 2.3.1.0
< 2.1.6.0
>= 2.2.0.0, < 2.2.3.0
Patched versions
2.3.1.0
2.1.6.0
2.2.3.0
Description
Published to the GitHub Advisory Database
Sep 6, 2018
Reviewed
Jun 16, 2020
Last updated
May 29, 2025
Ansible before versions 2.1.6.0, 2.2.3.0, 2.3.1.0, and 2.4.0.0 fails to properly mark lookup-plugin results as unsafe. If an attacker could control the results of lookup() calls, they could inject Unicode strings to be parsed by the jinja2 templating system, resulting in code execution. By default, the jinja2 templating language is now marked as 'unsafe' and is not evaluated.
References