Files
codeql/javascript/ql/test/library-tests/frameworks/AsyncPackage/waterfall.js
2025-06-15 17:59:49 +02:00

66 lines
1.2 KiB
JavaScript

let async_ = require('async');
let waterfall = require('a-sync-waterfall');
function source() {
return 'TAINT'
}
function sink(x) {
console.log(x)
}
var somethingWrong;
async_.waterfall([
function(callback) {
callback(null, 'safe', source());
},
function(safe, taint, callback) {
sink(taint); // NOT OK
sink(safe); // OK
callback(null, taint, safe);
},
function(taint, safe, callback) {
callback(null, taint, safe);
}
],
function finalCallback(err, taint, safe) {
sink(taint); // NOT OK
sink(safe); // OK
}
);
async_.waterfall([
function(callback) {
if (somethingWrong()) {
callback(source());
} else {
callback(null, 'safe');
}
},
function(safe, callback) {
sink(safe); // OK
callback(null, safe);
}
],
function(err, safe) {
sink(err); // NOT OK
sink(safe); // OK
}
);
waterfall([
function(callback) {
callback(null, source());
},
function(taint, callback) {
sink(taint); // NOT OK
callback(null, taint);
}
],
function(err, taint) {
sink(err); // OK
sink(taint); // NOT OK
}
);