Built motion from commit 3c2ce842.|2.6.31
[motion2.git] / server / services / routing / server / applications / strategy / agent.js
index 5b1f4c6..4df634e 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xe015=['handleTimeout','timeout','drained','prototype','push','handleDrained','debug','agent','isNil','agents','forcedOwnership','isAgentAvailable','channel','busyQueue','saveWaitingNotification','showNotification','writeLog','RINGING',':FORCED','[%s][AGENT]\x20agent\x20%s\x20is\x20not\x20available','[%s][AGENT]\x20timeout\x20with\x20%s','hideNotification','busy','removeWaitingNotification','STOP','TIMEOUT','exports','lodash','uuid','./util','notificationId','squeue','realtime','routing','handleRun','bind'];(function(_0x2356e2,_0x2489f8){var _0x16f73e=function(_0x29f7f7){while(--_0x29f7f7){_0x2356e2['push'](_0x2356e2['shift']());}};_0x16f73e(++_0x2489f8);}(_0xe015,0x13b));var _0x5e01=function(_0x502c7d,_0x2f1285){_0x502c7d=_0x502c7d-0x0;var _0x30b7ed=_0xe015[_0x502c7d];return _0x30b7ed;};'use strict';var _=require(_0x5e01('0x0'));var uuid=require(_0x5e01('0x1'));var util=require(_0x5e01('0x2'));var logger=require('../../../../../config/logger')('routing');var Agent=function(_0x46ed0d,_0x4e3569,_0x2136cf,_0x420f00){this[_0x5e01('0x3')]=uuid['v4']();this[_0x5e01('0x4')]=_0x46ed0d;this['agent']=_0x4e3569;this[_0x5e01('0x5')]=_0x2136cf;this[_0x5e01('0x6')]=_0x420f00;this['squeue']['push'](this[_0x5e01('0x7')][_0x5e01('0x8')](this),this[_0x5e01('0x9')][_0x5e01('0x8')](this));this[_0x5e01('0x4')]['on'](_0x5e01('0xa'),this['handleTimeout'][_0x5e01('0x8')](this));this['squeue']['on'](_0x5e01('0xb'),this['handleDrained'][_0x5e01('0x8')](this));};Agent[_0x5e01('0xc')]['push']=function(){this[_0x5e01('0x4')][_0x5e01('0xd')](this['handleRun']['bind'](this),this[_0x5e01('0x9')][_0x5e01('0x8')](this));};Agent[_0x5e01('0xc')][_0x5e01('0xe')]=function(){this[_0x5e01('0x9')](!![]);};Agent[_0x5e01('0xc')]['handleRun']=function(){logger[_0x5e01('0xf')]('[%s][AGENT]\x20try\x20with\x20%s',this['squeue']['id'],this[_0x5e01('0x10')]['id']);if(_[_0x5e01('0x11')](this['realtime'][_0x5e01('0x12')][this['agent']['id']])){logger[_0x5e01('0xf')]('[%s][AGENT]\x20agent\x20skipped,\x20unknown\x20id\x20%s',this[_0x5e01('0x4')]['id'],this['agent']['id']);setTimeout(this[_0x5e01('0xd')]['bind'](this),0x3e8);}else{if(this['routing'][_0x5e01('0x13')]||util[_0x5e01('0x14')](this['squeue']['id'],this[_0x5e01('0x5')][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']],this[_0x5e01('0x4')][_0x5e01('0x15')],![])){this[_0x5e01('0x5')][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']]['busy']=!![];this[_0x5e01('0x5')][_0x5e01('0x12')][this['agent']['id']][_0x5e01('0x16')]=undefined;util[_0x5e01('0x17')](this[_0x5e01('0x5')],this[_0x5e01('0x6')],this[_0x5e01('0x10')],this[_0x5e01('0x4')]['channel']);util[_0x5e01('0x18')](this[_0x5e01('0x3')],this[_0x5e01('0x4')]['id'],this[_0x5e01('0x5')]['agents'][this[_0x5e01('0x10')]['id']],null,this[_0x5e01('0x6')]);util[_0x5e01('0x19')](this['squeue']['id'],this[_0x5e01('0x5')][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']],_0x5e01('0x1a')+(this['routing']['forcedOwnership']?_0x5e01('0x1b'):''));}else{logger['debug'](_0x5e01('0x1c'),this[_0x5e01('0x4')]['id'],this[_0x5e01('0x10')]['id']);setTimeout(this[_0x5e01('0xd')]['bind'](this),0x3e8);}}};Agent['prototype']['handleTimeout']=function(_0x51a98d){if(_[_0x5e01('0x11')](this['realtime'][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']])){return logger[_0x5e01('0xf')]('[%s][AGENT]\x20agent\x20skipped,\x20unknown\x20id\x20%s',this[_0x5e01('0x4')]['id'],this[_0x5e01('0x10')]['id']);}else{logger[_0x5e01('0xf')](_0x5e01('0x1d'),this['squeue']['id'],this['agent']['id']);util[_0x5e01('0x1e')](this[_0x5e01('0x3')],this[_0x5e01('0x4')]['id'],this[_0x5e01('0x5')][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']],null,this[_0x5e01('0x6')]);this[_0x5e01('0x5')][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']][_0x5e01('0x1f')]=![];this[_0x5e01('0x5')]['agents'][this[_0x5e01('0x10')]['id']][_0x5e01('0x16')]=undefined;util[_0x5e01('0x20')](this['realtime'],this[_0x5e01('0x6')],this[_0x5e01('0x10')],this['squeue'][_0x5e01('0x15')]);util[_0x5e01('0x19')](this[_0x5e01('0x4')]['id'],this['realtime'][_0x5e01('0x12')][this[_0x5e01('0x10')]['id']],_0x51a98d?_0x5e01('0x21'):_0x5e01('0x22'));}if(!_0x51a98d){setTimeout(this[_0x5e01('0xd')][_0x5e01('0x8')](this),0x3e8);}};function agent(_0x1952fb,_0x26f5f7,_0x94d4ee,_0x2b052e){return new Agent(_0x1952fb,_0x26f5f7,_0x94d4ee,_0x2b052e);}module[_0x5e01('0x23')]=agent;
\ No newline at end of file
+var _0xb903=['[%s][AGENT]\x20agent\x20%s\x20is\x20not\x20available','[%s][AGENT]\x20agent\x20skipped,\x20unknown\x20id\x20%s','[%s][AGENT]\x20timeout\x20with\x20%s','TIMEOUT','exports','lodash','uuid','./util','../../../../../config/logger','notificationId','squeue','agent','routing','handleRun','bind','handleTimeout','handleDrained','push','debug','isNil','realtime','agents','forcedOwnership','isAgentAvailable','busy','busyQueue','saveWaitingNotification','channel','showNotification','writeLog','RINGING',':FORCED'];(function(_0x4a795d,_0xc6c970){var _0x4aac75=function(_0x3ff5e0){while(--_0x3ff5e0){_0x4a795d['push'](_0x4a795d['shift']());}};_0x4aac75(++_0xc6c970);}(_0xb903,0x185));var _0x3b90=function(_0x41613f,_0x2be3d3){_0x41613f=_0x41613f-0x0;var _0x2c477b=_0xb903[_0x41613f];return _0x2c477b;};'use strict';var _=require(_0x3b90('0x0'));var uuid=require(_0x3b90('0x1'));var util=require(_0x3b90('0x2'));var logger=require(_0x3b90('0x3'))('routing');var Agent=function(_0x3312ca,_0xf414f4,_0x3b024a,_0x1cd5d8){this[_0x3b90('0x4')]=uuid['v4']();this[_0x3b90('0x5')]=_0x3312ca;this[_0x3b90('0x6')]=_0xf414f4;this['realtime']=_0x3b024a;this[_0x3b90('0x7')]=_0x1cd5d8;this['squeue']['push'](this[_0x3b90('0x8')][_0x3b90('0x9')](this),this[_0x3b90('0xa')][_0x3b90('0x9')](this));this['squeue']['on']('timeout',this['handleTimeout']['bind'](this));this['squeue']['on']('drained',this[_0x3b90('0xb')][_0x3b90('0x9')](this));};Agent['prototype'][_0x3b90('0xc')]=function(){this[_0x3b90('0x5')]['push'](this[_0x3b90('0x8')][_0x3b90('0x9')](this),this[_0x3b90('0xa')]['bind'](this));};Agent['prototype'][_0x3b90('0xb')]=function(){this['handleTimeout'](!![]);};Agent['prototype'][_0x3b90('0x8')]=function(){logger[_0x3b90('0xd')]('[%s][AGENT]\x20try\x20with\x20%s',this['squeue']['id'],this[_0x3b90('0x6')]['id']);if(_[_0x3b90('0xe')](this[_0x3b90('0xf')][_0x3b90('0x10')][this[_0x3b90('0x6')]['id']])){logger['debug']('[%s][AGENT]\x20agent\x20skipped,\x20unknown\x20id\x20%s',this[_0x3b90('0x5')]['id'],this[_0x3b90('0x6')]['id']);setTimeout(this['push'][_0x3b90('0x9')](this),0x3e8);}else{if(this[_0x3b90('0x7')][_0x3b90('0x11')]||util[_0x3b90('0x12')](this['squeue']['id'],this[_0x3b90('0xf')]['agents'][this[_0x3b90('0x6')]['id']],this[_0x3b90('0x5')]['channel'],![])){this[_0x3b90('0xf')][_0x3b90('0x10')][this[_0x3b90('0x6')]['id']][_0x3b90('0x13')]=!![];this[_0x3b90('0xf')][_0x3b90('0x10')][this[_0x3b90('0x6')]['id']][_0x3b90('0x14')]=undefined;util[_0x3b90('0x15')](this[_0x3b90('0xf')],this['routing'],this[_0x3b90('0x6')],this[_0x3b90('0x5')][_0x3b90('0x16')]);util[_0x3b90('0x17')](this[_0x3b90('0x4')],this[_0x3b90('0x5')]['id'],this['realtime']['agents'][this[_0x3b90('0x6')]['id']],null,this[_0x3b90('0x7')]);util[_0x3b90('0x18')](this[_0x3b90('0x5')]['id'],this['realtime'][_0x3b90('0x10')][this[_0x3b90('0x6')]['id']],_0x3b90('0x19')+(this['routing'][_0x3b90('0x11')]?_0x3b90('0x1a'):''));}else{logger[_0x3b90('0xd')](_0x3b90('0x1b'),this[_0x3b90('0x5')]['id'],this[_0x3b90('0x6')]['id']);setTimeout(this['push'][_0x3b90('0x9')](this),0x3e8);}}};Agent['prototype'][_0x3b90('0xa')]=function(_0x9891e4){if(_[_0x3b90('0xe')](this[_0x3b90('0xf')][_0x3b90('0x10')][this[_0x3b90('0x6')]['id']])){return logger[_0x3b90('0xd')](_0x3b90('0x1c'),this['squeue']['id'],this['agent']['id']);}else{logger[_0x3b90('0xd')](_0x3b90('0x1d'),this[_0x3b90('0x5')]['id'],this[_0x3b90('0x6')]['id']);util['hideNotification'](this['notificationId'],this[_0x3b90('0x5')]['id'],this[_0x3b90('0xf')][_0x3b90('0x10')][this['agent']['id']],null,this[_0x3b90('0x7')]);this['realtime']['agents'][this[_0x3b90('0x6')]['id']][_0x3b90('0x13')]=![];this['realtime'][_0x3b90('0x10')][this[_0x3b90('0x6')]['id']][_0x3b90('0x14')]=undefined;util['removeWaitingNotification'](this['realtime'],this[_0x3b90('0x7')],this[_0x3b90('0x6')],this[_0x3b90('0x5')][_0x3b90('0x16')]);util['writeLog'](this['squeue']['id'],this[_0x3b90('0xf')][_0x3b90('0x10')][this['agent']['id']],_0x9891e4?'STOP':_0x3b90('0x1e'));}if(!_0x9891e4){setTimeout(this[_0x3b90('0xc')][_0x3b90('0x9')](this),0x3e8);}};function agent(_0x298df6,_0x5a3266,_0x2154e2,_0x583842){return new Agent(_0x298df6,_0x5a3266,_0x2154e2,_0x583842);}module[_0x3b90('0x1f')]=agent;
\ No newline at end of file