PT-2026-50141 · Pypi · Langflow
Published
2026-06-16
·
Updated
2026-06-16
·
CVE-2026-42867
CVSS v3.1
6.5
Medium
| Vector | AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:L |
Summary
Langflow is vulnerable to Path Traversal in the Knowledge Bases API (
POST /api/v1/knowledge bases). This occurs because user-supplied knowledge base names are used directly to create file paths without proper sanitization or containment checks. An authenticated attacker can exploit this flaw to create directories and write files anywhere on the server's filesystem.Details
The vulnerability exists in the
create knowledge base function within src/backend/base/langflow/api/v1/knowledge bases.py.This function constructs file paths directly from the user-supplied
name field without sanitization. The value is concatenated with the user's base directory and passed directly to kb path.mkdir(). Immediately following the directory creation, the application writes embedding metadata.json and schema.json into this attacker-controlled path.PoC (Proof of Concept)
For the Create endpoint, an attacker can supply traversal sequences or absolute paths in the
name field:../victim user/evil kb
or
/tmp/pwnedThis forces
kb path.mkdir() to create directories and write specific application files (embedding metadata.json and schema.json) at any reachable path on the server.Impact
Any Langflow instance exposing this endpoint to authenticated users is vulnerable. This exposes the server to:
- Cross-user data compromise: Creation of directories and files within another tenant's knowledge base space.
- Arbitrary filesystem manipulation: Directory creation at any path on the server where the application has write permissions (e.g.,
/app/data). - Data overwrite: Overwriting existing
embedding metadata.jsonandschema.jsonfiles in attacker-targeted paths, potentially corrupting existing knowledge bases.
Fixes
The issue was addressed in PR #12337. The fix introduces the
validate kb path containment() helper function, which uses Path.is relative to() instead of startswith() to enforce strict path boundaries and prevent prefix-ambiguity bugs. This helper is applied before any filesystem operations. Regression tests were added to verify that traversal payloads return a 403 Forbidden.Acknowledgements
Thanks to the security researchers who responsibly disclosed this vulnerability:
- @ddlxstudio
- @nekros1xx
Fix
Path traversal
Found an issue in the description? Have something to add? Feel free to write us 👾
Weakness Enumeration
Related Identifiers
Affected Products
Langflow