fix slight wrinkle in new Wemo node

This commit is contained in:
Dave Conway-Jones 2016-04-09 18:06:29 +01:00
parent 48bcd3c7df
commit c54a019899
2 changed files with 349 additions and 352 deletions

View File

@ -170,7 +170,7 @@
var devs = Object.keys(data); var devs = Object.keys(data);
if (devs.length !== 0) { if (devs.length !== 0) {
for (var d in devs) { for (var d in devs) {
if (dev.hasOwnProperty(d)) { if (devs.hasOwnProperty(d)) {
$('<option/>',{ $('<option/>',{
'value': devs[d], 'value': devs[d],
'text': data[devs[d]].name 'text': data[devs[d]].name

View File

@ -23,7 +23,7 @@ var interval = setInterval(wemo.start.bind(wemo), 60000);
wemo.start(); wemo.start();
module.exports = function(RED) { module.exports = function(RED) {
"use strict"; 'use strict';
var util = require('util'); var util = require('util');
var ip = require('ip'); var ip = require('ip');
var bodyParser = require('body-parser'); var bodyParser = require('body-parser');
@ -56,9 +56,9 @@ module.exports = function(RED) {
var resub_request = http.request(reSubOptions, function(res) { var resub_request = http.request(reSubOptions, function(res) {
//shoudl raise an error if needed //shoudl raise an error if needed
if (res.statusCode != 200) { if (res.statusCode != 200) {
console.log("problem with resubscription %s - %s", res.statusCode, res.statusMessage); console.log('problem with resubscription %s - %s', res.statusCode, res.statusMessage);
console.log("opts - %s", util.inspect(reSubOptions)); console.log('opts - %s', util.inspect(reSubOptions));
console.log("dev - %s", util.inspect(dev)); console.log('dev - %s', util.inspect(dev));
delete subscriptions[dev]; delete subscriptions[dev];
delete sub2dev[sub.sid]; delete sub2dev[sub.sid];
subscribe({dev: subs[s]}); subscribe({dev: subs[s]});
@ -81,7 +81,7 @@ module.exports = function(RED) {
} }
} }
} };
setInterval(resubscribe, 200000); setInterval(resubscribe, 200000);
@ -136,7 +136,7 @@ module.exports = function(RED) {
callback_url += 'wemoNG/notification'; callback_url += 'wemoNG/notification';
console.log("Callback URL = %s",callback_url); console.log('Callback URL = %s',callback_url);
var subscribeOptions = { var subscribeOptions = {
host: device.ip, host: device.ip,
@ -158,14 +158,14 @@ module.exports = function(RED) {
subscriptions[dev] = {'count': 1, 'sid': res.headers.sid}; subscriptions[dev] = {'count': 1, 'sid': res.headers.sid};
sub2dev[res.headers.sid] = dev; sub2dev[res.headers.sid] = dev;
} else { } else {
console.log("failed to subsrcibe"); console.log('failed to subsrcibe');
} }
}); });
sub_request.end(); sub_request.end();
} }
} }
} };
function unsubscribe(node) { function unsubscribe(node) {
var dev = node.dev; var dev = node.dev;
@ -206,8 +206,8 @@ module.exports = function(RED) {
var wemoNGConfig = function(n) { var wemoNGConfig = function(n) {
RED.nodes.createNode(this,n); RED.nodes.createNode(this,n);
this.device = n.device; this.device = n.device;
} };
RED.nodes.registerType("wemo-dev", wemoNGConfig); RED.nodes.registerType('wemo-dev', wemoNGConfig);
var wemoNGNode = function(n) { var wemoNGNode = function(n) {
RED.nodes.createNode(this,n); RED.nodes.createNode(this,n);
@ -215,17 +215,17 @@ module.exports = function(RED) {
node.device = n.device; node.device = n.device;
node.name = n.name; node.name = n.name;
node.dev = RED.nodes.getNode(node.device).device; node.dev = RED.nodes.getNode(node.device).device;
node.status({fill:"red",shape:"dot",text:"searching"}); node.status({fill: 'red',shape: 'dot',text: 'searching'});
//console.log("Control - %j" ,this.dev); //console.log("Control - %j" ,this.dev);
if (!wemo.get(node.dev)) { if (!wemo.get(node.dev)) {
wemo.on('discovered', function(d) { wemo.on('discovered', function(d) {
if (node.dev === d) { if (node.dev === d) {
node.status({fill:"green",shape:"dot",text:"found"}); node.status({fill: 'green',shape: 'dot',text: 'found'});
} }
}); });
} else { } else {
node.status({fill:"green",shape:"dot",text:"found"}); node.status({fill: 'green',shape: 'dot',text: 'found'});
} }
node.on('input', function(msg) { node.on('input', function(msg) {
@ -233,7 +233,7 @@ module.exports = function(RED) {
if (!dev) { if (!dev) {
//need to show that dev not currently found //need to show that dev not currently found
console.log("no device found"); console.log('no device found');
return; return;
} }
@ -253,7 +253,7 @@ module.exports = function(RED) {
if (msg.payload.state && typeof msg.payload.state === 'number') { if (msg.payload.state && typeof msg.payload.state === 'number') {
if (dev.type === 'socket') { if (dev.type === 'socket') {
if (msg.payload >= 0 && msg.payload < 2) { if (msg.payload >= 0 && msg.payload < 2) {
on = msg.payload.state on = msg.payload.state;
} }
} else if (dev.type === 'light' || dev.type === 'group') { } else if (dev.type === 'light' || dev.type === 'group') {
if (msg.payload >= 0 && msg.payload < 3) { if (msg.payload >= 0 && msg.payload < 3) {
@ -272,14 +272,14 @@ module.exports = function(RED) {
wemo.toggleSocket(dev, on); wemo.toggleSocket(dev, on);
} else if (dev.type === 'light`') { } else if (dev.type === 'light`') {
//console.log("light"); //console.log("light");
wemo.setStatus(dev,"10006", on); wemo.setStatus(dev,'10006', on);
} else { } else {
console.log("group"); console.log('group');
wemo.setStatus(dev, "10006", on); wemo.setStatus(dev, '10006', on);
} }
}); });
} };
RED.nodes.registerType("wemo out", wemoNGNode); RED.nodes.registerType('wemo out', wemoNGNode);
var wemoNGEvent = function(n) { var wemoNGEvent = function(n) {
RED.nodes.createNode(this,n); RED.nodes.createNode(this,n);
@ -290,7 +290,7 @@ module.exports = function(RED) {
node.topic = n.topic; node.topic = n.topic;
node.dev = RED.nodes.getNode(node.device).device; node.dev = RED.nodes.getNode(node.device).device;
node.status({fill:"red",shape:"dot",text:"searching"}); node.status({fill: 'red',shape: 'dot',text: 'searching'});
var onEvent = function(notification) { var onEvent = function(notification) {
var d = sub2dev[notification.sid]; var d = sub2dev[notification.sid];
@ -328,12 +328,12 @@ module.exports = function(RED) {
if (node.dev) { if (node.dev) {
//subscribe to events //subscribe to events
if (wemo.get(node.dev)) { if (wemo.get(node.dev)) {
node.status({fill:"green",shape:"dot",text:"found"}); node.status({fill: 'green',shape: 'dot',text: 'found'});
subscribe(node); subscribe(node);
} else { } else {
wemo.on('discovered', function(d) { wemo.on('discovered', function(d) {
if (node.dev === d) { if (node.dev === d) {
node.status({fill:"green",shape:"dot",text:"found"}); node.status({fill: 'green',shape: 'dot',text: 'found'});
subscribe(node); subscribe(node);
} }
}); });
@ -346,7 +346,7 @@ module.exports = function(RED) {
var device = devices[d]; var device = devices[d];
if (device.ip === node.ipaddr) { if (device.ip === node.ipaddr) {
node.dev = device.id; node.dev = device.id;
node.status({fill:"green",shape:"circle",text:"reconfigure"}); node.status({fill: 'green',shape: 'circle',text: 'reconfigure'});
subscribe(node); subscribe(node);
break; break;
} }
@ -354,19 +354,17 @@ module.exports = function(RED) {
} }
} }
node.on('close', function(done) { node.on('close', function(done) {
//should un subscribe from events //should un subscribe from events
wemo.removeListener('event', onEvent); wemo.removeListener('event', onEvent);
unsubscribe(node); unsubscribe(node);
done(); done();
}); });
} };
RED.nodes.registerType("wemo in", wemoNGEvent) RED.nodes.registerType('wemo in', wemoNGEvent);
RED.httpAdmin.get('/wemoNG/devices', function(req, res) { RED.httpAdmin.get('/wemoNG/devices', function(req, res) {
res.json(wemo.devices); res.json(wemo.devices);
}); });
RED.httpAdmin.use('/wemoNG/notification',bodyParser.raw({type: 'text/xml'})); RED.httpAdmin.use('/wemoNG/notification',bodyParser.raw({type: 'text/xml'}));
@ -380,7 +378,6 @@ module.exports = function(RED) {
evt.sid = notification.sid; evt.sid = notification.sid;
wemo.emit('event',evt); wemo.emit('event',evt);
}); });
res.send(""); res.send('');
}); });
};
}