From 46cc9bb906d42aa93e2a6a01a9f5540ea82fe5e5 Mon Sep 17 00:00:00 2001 From: Ben Hardill Date: Fri, 24 Jun 2016 11:06:59 +0100 Subject: [PATCH] Added more error checking in the discovery section (#214) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Replacing the original wemo node with the wemo-ng node * Added install instructions * Fix name of wemo out node * Fix some jshint errors More jshint fixes fix jshint last jshint fix Fix last jshint error * Adds proper url length detection * fix up the extra line added in the merge * Fix some jshint errors More jshint fixes fix jshint last jshint fix Fix last jshint error load of tiny listing fixes, undef, unused, etc fix slight wrinkle in new Wemo node Fix wemo package name for npm. Add contribution.md to node-red-nodes to make it more obvious. correct spelling in readme.md revert .jshintrc Added subtree and walker nodes. (#200) Thanks @mikakaraila - very useful. slight edits to snmp to pass jslint-ing Bump underlying serial port nam version correct BBB callback response to check exists To Fix #198 * Adds proper url length detection fix up the extra line added in the merge * Added some more error checking in discovery * Adds proper url length detection* fix up the extra line added in the merge * Adds proper url length detection * fix up the extra line added in the merge Add line output mode for Daemon node to address #202 Email rework (#195) * Rework of Node-RED email nodes tidy up email listing - no code changes add latest email node dips and update email node libs - bump version update package version for nodes tests add a few tests geohash, smooth, base64, msgpack correct path of source file Thanks @Ltrlg Fix typo in node-red-node-smooth (#205) node-red-node-physical-web: Added msg.advertising = true/false to enable/disable advertising (#204) * Added msg.advertising = true/false to enable/disable advertising * Fixed comparison with bool Don't use get_compass as it breaks get_orientation add envelope to email node options as part of node-red#875 Physical-web: Added status (found, updated and lost) as msg.topic (#206) Added msg.advertising = true/false to enable/disable advertising Added status (lost, updated, found) as msg.topic, if not already set Added checkbox to allow duplicates or not. * Re-added optional topic to avoid breaking compatibility * Cleaner topic slection add a v0.3 serial port to help with node5/6 let PI try to enable sensorTag access on install Add cc and bcc options to email node to close #209 updates to email node to better handle different mail types. Still not great - but does the basics… To close Better email node parsing (again) Fix indent fixed formating * Fix heading in README.md Fix node name in README.md --- hardware/wemo/README.md | 2 +- hardware/wemo/lib/wemo.js | 210 +++++++++++++++++++------------------ hardware/wemo/package.json | 2 +- 3 files changed, 112 insertions(+), 102 deletions(-) diff --git a/hardware/wemo/README.md b/hardware/wemo/README.md index 57e4a44f..3f5fe7f1 100644 --- a/hardware/wemo/README.md +++ b/hardware/wemo/README.md @@ -1,4 +1,4 @@ -# node-red-contrib-nodes-wemo +# node-red-node-wemo A set of Node-RED nodes for working with Belkin WeMo devices. diff --git a/hardware/wemo/lib/wemo.js b/hardware/wemo/lib/wemo.js index d3822fed..757a8f85 100644 --- a/hardware/wemo/lib/wemo.js +++ b/hardware/wemo/lib/wemo.js @@ -79,119 +79,129 @@ WeMoNG.prototype.start = function start() { var location = url.parse(headers.LOCATION); var port = location.port; request.get(location.href, function(err, res, xml) { - xml2js.parseString(xml, function(err, json) { - var device = { ip: location.hostname, port: location.port }; - for (var key in json.root.device[0]) { - device[key] = json.root.device[0][key][0]; - } - if (device.deviceType == "urn:Belkin:device:bridge:1") { - //console.log( device.ip + ' -' + device.deviceType); - var ip = device.ip; - var port = device.port; - var udn = device.UDN; - var postoptions = { - host: ip, - port: port, - path: getenddevs.path, - method: 'POST', - headers: { - 'SOAPACTION': getenddevs.action, - 'Content-Type': 'text/xml; charset="utf-8"', - 'Accept': '' + if (!err) { + xml2js.parseString(xml, function(err, json) { + if (!err) { + var device = { ip: location.hostname, port: location.port }; + for (var key in json.root.device[0]) { + device[key] = json.root.device[0][key][0]; } - }; + if (device.deviceType == "urn:Belkin:device:bridge:1") { + //console.log( device.ip + ' -' + device.deviceType); + var ip = device.ip; + var port = device.port; + var udn = device.UDN; + var postoptions = { + host: ip, + port: port, + path: getenddevs.path, + method: 'POST', + headers: { + 'SOAPACTION': getenddevs.action, + 'Content-Type': 'text/xml; charset="utf-8"', + 'Accept': '' + } + }; - var post_request = http.request(postoptions, function(res) { - var data = ""; - res.setEncoding('utf8'); - res.on('data', function(chunk) { - data += chunk; - }); + var post_request = http.request(postoptions, function(res) { + var data = ""; + res.setEncoding('utf8'); + res.on('data', function(chunk) { + data += chunk; + }); - res.on('end',function() { - xml2js.parseString(data, function(err, result) { - if(!err) { - var list = result["s:Envelope"]["s:Body"][0]["u:GetEndDevicesResponse"][0].DeviceLists[0]; - xml2js.parseString(list, function(err, result2) { - if (!err) { - var devinfo = result2.DeviceLists.DeviceList[0].DeviceInfos[0].DeviceInfo; - for (var i=0; i