2018-09-28 05:37:08 +00:00
|
|
|
var socketIOclient = require('socket.io-client');
|
2019-03-25 06:45:03 +00:00
|
|
|
module.exports = function(s,config,lang,io){
|
|
|
|
//send data to detector plugin
|
|
|
|
s.ocvTx = function(data){
|
|
|
|
// chaining coming in future update
|
|
|
|
s.sendToAllDetectors(data)
|
|
|
|
}
|
2018-09-28 05:37:08 +00:00
|
|
|
//function for receiving detector data
|
2019-03-25 06:45:03 +00:00
|
|
|
s.pluginEventController = function(d){
|
2018-09-28 05:37:08 +00:00
|
|
|
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;
|
2018-10-01 05:44:35 +00:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
}
|
2019-03-06 00:22:04 +00:00
|
|
|
s.connectedPlugins = {}
|
|
|
|
s.connectedDetectorPlugins = {}
|
|
|
|
s.detectorPluginArray = []
|
|
|
|
s.isAtleatOneDetectorPluginConnected = false
|
|
|
|
s.addDetectorPlugin = function(name,d){
|
2019-03-25 06:45:03 +00:00
|
|
|
if(config.useOldPluginConnectionMethod === true){
|
|
|
|
s.ocv = {
|
|
|
|
started: s.timeObject(),
|
|
|
|
id: d.id,
|
|
|
|
plug: d.plug,
|
|
|
|
notice: d.notice,
|
|
|
|
isClientPlugin: d.isClientPlugin,
|
|
|
|
isHostPlugin: d.isHostPlugin,
|
|
|
|
connectionType: d.connectionType
|
|
|
|
}
|
|
|
|
}
|
2019-03-06 00:22:04 +00:00
|
|
|
s.connectedDetectorPlugins[d.plug] = {
|
|
|
|
started: s.timeObject(),
|
|
|
|
id: d.id,
|
|
|
|
plug: d.plug,
|
|
|
|
notice: d.notice,
|
2019-03-25 06:45:03 +00:00
|
|
|
isClientPlugin: d.isClientPlugin,
|
|
|
|
isHostPlugin: d.isHostPlugin,
|
2019-03-06 00:22:04 +00:00
|
|
|
connectionType: d.connectionType
|
|
|
|
}
|
|
|
|
s.resetDetectorPluginArray()
|
|
|
|
}
|
|
|
|
s.removeDetectorPlugin = function(name){
|
2019-03-25 06:45:03 +00:00
|
|
|
if(config.oldPluginConnectionMethod === true && s.ocv && s.ocv.plug === name){
|
|
|
|
delete(s.ocv)
|
|
|
|
}
|
2019-03-06 00:22:04 +00:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
})
|
2019-03-08 05:27:40 +00:00
|
|
|
if(pluginArray.length > 0){
|
|
|
|
s.isAtleatOneDetectorPluginConnected = true
|
|
|
|
}else{
|
|
|
|
s.isAtleatOneDetectorPluginConnected = false
|
|
|
|
}
|
2019-03-25 06:45:03 +00:00
|
|
|
s.debugLog(`resetDetectorPluginArray : ${JSON.stringify(pluginArray)}`)
|
2019-03-06 00:22:04 +00:00
|
|
|
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(){
|
|
|
|
//
|
|
|
|
// }
|
2019-03-25 06:45:03 +00:00
|
|
|
s.pluginInitiatorSuccess = function(mode,d,cn){
|
2018-09-28 05:37:08 +00:00
|
|
|
s.systemLog('pluginInitiatorSuccess',d)
|
2019-03-06 00:22:04 +00:00
|
|
|
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'){
|
2019-03-06 00:22:04 +00:00
|
|
|
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)
|
2019-03-06 00:22:04 +00:00
|
|
|
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':
|
2019-03-25 06:45:03 +00:00
|
|
|
if(config.oldPluginConnectionMethod)cn.ocv = 1
|
2019-03-06 00:22:04 +00:00
|
|
|
cn.detectorPlugin = d.plug
|
|
|
|
s.addDetectorPlugin(d.plug,{
|
2018-11-02 23:44:53 +00:00
|
|
|
id: cn.id,
|
|
|
|
plug: d.plug,
|
|
|
|
notice: d.notice,
|
|
|
|
isClientPlugin: true,
|
|
|
|
connectionType: d.connectionType
|
2019-03-06 00:22:04 +00:00
|
|
|
})
|
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':
|
2019-03-06 00:22:04 +00:00
|
|
|
s.addDetectorPlugin(d.plug,{
|
2019-03-25 06:45:03 +00:00
|
|
|
id: "host",
|
|
|
|
plug: d.plug,
|
|
|
|
notice: d.notice,
|
|
|
|
isHostPlugin: true,
|
2018-11-02 23:44:53 +00:00
|
|
|
connectionType: d.connectionType
|
2019-03-06 00:22:04 +00:00
|
|
|
})
|
|
|
|
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){
|
2019-03-06 00:22:04 +00:00
|
|
|
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
|
|
|
|
}
|
2019-03-30 20:53:24 +00:00
|
|
|
var socket = socketIOclient(v.https+v.host+':'+v.port)
|
2018-09-28 05:37:08 +00:00
|
|
|
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)
|
2019-03-25 06:45:03 +00:00
|
|
|
if(d.ok === true){
|
2018-09-28 05:37:08 +00:00
|
|
|
s.pluginInitiatorSuccess("host",d)
|
|
|
|
}else{
|
|
|
|
s.pluginInitiatorFail("host",d)
|
|
|
|
}
|
2019-03-25 06:45:03 +00:00
|
|
|
})
|
2018-09-28 05:37:08 +00:00
|
|
|
socket.on('ocv',s.pluginEventController);
|
|
|
|
socket.on('disconnect', function(){
|
|
|
|
s.connectedPlugins[v.id].plugged=false
|
2019-03-06 02:18:52 +00:00
|
|
|
if(v.type === 'detector'){
|
|
|
|
s.tx({f:'detector_unplugged',plug:v.id},'CPU')
|
|
|
|
s.removeDetectorPlugin(v.id)
|
|
|
|
s.sendDetectorInfoToClient({f:'detector_plugged'},function(data){
|
|
|
|
s.tx(data,'CPU')
|
|
|
|
})
|
|
|
|
}
|
2018-09-28 05:37:08 +00:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2019-03-25 06:45:03 +00:00
|
|
|
var onWebSocketDisconnection = function(cn){
|
|
|
|
if(cn.pluginEngine){
|
|
|
|
s.connectedPlugins[cn.pluginEngine].plugged = false
|
|
|
|
s.tx({f:'plugin_engine_unplugged',plug:cn.pluginEngine},'CPU')
|
|
|
|
}
|
|
|
|
if(cn.detectorPlugin){
|
|
|
|
s.tx({f:'detector_unplugged',plug:cn.detectorPlugin},'CPU')
|
|
|
|
s.removeDetectorPlugin(cn.detectorPlugin)
|
|
|
|
s.sendDetectorInfoToClient({f:'detector_plugged'},function(data){
|
|
|
|
s.tx(data,'CPU')
|
|
|
|
})
|
|
|
|
}
|
|
|
|
if(cn.ocv && s.ocv){
|
|
|
|
s.tx({f:'detector_unplugged',plug:s.ocv.plug},'CPU')
|
|
|
|
delete(s.ocv);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var onSocketAuthentication = function(r,cn,d,tx){
|
|
|
|
if(s.isAtleatOneDetectorPluginConnected){
|
|
|
|
s.sendDetectorInfoToClient({f:'detector_plugged'},tx)
|
|
|
|
s.ocvTx({f:'readPlugins',ke:d.ke})
|
|
|
|
}
|
|
|
|
if(config.oldPluginConnectionMethod && s.ocv){
|
|
|
|
tx({f:'detector_plugged',plug:s.ocv.plug,notice:s.ocv.notice})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var onWebSocketConnection = function(cn){
|
|
|
|
cn.on('ocv',function(d){
|
|
|
|
if(!cn.pluginEngine && d.f === 'init'){
|
|
|
|
if(config.pluginKeys[d.plug] === d.pluginKey){
|
|
|
|
s.pluginInitiatorSuccess("client",d,cn)
|
|
|
|
}else{
|
|
|
|
s.pluginInitiatorFail("client",d,cn)
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
if(config.pluginKeys[d.plug] === d.pluginKey){
|
|
|
|
s.pluginEventController(d)
|
|
|
|
}else{
|
|
|
|
cn.disconnect()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
cn.on('f',function(d){
|
|
|
|
if((d.id || d.uid || d.mid) && cn.ke){
|
|
|
|
switch(d.f){
|
|
|
|
case'ocv_in':
|
|
|
|
s.ocvTx(d.data)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2019-04-19 15:20:25 +00:00
|
|
|
if(config.oldPluginConnectionMethod === undefined)config.oldPluginConnectionMethod = false
|
2019-03-25 06:45:03 +00:00
|
|
|
if(config.oldPluginConnectionMethod === true){
|
|
|
|
s.ocvTx = function(data){
|
|
|
|
if(!s.ocv){return}
|
|
|
|
if(s.ocv.isClientPlugin === true){
|
|
|
|
s.tx(data,s.ocv.id)
|
|
|
|
}else{
|
|
|
|
s.connectedPlugins[s.ocv.plug].tx(data)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
s.onSocketAuthentication(onSocketAuthentication)
|
|
|
|
s.onWebSocketDisconnection(onWebSocketDisconnection)
|
|
|
|
s.onWebSocketConnection(onWebSocketConnection)
|
2018-09-28 05:37:08 +00:00
|
|
|
}
|