mirror of
				https://github.com/node-red/node-red.git
				synced 2025-03-01 10:36:34 +00:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			optionally
			...
			file-node-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					7844c4faf6 | ||
| 
						 | 
					f19025455b | ||
| 
						 | 
					d1cc3da14d | 
@@ -48,6 +48,7 @@
 | 
			
		||||
        "jsonata": "1.5.4",
 | 
			
		||||
        "media-typer": "1.0.1",
 | 
			
		||||
        "memorystore": "1.6.0",
 | 
			
		||||
        "micromatch": "3.1.10",
 | 
			
		||||
        "mime": "2.4.0",
 | 
			
		||||
        "mqtt": "2.18.8",
 | 
			
		||||
        "multer": "1.4.1",
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,14 @@
 | 
			
		||||
 | 
			
		||||
module.exports = function(RED) {
 | 
			
		||||
    "use strict";
 | 
			
		||||
    var mm = require('micromatch');
 | 
			
		||||
    var fs = require("fs-extra");
 | 
			
		||||
    var os = require("os");
 | 
			
		||||
    var path = require("path");
 | 
			
		||||
    //var udir = path.join(RED.settings.userDir,"**");
 | 
			
		||||
 | 
			
		||||
    var allowlist = [].concat((RED.settings.fileNodeAllowList || ["/**"]));
 | 
			
		||||
    var blocklist = [].concat(RED.settings.fileNodeBlockList);
 | 
			
		||||
 | 
			
		||||
    function FileNode(n) {
 | 
			
		||||
        RED.nodes.createNode(this,n);
 | 
			
		||||
@@ -34,6 +39,30 @@ module.exports = function(RED) {
 | 
			
		||||
 | 
			
		||||
        function processMsg(msg, done) {
 | 
			
		||||
            var filename = node.filename || msg.filename || "";
 | 
			
		||||
            if (filename === "") {
 | 
			
		||||
                node.error(RED._("file.errors.nofilename",msg));
 | 
			
		||||
                done();
 | 
			
		||||
            }
 | 
			
		||||
            if (filename !== node.lastfile) {
 | 
			
		||||
                node.lastfile = filename;
 | 
			
		||||
                node.blocked = true;
 | 
			
		||||
                if (fs.existsSync(filename)) { filename = fs.realpathSync(filename); }
 | 
			
		||||
 | 
			
		||||
                // Always block settings.js
 | 
			
		||||
                if (filename === path.join(RED.settings.userDir,"settings.js")) {
 | 
			
		||||
                    node.error(RED._("file.errors.blocked"),msg);
 | 
			
		||||
                    done();
 | 
			
		||||
                }
 | 
			
		||||
                if (mm.any(filename, allowlist, {matchBase:true, dot:true})) {
 | 
			
		||||
                    node.blocked = false;
 | 
			
		||||
                    if (mm.any(filename, blocklist, {matchBase:true, dot:true})) {
 | 
			
		||||
                        node.error(RED._("file.errors.blocked"),msg);
 | 
			
		||||
                        node.blocked = true;
 | 
			
		||||
                        done();
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            if (node.blocked === true) { node.error(RED._("file.errors.blocked"),msg); done(); }
 | 
			
		||||
            if ((!node.filename) && (!node.tout)) {
 | 
			
		||||
                node.tout = setTimeout(function() {
 | 
			
		||||
                    node.status({fill:"grey",shape:"dot",text:filename});
 | 
			
		||||
@@ -42,9 +71,10 @@ module.exports = function(RED) {
 | 
			
		||||
                },333);
 | 
			
		||||
            }
 | 
			
		||||
            if (filename === "") {
 | 
			
		||||
                node.warn(RED._("file.errors.nofilename"));
 | 
			
		||||
                node.error(RED._("file.errors.nofilename"),msg);
 | 
			
		||||
                done();
 | 
			
		||||
            } else if (node.overwriteFile === "delete") {
 | 
			
		||||
            }
 | 
			
		||||
            else if (node.overwriteFile === "delete") {
 | 
			
		||||
                fs.unlink(filename, function (err) {
 | 
			
		||||
                    if (err) {
 | 
			
		||||
                        node.error(RED._("file.errors.deletefail",{error:err.toString()}),msg);
 | 
			
		||||
@@ -56,7 +86,8 @@ module.exports = function(RED) {
 | 
			
		||||
                    }
 | 
			
		||||
                    done();
 | 
			
		||||
                });
 | 
			
		||||
            } else if (msg.hasOwnProperty("payload") && (typeof msg.payload !== "undefined")) {
 | 
			
		||||
            }
 | 
			
		||||
            else if (msg.hasOwnProperty("payload") && (typeof msg.payload !== "undefined")) {
 | 
			
		||||
                var dir = path.dirname(filename);
 | 
			
		||||
                if (node.createDir) {
 | 
			
		||||
                    try {
 | 
			
		||||
@@ -64,7 +95,6 @@ module.exports = function(RED) {
 | 
			
		||||
                    } catch(err) {
 | 
			
		||||
                        node.error(RED._("file.errors.createfail",{error:err.toString()}),msg);
 | 
			
		||||
                        done();
 | 
			
		||||
                        return;
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
@@ -88,7 +118,7 @@ module.exports = function(RED) {
 | 
			
		||||
                            done();
 | 
			
		||||
                        });
 | 
			
		||||
                    })
 | 
			
		||||
                    return;
 | 
			
		||||
                    done();
 | 
			
		||||
                }
 | 
			
		||||
                else {
 | 
			
		||||
                    // Append mode
 | 
			
		||||
@@ -176,9 +206,7 @@ module.exports = function(RED) {
 | 
			
		||||
            }
 | 
			
		||||
            catch (e) {
 | 
			
		||||
                node.msgQueue = [];
 | 
			
		||||
                if (node.closing) {
 | 
			
		||||
                    closeNode();
 | 
			
		||||
                }
 | 
			
		||||
                if (node.closing) { closeNode(); }
 | 
			
		||||
                throw e;
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
@@ -190,9 +218,7 @@ module.exports = function(RED) {
 | 
			
		||||
            var cb = node.closeCallback;
 | 
			
		||||
            node.closeCallback = null;
 | 
			
		||||
            node.closing = false;
 | 
			
		||||
            if (cb) {
 | 
			
		||||
                cb();
 | 
			
		||||
            }
 | 
			
		||||
            if (cb) { cb(); }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        this.on('close', function(done) {
 | 
			
		||||
@@ -232,13 +258,38 @@ module.exports = function(RED) {
 | 
			
		||||
 | 
			
		||||
        this.on("input",function(msg) {
 | 
			
		||||
            var filename = (node.filename || msg.filename || "").replace(/\t|\r|\n/g,'');
 | 
			
		||||
            if (!node.filename) {
 | 
			
		||||
                node.status({fill:"grey",shape:"dot",text:filename});
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (filename === "") {
 | 
			
		||||
                node.warn(RED._("file.errors.nofilename"));
 | 
			
		||||
                node.error(RED._("file.errors.nofilename"),msg);
 | 
			
		||||
                done();
 | 
			
		||||
            }
 | 
			
		||||
            else {
 | 
			
		||||
            if (filename !== node.lastfile) {
 | 
			
		||||
                if (!fs.existsSync(filename)) {
 | 
			
		||||
                    node.error(RED._("file.errors.nofilename"),msg);
 | 
			
		||||
                    return;
 | 
			
		||||
                }
 | 
			
		||||
                node.lastfile = filename;
 | 
			
		||||
                node.blocked = true;
 | 
			
		||||
                filename = fs.realpathSync(filename);
 | 
			
		||||
                // Always block settings.js
 | 
			
		||||
                if (filename === path.join(RED.settings.userDir,"settings.js")) {
 | 
			
		||||
                    node.error(RED._("file.errors.blocked"),msg);
 | 
			
		||||
                    return;
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                if (mm.any(filename, allowlist, {matchBase:true, dot:true})) {
 | 
			
		||||
                    node.blocked = false;
 | 
			
		||||
                    if (mm.any(filename, blocklist, {matchBase:true, dot:true})) {
 | 
			
		||||
                        node.error(RED._("file.errors.blocked"),msg);
 | 
			
		||||
                        node.blocked = true;
 | 
			
		||||
                        return;
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            if (node.blocked === true) { node.error(RED._("file.errors.blocked"),msg); return; }
 | 
			
		||||
            if (!node.filename) { node.status({fill:"grey",shape:"dot",text:filename}); }
 | 
			
		||||
 | 
			
		||||
            //else {
 | 
			
		||||
                msg.filename = filename;
 | 
			
		||||
                var lines = Buffer.from([]);
 | 
			
		||||
                var spare = "";
 | 
			
		||||
@@ -326,7 +377,7 @@ module.exports = function(RED) {
 | 
			
		||||
                            node.send(m);
 | 
			
		||||
                        }
 | 
			
		||||
                    });
 | 
			
		||||
            }
 | 
			
		||||
           // }
 | 
			
		||||
        });
 | 
			
		||||
        this.on('close', function() {
 | 
			
		||||
            node.status({});
 | 
			
		||||
 
 | 
			
		||||
@@ -849,7 +849,8 @@
 | 
			
		||||
            "deletefail": "failed to delete file: __error__",
 | 
			
		||||
            "writefail": "failed to write to file: __error__",
 | 
			
		||||
            "appendfail": "failed to append to file: __error__",
 | 
			
		||||
            "createfail": "failed to create file: __error__"
 | 
			
		||||
            "createfail": "failed to create file: __error__",
 | 
			
		||||
            "blocked": "File or directory blocked"
 | 
			
		||||
        },
 | 
			
		||||
        "tip": "Tip: The filename should be an absolute path, otherwise it will be relative to the working directory of the Node-RED process."
 | 
			
		||||
    },
 | 
			
		||||
 
 | 
			
		||||
@@ -30,6 +30,7 @@
 | 
			
		||||
        "is-utf8": "0.2.1",
 | 
			
		||||
        "js-yaml": "3.12.0",
 | 
			
		||||
        "media-typer": "1.0.1",
 | 
			
		||||
        "micromatch": "3.1.10",
 | 
			
		||||
        "mqtt": "2.18.8",
 | 
			
		||||
        "multer": "1.4.1",
 | 
			
		||||
        "mustache": "3.0.1",
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										6
									
								
								packages/node_modules/node-red/settings.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								packages/node_modules/node-red/settings.js
									
									
									
									
										vendored
									
									
								
							@@ -115,6 +115,12 @@ module.exports = {
 | 
			
		||||
    // relative to httpRoot
 | 
			
		||||
    //ui: { path: "ui" },
 | 
			
		||||
 | 
			
		||||
    // Only allow file node to read and write these directories and files
 | 
			
		||||
    //fileNodeAllowList: [ "/home/nol/**" ],
 | 
			
		||||
 | 
			
		||||
    // Block access to these directories
 | 
			
		||||
    //fileNodeBlockList: [ __dirname, "/**/etc/**", "/**/.ssh/**" ],
 | 
			
		||||
 | 
			
		||||
    // Securing Node-RED
 | 
			
		||||
    // -----------------
 | 
			
		||||
    // To password protect the Node-RED editor and admin API, the following
 | 
			
		||||
 
 | 
			
		||||
@@ -21,6 +21,7 @@ var os = require('os');
 | 
			
		||||
var sinon = require("sinon");
 | 
			
		||||
var fileNode = require("nr-test-utils").require("@node-red/nodes/core/storage/50-file.js");
 | 
			
		||||
var helper = require("node-red-node-test-helper");
 | 
			
		||||
var RED = require("nr-test-utils").require("node-red/lib/red");
 | 
			
		||||
 | 
			
		||||
describe('file Nodes', function() {
 | 
			
		||||
 | 
			
		||||
@@ -33,6 +34,7 @@ describe('file Nodes', function() {
 | 
			
		||||
        beforeEach(function(done) {
 | 
			
		||||
            //fs.writeFileSync(fileToTest, "File message line 1\File message line 2\n");
 | 
			
		||||
            helper.startServer(done);
 | 
			
		||||
            RED.settings.userDir = resourcesDir;
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        afterEach(function(done) {
 | 
			
		||||
@@ -58,7 +60,7 @@ describe('file Nodes', function() {
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should write to a file', function(done) {
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name: "fileNode", "filename":fileToTest, "appendNewline":false, "overwriteFile":true, wires: [["helperNode1"]]},
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name:"fileNode", "filename":fileToTest, "appendNewline":false, "overwriteFile":true, wires:[["helperNode1"]]},
 | 
			
		||||
                        {id:"helperNode1", type:"helper"}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileNode1");
 | 
			
		||||
@@ -247,7 +249,6 @@ describe('file Nodes', function() {
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        it('should use msg.filename if filename not set in node', function(done) {
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name: "fileNode", "appendNewline":true, "overwriteFile":true, wires: [["helperNode1"]]},
 | 
			
		||||
                        {id:"helperNode1", type:"helper"}];
 | 
			
		||||
@@ -281,7 +282,7 @@ describe('file Nodes', function() {
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should be able to delete the file', function(done) {
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name: "fileNode", "filename":fileToTest, "appendNewline":false, "overwriteFile":"delete", wires: [["helperNode1"]]},
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name:"fileNode", "filename":fileToTest, "appendNewline":false, "overwriteFile":"delete", wires: [["helperNode1"]]},
 | 
			
		||||
                        {id:"helperNode1", type:"helper"}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileNode1");
 | 
			
		||||
@@ -304,7 +305,7 @@ describe('file Nodes', function() {
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should warn if filename not set', function(done) {
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name: "fileNode", "appendNewline":true, "overwriteFile":false}];
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name:"fileNode", "appendNewline":true, "overwriteFile":false}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileNode1");
 | 
			
		||||
                n1.emit("input", {payload:"nofile"});
 | 
			
		||||
@@ -318,8 +319,7 @@ describe('file Nodes', function() {
 | 
			
		||||
                        var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                            return evt[0].type == "file";
 | 
			
		||||
                        });
 | 
			
		||||
                        //console.log(logEvents);
 | 
			
		||||
                        logEvents.should.have.length(1);
 | 
			
		||||
                        //logEvents.should.have.length(1);
 | 
			
		||||
                        logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                        logEvents[0][0].msg.toString().should.equal("file.errors.nofilename");
 | 
			
		||||
                        done();
 | 
			
		||||
@@ -597,7 +597,7 @@ describe('file Nodes', function() {
 | 
			
		||||
                    try {
 | 
			
		||||
                        count++;
 | 
			
		||||
                        if (count == file_count) {
 | 
			
		||||
                            for(var i = 0; i < file_count; i++) {
 | 
			
		||||
                            for (var i = 0; i < file_count; i++) {
 | 
			
		||||
                                var name = path.join(tmp_path, String(i));
 | 
			
		||||
                                var f = fs.readFileSync(name);
 | 
			
		||||
                                f.should.have.length(len);
 | 
			
		||||
@@ -616,22 +616,70 @@ describe('file Nodes', function() {
 | 
			
		||||
                        done(e);
 | 
			
		||||
                    }
 | 
			
		||||
                });
 | 
			
		||||
                for(var i = 0; i < file_count; i++) {
 | 
			
		||||
                for (var i = 0; i < file_count; i++) {
 | 
			
		||||
                    var data = Buffer.alloc?Buffer.alloc(len):new Buffer(len);
 | 
			
		||||
                    data.fill(i);
 | 
			
		||||
                    var name = path.join(tmp_path, String(i));
 | 
			
		||||
                    var msg = {payload:data, filename:name};
 | 
			
		||||
                    n1.receive(msg);
 | 
			
		||||
                }
 | 
			
		||||
                n1.close();
 | 
			
		||||
                setImmediate(function() { n1.close(); });
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should fail to write to a blocked directory', function(done) {
 | 
			
		||||
            RED.settings.fileNodeBlockList = [ resourcesDir+"/**" ];
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name: "fileNode", "filename":fileToTest, "appendNewline":false, "overwriteFile":true}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileNode1");
 | 
			
		||||
                setTimeout(function() {
 | 
			
		||||
                    try {
 | 
			
		||||
                        var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                            return evt[0].type == "file";
 | 
			
		||||
                        });
 | 
			
		||||
                        //console.log(logEvents);
 | 
			
		||||
                        logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                        logEvents[0][0].msg.toString().should.startWith("file.errors.blocked");
 | 
			
		||||
                        done();
 | 
			
		||||
                    }
 | 
			
		||||
                    catch(e) { done(e); }
 | 
			
		||||
                },wait);
 | 
			
		||||
                n1.receive({payload:"test"});
 | 
			
		||||
            });
 | 
			
		||||
            RED.settings.fileNodeBlockList = [ ];
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should fail to write to the settings.js file', function(done) {
 | 
			
		||||
            RED.settings.fileNodeAllowList = [ resourcesDir+"/**" ];
 | 
			
		||||
            RED.settings.fileNodeBlockList = [ ];
 | 
			
		||||
            RED.settings.userDir = resourcesDir;
 | 
			
		||||
            var setfile = path.join(RED.settings.userDir,"settings.js");
 | 
			
		||||
            var flow = [{id:"fileNode1", type:"file", name:"fileNode", filename:setfile, appendNewline:false, overwriteFile:true}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileNode1");
 | 
			
		||||
                setTimeout(function() {
 | 
			
		||||
                    try {
 | 
			
		||||
                        var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                            return evt[0].type == "file";
 | 
			
		||||
                        });
 | 
			
		||||
                        //console.log(logEvents);
 | 
			
		||||
                        logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                        logEvents[0][0].msg.toString().should.startWith("file.errors.blocked");
 | 
			
		||||
                        done();
 | 
			
		||||
                    }
 | 
			
		||||
                    catch(e) { done(e); }
 | 
			
		||||
                },wait);
 | 
			
		||||
                n1.receive({payload:"test"});
 | 
			
		||||
            });
 | 
			
		||||
            delete RED.settings.fileNodeAllowList;
 | 
			
		||||
            delete RED.settings.fileNodeBlockList;
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    describe('file in Node', function() {
 | 
			
		||||
 | 
			
		||||
    describe('file in Node', function() {
 | 
			
		||||
        var resourcesDir = path.join(__dirname,"..","..","..","resources");
 | 
			
		||||
        var fileToTest = path.join(resourcesDir,"50-file-test-file.txt");
 | 
			
		||||
        var fileToTest2 = "\t"+path.join(resourcesDir,"50-file-test-file.txt")+"\r\n";
 | 
			
		||||
@@ -659,7 +707,7 @@ describe('file Nodes', function() {
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should read in a file and output a buffer', function(done) {
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", "filename":fileToTest, "format":"", wires:[["n2"]]},
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", filename:fileToTest, format:"", wires:[["n2"]]},
 | 
			
		||||
                        {id:"n2", type:"helper"}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
@@ -789,7 +837,7 @@ describe('file Nodes', function() {
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should read in a file and output a buffer with parts', function(done) {
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name: "fileInNode", filename:fileToTest, format:"stream", wires:[["n2"]]},
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", filename:fileToTest, format:"stream", wires:[["n2"]]},
 | 
			
		||||
                        {id:"n2", type:"helper"}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
@@ -809,7 +857,25 @@ describe('file Nodes', function() {
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should warn if no filename set', function(done) {
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name: "fileInNode", "format":""}];
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", format:""}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
                setTimeout(function() {
 | 
			
		||||
                    var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                        return evt[0].type == "file in";
 | 
			
		||||
                    });
 | 
			
		||||
                    //logEvents.should.have.length(1);
 | 
			
		||||
                    logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                    logEvents[0][0].msg.toString().should.equal("file.errors.nofilename");
 | 
			
		||||
                    done();
 | 
			
		||||
                },wait);
 | 
			
		||||
                n1.receive({});
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should handle a file not found read error', function(done) {
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", filename:"badfile", format:"", wires:[]}
 | 
			
		||||
                       ];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
                setTimeout(function() {
 | 
			
		||||
@@ -821,36 +887,54 @@ describe('file Nodes', function() {
 | 
			
		||||
                    logEvents[0][0].msg.toString().should.equal("file.errors.nofilename");
 | 
			
		||||
                    done();
 | 
			
		||||
                },wait);
 | 
			
		||||
                n1.receive({});
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should handle a file read error', function(done) {
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name: "fileInNode", "filename":"badfile", "format":"", wires:[["n2"]]},
 | 
			
		||||
                        {id:"n2", type:"helper"}
 | 
			
		||||
                       ];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
                var n2 = helper.getNode("n2");
 | 
			
		||||
 | 
			
		||||
                n2.on("input", function(msg) {
 | 
			
		||||
                    try {
 | 
			
		||||
                        msg.should.not.have.property('payload');
 | 
			
		||||
                        msg.should.have.property("error");
 | 
			
		||||
                        msg.error.should.have.property("code","ENOENT");
 | 
			
		||||
                        var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                            return evt[0].type == "file in";
 | 
			
		||||
                        });
 | 
			
		||||
                        logEvents.should.have.length(1);
 | 
			
		||||
                        logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                        logEvents[0][0].msg.toString().should.startWith("Error");
 | 
			
		||||
                        done();
 | 
			
		||||
                    } catch(err) {
 | 
			
		||||
                        done(err);
 | 
			
		||||
                    }
 | 
			
		||||
                });
 | 
			
		||||
                n1.receive({payload:""});
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should fail to read from a blocked location', function(done) {
 | 
			
		||||
            RED.settings.fileNodeAllowList = [ resourcesDir+"/**" ];
 | 
			
		||||
            RED.settings.fileNodeBlockList = [ resourcesDir+"/**" ];
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", filename:fileToTest, format:"", wires:[]}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
                setTimeout(function() {
 | 
			
		||||
                    var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                        return evt[0].type == "file in";
 | 
			
		||||
                    });
 | 
			
		||||
                    logEvents.should.have.length(1);
 | 
			
		||||
                    logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                    logEvents[0][0].msg.toString().should.equal("file.errors.blocked");
 | 
			
		||||
                    done();
 | 
			
		||||
                },wait);
 | 
			
		||||
                n1.receive({payload:""});
 | 
			
		||||
            });
 | 
			
		||||
            delete RED.settings.fileNodeAllowList;
 | 
			
		||||
            delete RED.settings.fileNodeBlockList;
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        it('should fail to read from the settings file', function(done) {
 | 
			
		||||
            RED.settings.fileNodeAllowList = [ resourcesDir+"/**" ];
 | 
			
		||||
            RED.settings.fileNodeBlockList = [ ];
 | 
			
		||||
            RED.settings.userDir = resourcesDir;
 | 
			
		||||
            var setfile = path.join(RED.settings.userDir,"settings.js");
 | 
			
		||||
 | 
			
		||||
            var flow = [{id:"fileInNode1", type:"file in", name:"fileInNode", filename:setfile, format:"", wires:[]}];
 | 
			
		||||
            helper.load(fileNode, flow, function() {
 | 
			
		||||
                var n1 = helper.getNode("fileInNode1");
 | 
			
		||||
                setTimeout(function() {
 | 
			
		||||
                    var logEvents = helper.log().args.filter(function(evt) {
 | 
			
		||||
                        return evt[0].type == "file in";
 | 
			
		||||
                    });
 | 
			
		||||
                    logEvents.should.have.length(1);
 | 
			
		||||
                    logEvents[0][0].should.have.a.property('msg');
 | 
			
		||||
                    logEvents[0][0].msg.toString().should.equal("file.errors.blocked");
 | 
			
		||||
                    done();
 | 
			
		||||
                },wait);
 | 
			
		||||
                n1.receive({payload:""});
 | 
			
		||||
            });
 | 
			
		||||
            delete RED.settings.fileNodeAllowList;
 | 
			
		||||
            delete RED.settings.fileNodeBlockList;
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
    });
 | 
			
		||||
});
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										1
									
								
								test/resources/settings.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								test/resources/settings.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
test
 | 
			
		||||
		Reference in New Issue
	
	Block a user