-
Notifications
You must be signed in to change notification settings - Fork 297
vm2 malforms arrays when passing them outside the sandbox boundary #265
Comments
The extra properties reported by console.log is a problem with node v10, see #198, these properties do not exisit. The spawn seems to be an seperate issue with node having problems working with proxied arrays. I don't see how we could fix this issue. |
Is it something in particular with how you use proxies in vm2 that causes the problem? The following code works correctly:
|
Thats the case since spawn will call slice(0) on the array and so the proxy will be removed. The proxies we use for vm2 however will wrap return values, so the return from slice will also be an proxy. const handler = {
get(target, key) {
if(key==='raw')
return target;
return this.wrap(target[key]);
},
apply(target, thiz, args) {
return this.wrap(target.apply(this.unwrap(thiz), args));
},
wrap(obj) {
if(obj===null || (typeof obj!=='object' && typeof obj!=='function'))
return obj;
return new Proxy(obj, this);
},
unwrap(obj) {
return obj.raw || obj;
}
};
const proc = require('child_process').spawn('ls', new Proxy(['./'], handler));
proc.stdout.on('data', (data) => console.log('stdout:', data.toString()));
proc.stderr.on('data', (data) => console.log('stderr:', data.toString()));
proc.on('close', (code) => console.log('exit code:', code)); |
Is there anything that the user can do to overcome this problem? I have the same issue with Node 8.17.0 and vm2 3.8.4 and would prefer not to remove the sandboxing. |
When an array produced within the sandbox is passed to a function outside of the sandbox boundary, the passed array contains additional elements (fields, maybe?). This, in turn, causes problems for child_process.spawn, which fails when running with a malformed array as a parameter.
The following code example demonstrates the problem:
The result of executing the above script is the following printout:
Note the additional
'0': 'a', '1': 'b', '2': 'c'
elements.This causes a failure when running
child_process.spawn
from within the sandbox. Specifically, thespawn
function cannot handle the malformed array passed as the arguments parameter, and instead passes it as anull
, which usually causes the executed child process to fail.The following code exemplifies this behaviour:
The above execution results in the following printout:
The text was updated successfully, but these errors were encountered: