Description
SandboxJS is a JavaScript sandboxing library. Prior to 0.8.29, there is a sandbox escape vulnerability due to a mismatch between the key on which the validation is performed and the key used for accessing properties. Even though the key used in property accesses is annotated as string, this is never enforced. So, attackers can pass malicious objects that coerce to different string values when used, e.g., one for the time the key is sanitized using hasOwnProperty(key) and a different one for when the key is used for the actual property access. This vulnerability is fixed in 0.8.29.
Problem types
CWE-367: Time-of-check Time-of-use (TOCTOU) Race Condition
Product status
References
github.com/...dboxJS/security/advisories/GHSA-7x3h-rm86-3342
github.com/...dboxJS/security/advisories/GHSA-7x3h-rm86-3342
github.com/...ommit/67cb186c41c78c51464f70405504e8ef0a6e43c3
github.com/...4666fe48cfda58a4d5f37005b43754/src/executor.ts