by @LeSuisse Activity log
- Created automatic suggestion
- @LeSuisse ignored
-
@LeSuisse
removed
6 packages
- vscode-extensions.gleam.gleam
- tree-sitter-grammars.tree-sitter-gleam
- vimPlugins.nvim-treesitter-parsers.gleam
- python312Packages.tree-sitter-grammars.tree-sitter-gleam
- python313Packages.tree-sitter-grammars.tree-sitter-gleam
- python314Packages.tree-sitter-grammars.tree-sitter-gleam
- @LeSuisse accepted
- @LeSuisse published on GitHub
Improper Path Validation in Git Dependency Handling Allows Arbitrary File System Modification
Improper path validation vulnerability in the Gleam compiler's handling of git dependencies allows arbitrary file system modification during dependency download. Dependency names from gleam.toml and manifest.toml are incorporated into filesystem paths without sufficient validation or confinement to the intended dependency directory, allowing attacker-controlled paths (via relative traversal such as ../ or absolute paths) to target filesystem locations outside that directory. When resolving git dependencies (e.g. via gleam deps download), the computed path is used for filesystem operations including directory deletion and creation. This vulnerability occurs during the dependency resolution and download phase, which is generally expected to be limited to fetching and preparing dependencies within a confined directory. A malicious direct or transitive git dependency can exploit this issue to delete and overwrite arbitrary directories outside the intended dependency directory, including attacker-chosen absolute paths, potentially causing data loss. In some environments, this may be further leveraged to achieve code execution, for example by overwriting git hooks or shell configuration files. This issue affects Gleam from 1.9.0-rc1 until 1.15.3 and 1.16.0-rc1.
References
Ignored references (2)
Affected products
- *
- *
Matching in nixpkgs
Ignored packages (6)
pkgs.vscode-extensions.gleam.gleam
Support for the Gleam programming language
pkgs.tree-sitter-grammars.tree-sitter-gleam
None
pkgs.vimPlugins.nvim-treesitter-parsers.gleam
None
-
nixos-unstable 0.0.0+rev=0bb1b0a
- nixpkgs-unstable 0.0.0+rev=0bb1b0a
- nixos-unstable-small 0.0.0+rev=0bb1b0a
pkgs.python312Packages.tree-sitter-grammars.tree-sitter-gleam
Python bindings for tree-sitter-gleam
pkgs.python313Packages.tree-sitter-grammars.tree-sitter-gleam
Python bindings for tree-sitter-gleam
pkgs.python314Packages.tree-sitter-grammars.tree-sitter-gleam
Python bindings for tree-sitter-gleam
Package maintainers
-
@minijackson Rémi Nicole <minijackson@riseup.net>
-
@happysalada Raphael Megzari <raphael@megzari.com>
-
@adamcstephens Adam C. Stephens <happy.plan4249@valkor.net>
-
@DianaOlympos Thomas Depierre
-
@llakala llakala <elevenaka11@gmail.com>
-
@gleber Gleb Peregud <gleber.p@gmail.com>
-
@ankhers Justin Wood <me@ankhers.dev>
-
@yurrriq Eric Bailey <eric@ericb.me>
-
@philtaken Philipp Herzog <philipp.herzog@protonmail.com>