by @mweinelt Activity log
- Created automatic suggestion
- @mweinelt dismissed
Werkzeug safe_join() allows Windows special device names
Werkzeug is a comprehensive WSGI web application library. Versions 3.1.5 and below, the safe_join function allows Windows device names as filenames if preceded by other path segments. This was previously reported as GHSA-hgf8-39gv-g3f2, but the added filtering failed to account for the fact that safe_join accepts paths with multiple segments, such as example/NUL. The function send_from_directory uses safe_join to safely serve files at user-specified paths under a directory. If the application is running on Windows, and the requested path ends with a special device name, the file will be opened successfully, but reading will hang indefinitely. This issue has been fixed in version 3.1.6.
References
- https://github.com/pallets/werkzeug/security/advisories/GHSA-29vq-49wr-vm6x x_refsource_CONFIRM
- https://github.com/pallets/werkzeug/commit/f407712fdc60a09c2b3f4fe7db557703e5d9338d x_refsource_MISC
- https://github.com/pallets/werkzeug/releases/tag/3.1.6 x_refsource_MISC
Affected products
- ==< 3.1.6
Matching in nixpkgs
pkgs.python312Packages.werkzeug
Comprehensive WSGI web application library
pkgs.python313Packages.werkzeug
Comprehensive WSGI web application library
pkgs.python314Packages.werkzeug
Comprehensive WSGI web application library