node-red-contrib-hikvision-ultimate
Version:
A native set of nodes for Hikvision (and compatible) Cameras, Alarms, Radars, NVR, Doorbells, etc.
97 lines (82 loc) • 3.24 kB
JavaScript
module.exports = function (RED) {
function hikvisionUltimateAccessControlTerminal(config) {
RED.nodes.createNode(this, config);
var node = this;
node.topic = config.topic || config.name;
node.server = RED.nodes.getNode(config.server)
const isDebug = node.server && node.server.debug;
const logDebug = (text) => {
if (isDebug) RED.log.info(`hikvisionUltimateAccessControlTerminal: ${text}`);
};
node.filtermajorevent = Number(config.filtermajorevent) || 0;
node.filterminorevent = parseInt(config.filterminorevent || 0, 16); // Hex to decimal
node.setNodeStatus = ({ fill, shape, text }) => {
var dDate = new Date();
node.status({ fill: fill, shape: shape, text: text + " (" + dDate.getDate() + ", " + dDate.toLocaleTimeString() + ")" })
}
// Called from config node, to send output to the flow
node.sendPayload = (_msg) => {
if (_msg === null || _msg === undefined) return;
_msg.topic = node.topic;
if (_msg.hasOwnProperty("errorDescription")) {
logDebug(`Connection status message: ${_msg.errorDescription || ""}`);
node.send([null, _msg]);
return;
}; // It's a connection error/restore comunication.
if (!_msg.hasOwnProperty("payload") || (_msg.hasOwnProperty("payload") && (_msg.payload === undefined || _msg.payload === null))) {
logDebug("Discarded incoming message without payload");
return;
}
// Apply filter
if (node.filtermajorevent > 0) {
if (Number(_msg.payload.major) === node.filtermajorevent) {
if (node.filterminorevent > 0) {
if (Number(_msg.payload.minor) === node.filterminorevent) {
node.send([_msg, null]);
setTimeout(() => {
node.setNodeStatus({ fill: "green", shape: "dot", text: "Event " + _msg.payload.eventDescription });
}, 1000);
logDebug(`Forwarded filtered event major ${_msg.payload.major} minor ${_msg.payload.minor}`);
} else {
try {
setTimeout(() => {
node.setNodeStatus({ fill: "grey", shape: "dot", text: "Filtered " + _msg.payload.eventDescription });
}, 500);
} catch (error) { }
logDebug(`Dropped event minor ${_msg.payload.minor} (filter ${node.filterminorevent})`);
return;
}
} else {
node.send([_msg, null]);
setTimeout(() => {
node.setNodeStatus({ fill: "green", shape: "dot", text: "Event " + _msg.payload.eventDescription });
}, 1000);
logDebug(`Forwarded event major ${_msg.payload.major} (no minor filter)`);
}
}
} else {
node.send([_msg, null]);
try {
setTimeout(() => {
node.setNodeStatus({ fill: "green", shape: "dot", text: "Event " + _msg.payload.eventDescription });
}, 1000);
} catch (error) { }
logDebug(`Forwarded event ${_msg.payload.eventDescription || ""} without filters`);
}
}
// On each deploy, unsubscribe+resubscribe
if (node.server) {
node.server.removeClient(node);
node.server.addClient(node);
}
this.on('input', function (msg) {
});
node.on("close", function (done) {
if (node.server) {
node.server.removeClient(node);
}
done();
});
}
RED.nodes.registerType("hikvisionUltimateAccessControlTerminal", hikvisionUltimateAccessControlTerminal);
}