Fix msgpack node to handle more than just objects...

Fix to close Issue #482 and #483
This commit is contained in:
Dave C-J
2014-11-09 14:28:09 +00:00
parent 8b689ca09b
commit 7474905b08
3 changed files with 8 additions and 13 deletions

View File

@@ -24,26 +24,22 @@ module.exports = function(RED) {
this.on("input", function(msg) {
if (Buffer.isBuffer(msg.payload)) {
var l = msg.payload.length;
msg.payload = msgpack.decode(msg.payload);
if (typeof msg.payload === "object") {
try {
msg.payload = msgpack.decode(msg.payload);
node.send(msg);
node.status({text:l +" b->o "+ JSON.stringify(msg.payload).length});
}
else {
node.warn("Input not a MsgPack buffer");
catch (e) {
node.warn("Bad decode: "+e);
node.status({text:"not a msgpack buffer"});
}
}
else if (typeof msg.payload === "object") {
else {
var l = JSON.stringify(msg.payload).length;
msg.payload = msgpack.encode(msg.payload);
node.send(msg);
node.status({text:l +" o->b "+ msg.payload.length});
}
else {
node.warn("This node only handles js objects or msgpack buffers.");
node.status({text:"error"});
}
});
}
RED.nodes.registerType("msgpack",MsgPackNode);