このコード リストを実行すると、非同期呼び出しが正しく行われていないのはなぜですか? 私は物事を動かし、それらを機能に分割してきましたが、実行間でまだ競争が続いています。
実行したい順序はネストにありますが、機能していないため何か問題があると思います。
server.route({
method: 'POST',
path: '/convert',
config: {
validate: {
payload: {
fileUpload: Joi.object({
headers: Joi.object({
'content-type': Joi.string().valid(['application/pdf']).required(),
}).unknown().required()
}).unknown()
}
},
payload: {
output: 'file',
maxBytes: 209715200,
uploads:'./thumbs'
},
handler: function(request, reply) {
var newPath,
filename,
filenamePng;
fs.readFile(request.payload.fileUpload.path, function(err, data) {
filename = request.payload.fileUpload.filename;
filenamePng = filename.substr(0, filename.indexOf('.'));
newPath = __dirname + "/thumbs/";
fs.writeFile(newPath + filename, data, function(err) {
ChildProcess.exec('cd ' + newPath + ' && convert ' + filename + ' -thumbnail 50% ' + filenamePng + '_thumb_page_' + '%d' + '.png', function(error) {
fs.readdir(__dirname + "/thumbs", function(error, list) {
list.forEach(function(element) {
element = element.toString();
Thumbs.addThumbnail(Thumbs.thumbnailArray, {name: element, url: './thumbs/' + element });
});
var tmpFN = request.payload.fileUpload.path;
fs.unlink(tmpFN, function(err){
if(err){
console.log(err);
}
else {
console.log('/tmp/file deleted')
// reply(Thumbs.showThumbnails(Thumbs.thumbs));
};
});
reply(Thumbs.showThumbnails(Thumbs.thumbs));
});
});
});
process.on('exit', function(code) {
console.log('PROCESS FINISHED');
});
});
}
}
});