Shinobi/libs/plugins.js

169 lines
6.1 KiB
JavaScript
Raw Normal View History

2018-09-28 05:37:08 +00:00
var socketIOclient = require('socket.io-client');
module.exports = function(s,config,lang){
//function for receiving detector data
s.pluginEventController=function(d){
switch(d.f){
case'trigger':
2018-09-29 04:04:50 +00:00
s.triggerEvent(d)
2018-09-28 05:37:08 +00:00
break;
case's.tx':
s.tx(d.data,d.to)
break;
case's.sqlQuery':
s.sqlQuery(d.query,d.values)
2018-09-28 05:37:08 +00:00
break;
case'log':
s.systemLog('PLUGIN : '+d.plug+' : ',d)
break;
}
}
//multi plugin connections
s.connectedPlugins = {}
s.connectedDetectorPlugins = {}
s.detectorPluginArray = []
s.isAtleatOneDetectorPluginConnected = false
s.addDetectorPlugin = function(name,d){
s.connectedDetectorPlugins[d.plug] = {
started: s.timeObject(),
id: d.id,
plug: d.plug,
notice: d.notice,
connectionType: d.connectionType
}
s.resetDetectorPluginArray()
}
s.removeDetectorPlugin = function(name){
delete(s.connectedDetectorPlugins[name])
s.resetDetectorPluginArray(name)
}
s.resetDetectorPluginArray = function(){
pluginArray = []
Object.keys(s.connectedPlugins).forEach(function(name){
var plugin = s.connectedPlugins[name]
if(plugin.plugged === true && plugin.type === 'detector'){
pluginArray.push(name)
}
})
if(pluginArray.length > 0)s.isAtleatOneDetectorPluginConnected = true
s.detectorPluginArray = pluginArray
}
s.sendToAllDetectors = function(data){
s.detectorPluginArray.forEach(function(name){
s.connectedPlugins[name].tx(data)
})
}
s.sendDetectorInfoToClient = function(data,txFunction){
s.detectorPluginArray.forEach(function(name){
var detectorData = Object.assign(data,{
notice: s.connectedDetectorPlugins[name].notice,
plug: name
})
txFunction(detectorData)
})
}
// s.sendToDetectorsInChain = function(){
//
// }
2018-09-28 05:37:08 +00:00
s.pluginInitiatorSuccess=function(mode,d,cn){
s.systemLog('pluginInitiatorSuccess',d)
if(!s.connectedPlugins[d.plug]){
s.connectedPlugins[d.plug]={
plug: d.plug,
type: d.type
}
}
s.connectedPlugins[d.plug].plugged = true
2018-09-28 05:37:08 +00:00
if(mode==='client'){
s.connectedPlugins[d.plug].tx = function(x){return cn.emit('f',x)}
2018-09-28 05:37:08 +00:00
//is in client mode (camera.js is client)
cn.pluginEngine = d.plug
2018-09-28 05:37:08 +00:00
s.systemLog('Connected to plugin : Detector - '+d.plug+' - '+d.type)
switch(d.type){
default:case'detector':
cn.detectorPlugin = d.plug
s.addDetectorPlugin(d.plug,{
id: cn.id,
plug: d.plug,
notice: d.notice,
isClientPlugin: true,
connectionType: d.connectionType
})
2018-09-28 05:37:08 +00:00
s.tx({f:'detector_plugged',plug:d.plug,notice:d.notice},'CPU')
break;
}
}else{
//is in host mode (camera.js is client)
switch(d.type){
default:case'detector':
s.addDetectorPlugin(d.plug,{
id:"host",
plug:d.plug,
notice:d.notice,
isHostPlugin:true,
connectionType: d.connectionType
})
s.tx({f:'detector_plugged',plug:d.plug,notice:d.notice},'CPU')
2018-09-28 05:37:08 +00:00
break;
}
}
s.tx({f:'readPlugins',ke:d.ke},'CPU')
}
s.pluginInitiatorFail=function(mode,d,cn){
if(s.connectedPlugins[d.plug])s.connectedPlugins[d.plug].plugged=false
if(mode==='client'){
//is in client mode (camera.js is client)
cn.disconnect()
}else{
//is in host mode (camera.js is client)
}
}
if(config.plugins&&config.plugins.length>0){
config.plugins.forEach(function(v){
s.connectedPlugins[v.id]={
plug: v.id,
type: v.type
}
2018-09-28 05:37:08 +00:00
if(v.enabled===false){return}
if(v.mode==='host'){
//is in host mode (camera.js is client)
if(v.https===true){
v.https='https://'
}else{
v.https='http://'
}
if(!v.port){
v.port=80
}
var socket = socketIOclient(v.https+v.host+':'+v.port)
s.connectedPlugins[v.id].tx = function(x){return socket.emit('f',x)}
socket.on('connect', function(cn){
s.systemLog('Connected to plugin (host) : '+v.id)
s.connectedPlugins[v.id].tx({f:'init_plugin_as_host',key:v.key})
});
socket.on('init',function(d){
s.systemLog('Initialize Plugin : Host',d)
if(d.ok===true){
s.pluginInitiatorSuccess("host",d)
}else{
s.pluginInitiatorFail("host",d)
}
});
socket.on('ocv',s.pluginEventController);
socket.on('disconnect', function(){
s.connectedPlugins[v.id].plugged=false
delete(s.api[v.id])
s.systemLog('Plugin Disconnected : '+v.id)
s.connectedPlugins[v.id].reconnector = setInterval(function(){
if(socket.connected===true){
clearInterval(s.connectedPlugins[v.id].reconnector)
}else{
socket.connect()
}
},1000*2)
});
s.connectedPlugins[v.id].ws = socket;
}
})
}
}