1
0
mirror of https://github.com/node-red/node-red.git synced 2023-10-10 13:36:53 +02:00

Always request buffer

This commit is contained in:
bartbutenaers 2017-03-05 15:07:16 +01:00
parent 5ec63e36fd
commit c190964f85

View File

@ -156,30 +156,19 @@ module.exports = function(RED) {
tlsNode.addTLSOptions(opts); tlsNode.addTLSOptions(opts);
} }
var req = ((/^https/.test(urltotest))?https:http).request(opts,function(res) { var req = ((/^https/.test(urltotest))?https:http).request(opts,function(res) {
//(node.ret === "bin") ? res.setEncoding('binary') : res.setEncoding('utf8'); // Force NodeJs to return a Buffer (instead of a string)
if (node.ret === "bin") { // See https://github.com/nodejs/node/issues/6038
// Force NodeJs to return a Buffer instead of a string res.setEncoding(null);
// See https://github.com/nodejs/node/issues/6038 delete res._readableState.decoder;
res.setEncoding(null);
delete res._readableState.decoder;
}
msg.statusCode = res.statusCode; msg.statusCode = res.statusCode;
msg.headers = res.headers; msg.headers = res.headers;
msg.responseUrl = res.responseUrl; msg.responseUrl = res.responseUrl;
if (node.ret === "bin") { msg.payload = [];
msg.payload = [];
}
else {
msg.payload = "";
}
// msg.url = url; // revert when warning above finally removed // msg.url = url; // revert when warning above finally removed
res.on('data',function(chunk) { res.on('data',function(chunk) {
if (node.ret === "bin") { msg.payload.push(chunk);
msg.payload.push(chunk);
}
else {
msg.payload += chunk;
}
}); });
res.on('end',function() { res.on('end',function() {
if (node.metric()) { if (node.metric()) {
@ -192,13 +181,18 @@ module.exports = function(RED) {
node.metric("size.bytes", msg, res.client.bytesRead); node.metric("size.bytes", msg, res.client.bytesRead);
} }
} }
if (node.ret === "bin") {
msg.payload = Buffer.concat(msg.payload); // Convert the payload to the required return type
} msg.payload = Buffer.concat(msg.payload); // bin
else if (node.ret === "obj") { if (node.ret !== "bin") {
try { msg.payload = JSON.parse(msg.payload); } msg.payload = msg.payload.toString('utf8'); // txt
catch(e) { node.warn(RED._("httpin.errors.json-error")); }
if (node.ret === "obj") {
try { msg.payload = JSON.parse(msg.payload); } // obj
catch(e) { node.warn(RED._("httpin.errors.json-error")); }
}
} }
node.send(msg); node.send(msg);
node.status({}); node.status({});
}); });