Home

Description

Langroid is a framework for building large-language-model-powered applications. Prior to version 0.59.32, there is a bypass to the fix for CVE-2025-46724. TableChatAgent can call pandas_eval tool to evaluate the expression. There is a WAF in langroid/utils/pandas_utils.py introduced to block code injection CVE-2025-46724. However it can be bypassed due to _literal_ok() returning False instead of raising UnsafeCommandError on invalid input, combined with unrestricted access to dangerous dunder attributes (__init__, __globals__, __builtins__). This allows chaining whitelisted DataFrame methods to leak the eval builtin and execute arbitrary code. This issue has been patched in version 0.59.32.

PUBLISHED Reserved 2026-02-02 | Published 2026-02-04 | Updated 2026-02-04 | Assigner GitHub_M




CRITICAL: 9.4CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:P/VC:H/VI:H/VA:H/SC:H/SI:H/SA:H

Problem types

CWE-94: Improper Control of Generation of Code ('Code Injection')

Product status

< 0.59.32
affected

References

github.com/...ngroid/security/advisories/GHSA-x34r-63hx-w57f

github.com/...ngroid/security/advisories/GHSA-jqq5-wc57-f8hj

github.com/...ommit/30abbc1a854dee22fbd2f8b2f575dfdabdb603ea

cve.org (CVE-2026-25481)

nvd.nist.gov (CVE-2026-25481)

Download JSON