-
Notifications
You must be signed in to change notification settings - Fork 30.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
src: ensure that file descriptors 0-2 are valid
Check that stdin, stdout and stderr map to open file descriptors and remap them to /dev/null if that isn't the case. Protects against information leaks or worse when io.js is started with closed stdio file descriptors. PR-URL: #875 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Vladimir Kurchatkin <vladimir.kurchatkin@gmail.com>
- Loading branch information
1 parent
a956791
commit b5f25a9
Showing
2 changed files
with
40 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
var common = require('../common'); | ||
var assert = require('assert'); | ||
var spawn = require('child_process').spawn; | ||
|
||
if (process.platform === 'win32') { | ||
console.log('Skipping test, platform not supported.'); | ||
return; | ||
} | ||
|
||
if (process.argv[2] === 'child') { | ||
process.stdout.write('stdout', function() { | ||
process.stderr.write('stderr', function() { | ||
process.exit(42); | ||
}); | ||
}); | ||
} | ||
|
||
// Run the script in a shell but close stdout and stderr. | ||
var cmd = '"' + process.execPath + '" "' + __filename + '" child 1>&- 2>&-'; | ||
var proc = spawn('/bin/sh', ['-c', cmd], { stdio: 'inherit' }); | ||
|
||
proc.on('exit', common.mustCall(function(exitCode) { | ||
assert.equal(exitCode, 42); | ||
})); |