CVE-2026-25632 PUBLISHED

EPyT-Flow has unsafe JSON deserialization (__type__)

Assigner: GitHub_M
Reserved: 04.02.2026 Published: 06.02.2026 Updated: 06.02.2026

EPyT-Flow is a Python package designed for the easy generation of hydraulic and water quality scenario data of water distribution networks. Prior to 0.16.1, EPyT-Flow’s REST API parses attacker-controlled JSON request bodies using a custom deserializer (my_load_from_json) that supports a type field. When type is present, the deserializer dynamically imports an attacker-specified module/class and instantiates it with attacker-supplied arguments. This allows invoking dangerous classes such as subprocess.Popen, which can lead to OS command execution during JSON parsing. This also affects the loading of JSON files. This vulnerability is fixed in 0.16.1.

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:H
CVSS Score: 10

Product Status

Vendor WaterFutures
Product EPyT-Flow
Versions
  • Version < 0.16.1 is affected

References

Problem Types

  • CWE-502: Deserialization of Untrusted Data CWE