PySpector: Plugin Sandbox Bypass leads to Arbitrary Code Execution
Description
PySpector is a static analysis security testing (SAST) Framework engineered for modern Python development workflows. PySpector versions 0.1.6 and prior are affected by a security validation bypass in the plugin system. The validate_plugin_code() function in plugin_system.py, performs static AST analysis to block dangerous API calls before a plugin is trusted and executed. However, the internal resolve_name() helper only handles ast.Name and ast.Attribute node types, returning None for all others. When a plugin uses indirect function calls via getattr() (such as getattr(os, 'system')) the outer call's func node is of type ast.Call, causing resolve_name() to return None, and the security check to be silently skipped. The plugin incorrectly passes the trust workflow, and executes arbitrary system commands on the user's machine when loaded. This issue has been patched in version 0.1.7.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
pyspectorPyPI | < 0.1.7 | 0.1.7 |
Affected products
1- Range: < 0.1.7
Patches
0No patches discovered yet.
Vulnerability mechanics
AI mechanics synthesis has not run for this CVE yet.
References
3- github.com/advisories/GHSA-v3xv-8vc3-h2m6ghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2026-33139ghsaADVISORY
- github.com/ParzivalHack/PySpector/security/advisories/GHSA-v3xv-8vc3-h2m6ghsax_refsource_CONFIRMWEB
News mentions
0No linked articles in our index yet.