Home

Description

An SSTI (Server-Side Template Injection) vulnerability exists in the get_contract_template method of Frappe ERPNext through 15.89.0. The function renders attacker-controlled Jinja2 templates (contract_terms) using frappe.render_template() with a user-supplied context (doc). Although Frappe uses a custom SandboxedEnvironment, several dangerous globals such as frappe.db.sql are still available in the execution context via get_safe_globals(). An authenticated attacker with access to create or modify a Contract Template can inject arbitrary Jinja expressions into the contract_terms field, resulting in server-side code execution within a restricted but still unsafe context. This vulnerability can be used to leak database information.

PUBLISHED Reserved 2025-11-30 | Published 2025-12-15 | Updated 2025-12-17 | Assigner mitre

References

www.notion.so/...86eadc80878e8fcc7b6c26a584?source=copy_link

iamanc.github.io/post/erpnext-ssti-bug-2

cve.org (CVE-2025-66435)

nvd.nist.gov (CVE-2025-66435)

Download JSON

Data based on CVE®. Copyright © 1999-2025, The MITRE Corporation. All rights reserved.