tuya mqtt client added and code seperation

This commit is contained in:
KarstenSiedentopp
2018-06-23 13:25:40 +02:00
parent 09f6ad7f7f
commit 2e2d5801d3
7 changed files with 1147 additions and 109 deletions

View File

@@ -1,57 +1,103 @@
const mqtt = require('mqtt');
const TuyaDevice = require('./tuya-connector');
const CronJob = require('cron').CronJob;
const autoUpdate = [];
/**
* MQTT Settings
*/
var Topic = '#'; //subscribe to all topics
var options = {
clientId: 'MyMQTT',
clientId: 'tuya_mqtt',
port: 1883,
keepalive: 60
};
const client = mqtt.connect({
host: 'localhost',
port: 1883
});
client.on('connect', mqtt_connect);
client.on('reconnect', mqtt_reconnect);
client.on('error', mqtt_error);
client.on('message', mqtt_messsageReceived);
client.on('close', mqtt_close);
function mqtt_connect() {
console.log("Connecting MQTT");
client.subscribe(Topic, mqtt_subscribe);
function bmap(istate) {
return istate ? 'ON' : "OFF";
}
function mqtt_subscribe(err, granted) {
console.log("Subscribed to " + Topic);
if (err) {
console.log(err);
client.on('connect', function () {
var topic = 'tuya/#';
client.subscribe(topic);
})
var knowDevice = function (tuyaID, tuyaKey, tuyaIP) {
var isKnown = false;
autoUpdate.forEach(function (entry) {
if (entry.id == tuyaID && entry.key == tuyaKey && entry.ip == tuyaIP) {
isKnown = true;
}
});
return isKnown;
}
var addDevice = function (tuyaID, tuyaKey, tuyaIP) {
var newDevice = {
id: tuyaID,
key: tuyaKey,
ip: tuyaIP
};
autoUpdate.push(newDevice);
}
exports.publishStatus = function (tuyaID, tuyaKey, tuyaIP, status) {
if (tuyaID != undefined && tuyaKey != undefined && tuyaIP != undefined) {
var topic = "tuya/socket/" + tuyaID + "/" + tuyaKey + "/" + tuyaIP + "/state";
client.publish(topic, status, {
retain: true,
qos: 2
});
}
}
function mqtt_reconnect(err) {
console.log("Reconnect MQTT");
if (err) {
console.log(err);
}
client = mqtt.connect(Broker_URL, options);
}
function mqtt_error(err) {
console.log("Error!");
if (err) {
console.log(err);
exports.setStatus = function (tuyaID, tuyaKey, tuyaIP, status) {
if (tuyaID != undefined && tuyaKey != undefined && tuyaIP != undefined) {
if (!knowDevice(tuyaID, tuyaKey, tuyaIP)) {
addDevice(tuyaID, tuyaKey, tuyaIP);
}
TuyaDevice.createDevice(tuyaID, tuyaKey, tuyaIP);
if (TuyaDevice.hasDevice()) {
TuyaDevice.setStatus(status, function (newStatus) {
module.exports.publishStatus(tuyaID, tuyaKey, tuyaIP, newStatus);
});
}
}
}
function after_publish() {
//do nothing
exports.getStatus = function (tuyaID, tuyaKey, tuyaIP) {
if (tuyaID != undefined && tuyaKey != undefined && tuyaIP != undefined) {
TuyaDevice.createDevice(tuyaID, tuyaKey, tuyaIP);
if (TuyaDevice.hasDevice()) {
TuyaDevice.getStatus(function (status) {
module.exports.publishStatus(tuyaID, tuyaKey, tuyaIP, bmap(status));
})
}
}
}
function mqtt_messsageReceived(topic, message, packet) {
console.log('Topic=' + topic + ' Message=' + message);
}
client.on('message', function (topic, message) {
try {
var topic = topic.split("/");
var type = topic[1];
var exec = topic[5];
if (type == "socket" && exec == "command" && topic.length == 7) {
module.exports.setStatus(topic[2], topic[3], topic[4], topic[6]);
}
} catch (e) {
console.error(e);
}
});
function mqtt_close() {
console.log("Close MQTT");
}
new CronJob('0 */1 * * * *', function () {
try {
autoUpdate.forEach(function (entry) {
module.exports.getStatus(entry.id, entry.key, entry.ip);
});
} catch (e) {
console.error(e);
}
}, null, true, 'America/Los_Angeles');