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.
Cite this page
CVE-2025-66435. CVEDatabase.com. Retrieved 1 May 2026. https://cvedatabase.com/cve/CVE-2025-66435
Use CWE-94, Frappe vendor hub and Erpnext product page to widen CVE-2025-66435 into its surrounding weakness, vendor, and product context.
Compare it with CVE-2025-67289, CVE-2026-27471 and CVE-2026-31017 for nearby disclosures in the same product family.