From ea763fdfd53fa9e27f87ae8ab86ad4c4d0f666d0 Mon Sep 17 00:00:00 2001 From: Nick O'Leary Date: Sun, 14 Jan 2018 00:33:25 +0000 Subject: [PATCH] File out - create dirs synchronously to ensure they exist Fixes #1489 --- nodes/core/storage/50-file.js | 13 ++++++++----- package.json | 2 +- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/nodes/core/storage/50-file.js b/nodes/core/storage/50-file.js index 86795796e..5623b4de8 100644 --- a/nodes/core/storage/50-file.js +++ b/nodes/core/storage/50-file.js @@ -49,9 +49,12 @@ module.exports = function(RED) { else if (msg.hasOwnProperty("payload") && (typeof msg.payload !== "undefined")) { var dir = path.dirname(filename); if (node.createDir) { - fs.ensureDir(dir, function(err) { - if (err) { node.error(RED._("file.errors.createfail",{error:err.toString()}),msg); } - }); + try { + fs.ensureDirSync(dir); + } catch(err) { + node.error(RED._("file.errors.createfail",{error:err.toString()}),msg); + return; + } } var data = msg.payload; @@ -60,11 +63,11 @@ module.exports = function(RED) { } if (typeof data === "boolean") { data = data.toString(); } if (typeof data === "number") { data = data.toString(); } - if ((this.appendNewline) && (!Buffer.isBuffer(data))) { data += os.EOL; } + if ((node.appendNewline) && (!Buffer.isBuffer(data))) { data += os.EOL; } node.data.push(Buffer.from(data)); while (node.data.length > 0) { - if (this.overwriteFile === "true") { + if (node.overwriteFile === "true") { node.wstream = fs.createWriteStream(filename, { encoding:'binary', flags:'w', autoClose:true }); node.wstream.on("error", function(err) { node.error(RED._("file.errors.writefail",{error:err.toString()}),msg); diff --git a/package.json b/package.json index cbaa2fd7f..1159492b8 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "express": "4.16.2", "express-session": "1.15.6", "follow-redirects": "1.3.0", - "fs-extra": "1.0.0", + "fs-extra": "5.0.0", "fs.notify": "0.0.4", "hash-sum": "1.0.2", "i18next": "1.10.6",