Built motion from commit (unavailable).|2.5.1
[motion2.git] / server / services / ami / report / voiceQueueReport.js
1 // *************************************************************************
2 // *                                                                       *
3 // * xCALLY Motion -  The Omnichannel Contact Center                       *
4 // * Copyright (c) Xenialab s.r.l. All Rights Reserved                     *
5 // *                                                                       *
6 // *************************************************************************
7 // *                                                                       *
8 // * Email: info@xcally.com                                                *
9 // * Website: https://www.xcally.com                                       *
10 // *                                                                       *
11 // *************************************************************************
12 // *                                                                       *
13 // * The SOFTWARE PRODUCT is protected by copyright laws and international *
14 // * copyright treaties, as well as other intellectual property laws and   *
15 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                         *
16 // *                                                                       *
17 // *************************************************************************
18 var _0x0003=['value','variable','queuestatus','CONTINUE','TIMEOUT','timeout','custom:timeout','queueposition','EXITWITHKEY','variables','[syncVarSet][VoiceQueueReport]','rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrtt','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberlastcall','membername','memberpenalty','memberrealtime','includes','length','sumHoldTime','diff','milliseconds','sumBillable','queuecallercompleteAt','lastevent','custom:voiceQueueReport','[syncHangup][VoiceQueueReport]','syncAttendedTransfer','secondtransfererexten','secondtransfereruniqueid','ATTENDEDTRANSFER','transfereeuniqueid','switch','transfertargetuniqueid','origtransfererexten','origtransfereruniqueid','ATTENDED','BLINDTRANSFER','extension','context','transfererchannel','mohstarttime','mohtime','[syncMusicOnHoldStop][VoiceQueueReport]','exports','lodash','moment','md5','ioredis','ami','../ami','../model/queueReport','redis','socket.io-emitter','enqueue','tail','finally','sequence','queueReports','agents','channels','voiceQueues','campaigns','syncQueueSummary','bind','queuesummarycomplete','queuecallerjoin','queuecallerabandon','syncQueueCallerAbandon','queuecallerleave','agentcomplete','syncAgentComplete','agentconnect','syncAgentConnect','varset','syncVarSet','hangup','syncHangup','fullybooted','syncFullyBooted','musiconholdstart','syncMusicOnHoldStart','musiconholdstop','syncMusicOnHoldStop','attendedtransfer','syncBlindTransfer','loopQueueSummary','loopQueueShow','isUndefined','hasOwnProperty','isEmpty','talking','pTalking','queueStatusComplete','clearZombieChannels','isNil','Action','channel','message','No\x20such\x20channel','error','[voiceQueueReport][checkChannel]','[voiceQueueReport][checkQueueReport]','prototype','[FullyBooted]\x20clear\x20realtime','clearQueueReport','emitVoiceQueueChannelRemove','inspect','emit','emitVoiceQueueChannelSave','voice:queue:%s','name','voice_queue_channel:save','info','stringify','format','voice_queue_channel:remove','emitVoiceQueueSummary','type','inbound','strategy','answered','available','loggedIn','sumDuration','total','unmanaged','Trunk','Interval','voice_queue:save','isNotNull','[queues]','flagQueueSummary','queuesummary','catch','queue','countBy','callers','waiting','toNumber','loggedin','custom:queuesummary','[syncQueueSummary][VoiceQueueReport]','syncQueueSummaryComplete','syncNewExten','syncQueueCallerJoin','uniqueid','queuecallerjoinAt','YYYY-MM-DD\x20HH:mm:ss','position','count','merge','pick','push','last','queuecallercomplete','holdtime','originalposition','queuecallerabandonAt','queuecallerexitreason','ABANDONED','lastAssignedTo','[syncQueueCallerAbandon][VoiceQueueReport]','syncQueueCallerLeave','queuecallerleaveAt','connectedlinenum','connectedlinename','COMPLETEDBYAGENT','[syncAgentConnect][VoiceQueueReport]','assigned','queuecallerexit','queuecallerexitAt','transfer','reason','COMPLETED','startsWith','toLowerCase','linkedid','add','seconds','transfertype','FORWARD','transferexten','destexten','transferuniqueid','toUpperCase','[syncAgentComplete][VoiceQueueReport]','addVariable','keys'];(function(_0x4ee917,_0x948a17){var _0x2213a5=function(_0x19a1d7){while(--_0x19a1d7){_0x4ee917['push'](_0x4ee917['shift']());}};_0x2213a5(++_0x948a17);}(_0x0003,0x1c8));var _0x3000=function(_0x43d698,_0x4ab67f){_0x43d698=_0x43d698-0x0;var _0xa52a3c=_0x0003[_0x43d698];return _0xa52a3c;};'use strict';var _=require(_0x3000('0x0'));var moment=require(_0x3000('0x1'));var BPromise=require('bluebird');var util=require('util');var md5=require(_0x3000('0x2'));var Redis=require(_0x3000('0x3'));var config=require('../../../config/environment');var logger=require('../../../config/logger')(_0x3000('0x4'));var ami=require(_0x3000('0x5'));var QueueReport=require(_0x3000('0x6'));config['redis']=_['defaults'](config[_0x3000('0x7')],{'host':'localhost','port':0x18eb});var io=require(_0x3000('0x8'))(new Redis(config['redis']));var Sequence=function(){};Sequence['prototype'][_0x3000('0x9')]=function(_0xe87e84){this[_0x3000('0xa')]=this[_0x3000('0xa')]?this[_0x3000('0xa')][_0x3000('0xb')](_0xe87e84):_0xe87e84();};function VoiceQueueReport(_0x3aa400){this[_0x3000('0xc')]=new Sequence();this[_0x3000('0xd')]={};this['agents']=_0x3aa400[_0x3000('0xe')];this[_0x3000('0xf')]=_0x3aa400['queueChannels'];this[_0x3000('0x10')]=_0x3aa400[_0x3000('0x10')];this['flagQueueSummary']=!![];this[_0x3000('0x11')]=_0x3aa400[_0x3000('0x11')];this['variables']={};ami['on']('queuesummary',this[_0x3000('0x12')][_0x3000('0x13')](this));ami['on'](_0x3000('0x14'),this['syncQueueSummaryComplete']['bind'](this));ami['on'](_0x3000('0x15'),this['syncQueueCallerJoin'][_0x3000('0x13')](this));ami['on'](_0x3000('0x16'),this[_0x3000('0x17')][_0x3000('0x13')](this));ami['on'](_0x3000('0x18'),this['syncQueueCallerLeave'][_0x3000('0x13')](this));ami['on'](_0x3000('0x19'),this[_0x3000('0x1a')][_0x3000('0x13')](this));ami['on'](_0x3000('0x1b'),this[_0x3000('0x1c')]['bind'](this));ami['on'](_0x3000('0x1d'),this[_0x3000('0x1e')]['bind'](this));ami['on'](_0x3000('0x1f'),this[_0x3000('0x20')][_0x3000('0x13')](this));ami['on'](_0x3000('0x21'),this[_0x3000('0x22')][_0x3000('0x13')](this));ami['on'](_0x3000('0x23'),this[_0x3000('0x24')]['bind'](this));ami['on'](_0x3000('0x25'),this[_0x3000('0x26')][_0x3000('0x13')](this));ami['on'](_0x3000('0x27'),this['syncAttendedTransfer']['bind'](this));ami['on']('blindtransfer',this[_0x3000('0x28')]['bind'](this));this[_0x3000('0x29')]();this[_0x3000('0x2a')]();}function isNotNull(_0x36e2e9){return _0x36e2e9!==null&&!_[_0x3000('0x2b')](_0x36e2e9);}function clearChannels(_0x5d44cb){if(!_['isEmpty'](_0x5d44cb)){for(var _0x219e75 in _0x5d44cb){if(_0x5d44cb[_0x3000('0x2c')](_0x219e75)){delete _0x5d44cb[_0x219e75];}}}}function clearCampaigns(_0x1df9b0){if(!_[_0x3000('0x2d')](_0x1df9b0)){for(var _0x4d3993 in _0x1df9b0){if(_0x1df9b0[_0x3000('0x2c')](_0x4d3993)){_0x1df9b0[_0x4d3993]['originated']=0x0;}}}}function clearVoiceQueues(_0x30413a){if(!_[_0x3000('0x2d')](_0x30413a)){for(var _0xd03348 in _0x30413a){if(_0x30413a['hasOwnProperty'](_0xd03348)){_0x30413a[_0xd03348]['originated']=0x0;_0x30413a[_0xd03348][_0x3000('0x2e')]=0x0;_0x30413a[_0xd03348][_0x3000('0x2f')]=0x0;_0x30413a[_0xd03348]['waiting']=0x0;_0x30413a[_0xd03348][_0x3000('0x30')]=!![];}}}}function clearAgentBooked(_0x1ba6c3){if(!_['isEmpty'](_0x1ba6c3)){for(var _0x240657 in _0x1ba6c3){if(_0x1ba6c3[_0x3000('0x2c')](_0x240657)){_0x1ba6c3[_0x240657]['unlockRR']=!![];}}}}VoiceQueueReport['prototype'][_0x3000('0x31')]=function(){var _0x5edcc9=this;for(var _0x46fddf in this['channels']){if(this[_0x3000('0xf')][_0x3000('0x2c')](_0x46fddf)&&!this[_0x3000('0xf')][_0x46fddf]['switch']){this['sequence']['enqueue'](function(){if(!_[_0x3000('0x32')](_0x5edcc9[_0x3000('0xf')][_0x46fddf])){return ami[_0x3000('0x33')]({'action':'status','channel':_0x5edcc9['channels'][_0x46fddf][_0x3000('0x34')]})['catch'](function(_0x1eb170){if(_0x1eb170[_0x3000('0x35')]===_0x3000('0x36')){setTimeout(function(){if(_0x5edcc9[_0x3000('0xf')][_0x46fddf]){delete _0x5edcc9[_0x3000('0xf')][_0x46fddf];logger[_0x3000('0x37')](_0x3000('0x38'),_0x46fddf);}if(_0x5edcc9[_0x3000('0xd')][_0x46fddf]){delete _0x5edcc9['queueReports'][_0x46fddf];logger[_0x3000('0x37')](_0x3000('0x39'),_0x46fddf);}if(_0x5edcc9['variables'][_0x46fddf]){delete _0x5edcc9['variables'][_0x46fddf];logger[_0x3000('0x37')]('[voiceQueueReport][checkVariables]',_0x46fddf);}},0x1f40);}});}});}}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x22')]=function(){logger[_0x3000('0x37')](_0x3000('0x3b'));clearChannels(this['channels']);this[_0x3000('0x3c')](this[_0x3000('0xd')]);clearAgentBooked(this['agents']);clearVoiceQueues(this[_0x3000('0x10')]);clearCampaigns(this[_0x3000('0x11')]);};VoiceQueueReport[_0x3000('0x3a')]['clearQueueReport']=function(_0x32626d){var _0x9451e7=this;if(!_[_0x3000('0x2d')](_0x32626d)){for(var _0x4ccab8 in _0x32626d){if(_0x32626d[_0x3000('0x2c')](_0x4ccab8)){_0x9451e7[_0x3000('0x3d')](_0x32626d[_0x4ccab8]);delete _0x32626d[_0x4ccab8];}}}};function loggerCatch(_0x50c06d){return function(_0x13bd53){logger[_0x3000('0x37')](_0x50c06d,util[_0x3000('0x3e')](_0x13bd53,{'showHidden':![],'depth':null}));};}VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x3f')]=function(_0x28d87c,_0xd53f48,_0x36ca9b){io['to'](_0x28d87c)[_0x3000('0x3f')](_0xd53f48,_0x36ca9b);};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x40')]=function(_0x4a44a5){this[_0x3000('0x3f')](util['format'](_0x3000('0x41'),_0x4a44a5[_0x3000('0x42')]),_0x3000('0x43'),_0x4a44a5);};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x3d')]=function(_0x3afcef){logger[_0x3000('0x44')]('[DEBUG]\x20Emit\x20voice_queue_channel:remove\x20event',JSON[_0x3000('0x45')](_0x3afcef));this[_0x3000('0x3f')](util[_0x3000('0x46')](_0x3000('0x41'),_0x3afcef[_0x3000('0x42')]),_0x3000('0x47'),_0x3afcef);};VoiceQueueReport['prototype'][_0x3000('0x48')]=function(_0x102491){if(_0x102491[_0x3000('0x49')]===_0x3000('0x4a')){var _0x3bd9e4={'id':_0x102491['id'],'name':_0x102491[_0x3000('0x42')],'strategy':_0x102491[_0x3000('0x4b')],'answered':_0x102491[_0x3000('0x4c')],'available':_0x102491[_0x3000('0x4d')],'loggedIn':_0x102491[_0x3000('0x4e')],'pTalking':_0x102491[_0x3000('0x2f')],'sumBillable':_0x102491['sumBillable'],'sumDuration':_0x102491[_0x3000('0x4f')],'sumHoldTime':_0x102491['sumHoldTime']||0x0,'talking':_0x102491['talking'],'total':_0x102491[_0x3000('0x50')],'type':_0x102491[_0x3000('0x49')],'unmanaged':_0x102491[_0x3000('0x51')],'abandoned':_0x102491['abandoned'],'waiting':_0x102491['waiting']};if(_0x102491[_0x3000('0x52')]){_0x3bd9e4[_0x3000('0x52')]={'id':_0x102491[_0x3000('0x52')]['id'],'name':_0x102491[_0x3000('0x52')]['name'],'active':_0x102491[_0x3000('0x52')]['active'],'callerid':_0x102491[_0x3000('0x52')]['callerid']};}if(_0x102491[_0x3000('0x53')]){_0x3bd9e4[_0x3000('0x53')]={'id':_0x102491[_0x3000('0x53')]['id'],'name':_0x102491['Interval'][_0x3000('0x42')]};}var _0x39109d=md5(JSON[_0x3000('0x45')](_0x3bd9e4));if(_0x102491['md5']!==_0x39109d){_0x102491[_0x3000('0x2')]=_0x39109d;this[_0x3000('0x3f')](util[_0x3000('0x46')]('voice:queue:%s',_0x3bd9e4[_0x3000('0x42')]),_0x3000('0x54'),_0x3bd9e4);}}};VoiceQueueReport['prototype'][_0x3000('0x55')]=function(_0x2d6bf3){return _0x2d6bf3!==null&&!_[_0x3000('0x2b')](_0x2d6bf3);};VoiceQueueReport[_0x3000('0x3a')]['loopQueueShow']=function(){var _0x31cb1e=this;setInterval(function(){_0x31cb1e[_0x3000('0x31')]();ami[_0x3000('0x33')]({'action':'queues'})['catch'](loggerCatch(_0x3000('0x56')));},0x2710);};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x29')]=function(){var _0x5f0a90=this;setInterval(function(){if(_0x5f0a90[_0x3000('0x57')]){return ami['Action']({'action':_0x3000('0x58')})['then'](function(_0x153e42){_0x5f0a90[_0x3000('0x57')]=![];})[_0x3000('0x59')](loggerCatch('[queuesummary]'));}},0x3e8);};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x12')]=function(_0x3dbf66){try{if(this['isNotNull'](_0x3dbf66)&&this[_0x3000('0x55')](_0x3dbf66[_0x3000('0x5a')])){if(this[_0x3000('0x10')][_0x3dbf66['queue']]){var _0x410dda=_[_0x3000('0x5b')](this[_0x3000('0xf')],_0x3000('0x5a'))[_0x3dbf66[_0x3000('0x5a')]]||0x0;var _0x54ec39=_0x410dda-_0x3dbf66[_0x3000('0x5c')];if(this['voiceQueues'][_0x3dbf66['queue']][_0x3000('0x5d')]!==_[_0x3000('0x5e')](_0x3dbf66['callers'])||this[_0x3000('0x10')][_0x3dbf66[_0x3000('0x5a')]][_0x3000('0x4e')]!==_['toNumber'](_0x3dbf66[_0x3000('0x5f')])||this[_0x3000('0x10')][_0x3dbf66['queue']]['available']!==_[_0x3000('0x5e')](_0x3dbf66[_0x3000('0x4d')])||this[_0x3000('0x10')][_0x3dbf66['queue']][_0x3000('0x2e')]!==_0x54ec39){this['voiceQueues'][_0x3dbf66['queue']][_0x3000('0x5d')]=_[_0x3000('0x5e')](_0x3dbf66[_0x3000('0x5c')]);this[_0x3000('0x10')][_0x3dbf66[_0x3000('0x5a')]][_0x3000('0x4e')]=_[_0x3000('0x5e')](_0x3dbf66[_0x3000('0x5f')]);this['voiceQueues'][_0x3dbf66[_0x3000('0x5a')]][_0x3000('0x4d')]=_[_0x3000('0x5e')](_0x3dbf66[_0x3000('0x4d')]);this[_0x3000('0x10')][_0x3dbf66[_0x3000('0x5a')]]['talking']=_0x54ec39>0x0?_0x54ec39:0x0;this[_0x3000('0x10')][_0x3dbf66[_0x3000('0x5a')]][_0x3000('0x2e')]=this[_0x3000('0x10')][_0x3dbf66['queue']][_0x3000('0x2e')]>_['toNumber'](_0x3dbf66[_0x3000('0x5f')])?_[_0x3000('0x5e')](_0x3dbf66[_0x3000('0x5f')]):this['voiceQueues'][_0x3dbf66[_0x3000('0x5a')]][_0x3000('0x2e')];this[_0x3000('0x48')](this['voiceQueues'][_0x3dbf66['queue']]);}ami[_0x3000('0x3f')](_0x3000('0x60'),this[_0x3000('0x10')][_0x3dbf66[_0x3000('0x5a')]]);}}}catch(_0x5b036c){logger['error'](_0x3000('0x61'),util[_0x3000('0x3e')](_0x5b036c,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x62')]=function(_0x498101){this['flagQueueSummary']=!![];};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x63')]=function(_0x3933b4){};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x64')]=function(_0x222a90){try{if(this['isNotNull'](_0x222a90)){if(_[_0x3000('0x2b')](this[_0x3000('0xd')][_0x222a90[_0x3000('0x65')]])){this[_0x3000('0xd')][_0x222a90[_0x3000('0x65')]]=[];this[_0x3000('0xf')][_0x222a90[_0x3000('0x65')]]={};}var _0x412c95=new QueueReport();_0x412c95[_0x3000('0x42')]=_0x222a90['queue'];_0x412c95[_0x3000('0x49')]=this['voiceQueues'][_0x412c95[_0x3000('0x42')]]&&this['voiceQueues'][_0x412c95[_0x3000('0x42')]][_0x3000('0x49')]?this[_0x3000('0x10')][_0x412c95['name']][_0x3000('0x49')]||'inbound':_0x3000('0x4a');_0x412c95[_0x3000('0x5a')]=_0x222a90['queue'];_0x412c95[_0x3000('0x66')]=moment()[_0x3000('0x46')](_0x3000('0x67'));_0x412c95[_0x3000('0x68')]=_0x222a90[_0x3000('0x68')];_0x412c95[_0x3000('0x69')]=_0x222a90[_0x3000('0x69')];_[_0x3000('0x6a')](_0x412c95,_[_0x3000('0x6b')](_0x222a90,_['keys'](_0x412c95)));this[_0x3000('0xd')][_0x222a90[_0x3000('0x65')]][_0x3000('0x6c')](_0x412c95);this[_0x3000('0xf')][_0x222a90[_0x3000('0x65')]]=_0x412c95;this[_0x3000('0x40')](_0x412c95);}}catch(_0x40153e){logger['error']('[syncQueueCallerJoin][VoiceQueueReport]',util[_0x3000('0x3e')](_0x40153e,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')]['syncQueueCallerAbandon']=function(_0x2ab825){try{if(this[_0x3000('0x55')](_0x2ab825)){if(this[_0x3000('0xd')][_0x2ab825['uniqueid']]){var _0x15f37f=_[_0x3000('0x6d')](this['queueReports'][_0x2ab825[_0x3000('0x65')]]);_0x15f37f[_0x3000('0x6e')]=![];_0x15f37f['queuecallercompleteAt']=null;_0x15f37f[_0x3000('0x6f')]=_0x2ab825[_0x3000('0x6f')];_0x15f37f[_0x3000('0x70')]=_0x2ab825[_0x3000('0x70')];_0x15f37f[_0x3000('0x16')]=!![];_0x15f37f[_0x3000('0x71')]=moment()[_0x3000('0x46')]('YYYY-MM-DD\x20HH:mm:ss');_0x15f37f[_0x3000('0x72')]=_0x3000('0x73');_0x15f37f[_0x3000('0x74')]=null;this[_0x3000('0xf')][_0x2ab825[_0x3000('0x65')]]=_0x15f37f;this[_0x3000('0x3d')](_0x15f37f);}}}catch(_0x629a3d){logger['error'](_0x3000('0x75'),util[_0x3000('0x3e')](_0x629a3d,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x76')]=function(_0x3c582e){try{if(this[_0x3000('0x55')](_0x3c582e)){if(this[_0x3000('0xd')][_0x3c582e[_0x3000('0x65')]]){var _0x100adb=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x3c582e[_0x3000('0x65')]]);_0x100adb[_0x3000('0x77')]=moment()['format'](_0x3000('0x67'));_0x100adb['connectedlinenum']=_0x3c582e[_0x3000('0x78')];_0x100adb[_0x3000('0x79')]=_0x3c582e[_0x3000('0x79')];this[_0x3000('0xf')][_0x3c582e[_0x3000('0x65')]]=_0x100adb;this[_0x3000('0x40')](_0x100adb);}}}catch(_0x1240a8){logger['error']('[syncQueueCallerLeave][VoiceQueueReport]',util['inspect'](_0x1240a8,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')]['syncAgentConnect']=function(_0x10231f){try{if(this[_0x3000('0x55')](_0x10231f)){if(this[_0x3000('0xd')][_0x10231f[_0x3000('0x65')]]){var _0x4e9ebb=_[_0x3000('0x6d')](this['queueReports'][_0x10231f[_0x3000('0x65')]]);_0x4e9ebb[_0x3000('0x6e')]=!![];_0x4e9ebb[_0x3000('0x72')]=_0x3000('0x7a');}}}catch(_0x551624){logger[_0x3000('0x37')](_0x3000('0x7b'),util['inspect'](_0x551624,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x3000('0x1a')]=function(_0x4bf912){try{if(this['isNotNull'](_0x4bf912)){if(this[_0x3000('0xd')][_0x4bf912[_0x3000('0x65')]]){var _0x486a0c=_[_0x3000('0x6d')](this['queueReports'][_0x4bf912[_0x3000('0x65')]]);_0x486a0c['queuecallerabandon']=![];_0x486a0c[_0x3000('0x71')]=null;_0x486a0c[_0x3000('0x7c')]=!![];_0x486a0c[_0x3000('0x74')]=_0x4bf912['membername'];_0x486a0c[_0x3000('0x6f')]=_0x4bf912['holdtime'];_0x486a0c['queuecallercomplete']=!![];_0x486a0c[_0x3000('0x7d')]=![];_0x486a0c[_0x3000('0x7e')]=null;if(!_0x486a0c[_0x3000('0x7f')]){if(_0x4bf912[_0x3000('0x80')]==_0x3000('0x7f')){_0x486a0c[_0x3000('0x72')]=_0x3000('0x81');}else{if(_[_0x3000('0x82')](_0x4bf912[_0x3000('0x34')][_0x3000('0x83')](),'local/')){if(this[_0x3000('0xd')][_0x4bf912[_0x3000('0x84')]]){var _0x2f1191=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x4bf912[_0x3000('0x84')]]);_0x2f1191[_0x3000('0x6e')]=![];_0x2f1191[_0x3000('0x7d')]=!![];_0x2f1191[_0x3000('0x7e')]=moment(_0x486a0c[_0x3000('0x66')])[_0x3000('0x85')](_0x4bf912[_0x3000('0x6f')],_0x3000('0x86'))[_0x3000('0x46')](_0x3000('0x67'));_0x2f1191[_0x3000('0x72')]='FORWARDTRANSFER';_0x2f1191[_0x3000('0x7f')]=!![];_0x2f1191[_0x3000('0x87')]=_0x3000('0x88');_0x2f1191[_0x3000('0x89')]=_0x4bf912[_0x3000('0x8a')];_0x2f1191[_0x3000('0x8b')]=_0x4bf912[_0x3000('0x65')];var _0x21e200=this[_0x3000('0xd')][_0x4bf912[_0x3000('0x84')]];this[_0x3000('0xd')][_0x4bf912['linkedid']]=this[_0x3000('0xd')][_0x4bf912[_0x3000('0x65')]];this['queueReports'][_0x4bf912[_0x3000('0x65')]]=_0x21e200;}}else{_0x486a0c[_0x3000('0x72')]='COMPLETEDBY'+_0x4bf912['reason'][_0x3000('0x8c')]();}}}this[_0x3000('0xf')][_0x4bf912[_0x3000('0x65')]]=_0x486a0c;this['emitVoiceQueueChannelRemove'](_0x486a0c);}}}catch(_0x3aa69d){logger[_0x3000('0x37')](_0x3000('0x8d'),util[_0x3000('0x3e')](_0x3aa69d,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x1e')]=function(_0x144f4c){try{if(this[_0x3000('0x55')](_0x144f4c)){this[_0x3000('0x8e')](_0x144f4c['uniqueid'],_[_0x3000('0x8f')](_0x144f4c['variable'])[0x0],_0x144f4c[_0x3000('0x90')]);if(this[_0x3000('0xd')][_0x144f4c['uniqueid']]){var _0x1e8b62=_[_0x3000('0x6d')](this['queueReports'][_0x144f4c[_0x3000('0x65')]]);if(_0x1e8b62){if(this[_0x3000('0x55')](_0x144f4c[_0x3000('0x91')])&&this[_0x3000('0x55')](_0x144f4c[_0x3000('0x91')][_0x3000('0x92')])){switch(_0x144f4c[_0x3000('0x90')]){case _0x3000('0x93'):_0x1e8b62['queuecallerexit']=![];_0x1e8b62[_0x3000('0x7e')]=null;break;case _0x3000('0x94'):_0x1e8b62['lastevent']=_0x3000('0x95');ami[_0x3000('0x3f')](_0x3000('0x96'),_0x1e8b62);break;default:_0x1e8b62['queuecallerexit']=!![];_0x1e8b62[_0x3000('0x7e')]=moment()[_0x3000('0x46')](_0x3000('0x67'));_0x1e8b62[_0x3000('0x77')]=moment()[_0x3000('0x46')](_0x3000('0x67'));}_0x1e8b62[_0x3000('0x16')]=![];_0x1e8b62['queuecallerabandonAt']=null;_0x1e8b62[_0x3000('0x72')]=_0x144f4c['value'];this[_0x3000('0xf')][_0x144f4c[_0x3000('0x65')]]=_0x1e8b62;this['emitVoiceQueueChannelRemove'](_0x1e8b62);}else if(this['isNotNull'](_0x144f4c[_0x3000('0x91')])&&this[_0x3000('0x55')](_0x144f4c[_0x3000('0x91')][_0x3000('0x97')])){if(!_0x1e8b62[_0x3000('0x16')]){_0x1e8b62['queuecallerexit']=!![];_0x1e8b62[_0x3000('0x7e')]=moment()['format'](_0x3000('0x67'));_0x1e8b62[_0x3000('0x72')]=_0x3000('0x98');_0x1e8b62[_0x3000('0x77')]=moment()[_0x3000('0x46')](_0x3000('0x67'));this['channels'][_0x144f4c[_0x3000('0x65')]]=_0x1e8b62;}}_0x1e8b62[_0x3000('0x99')]=this[_0x3000('0x99')][_0x144f4c[_0x3000('0x65')]];}}}}catch(_0x193ce3){logger[_0x3000('0x37')](_0x3000('0x9a'),util[_0x3000('0x3e')](_0x193ce3,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype']['addVariable']=function(_0x4314dd,_0x40cb42,_0x5334ba){var _0x11cb55=[_0x3000('0x9b'),_0x3000('0x9c'),_0x3000('0x9d'),_0x3000('0x9e'),_0x3000('0x9f'),_0x3000('0xa0'),_0x3000('0xa1'),'rtpaudioqosrttbridged','sipcallid',_0x3000('0xa2'),_0x3000('0xa3'),_0x3000('0xa4'),_0x3000('0xa5'),_0x3000('0xa6'),_0x3000('0xa7'),_0x3000('0xa8'),_0x3000('0xa9'),_0x3000('0xaa'),_0x3000('0xab')];if(!_[_0x3000('0x32')](_0x40cb42)&&!_[_0x3000('0xac')](_0x11cb55,_0x40cb42)){if(_[_0x3000('0x2b')](this[_0x3000('0x99')][_0x4314dd])){this['variables'][_0x4314dd]={};}this[_0x3000('0x99')][_0x4314dd][_0x40cb42]=_0x5334ba;}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x20')]=function(_0x570ce8){try{if(this['isNotNull'](_0x570ce8)){if(this[_0x3000('0xd')][_0x570ce8[_0x3000('0x65')]]){for(var _0x222b54=0x0,_0x589102={};_0x222b54<this[_0x3000('0xd')][_0x570ce8['uniqueid']][_0x3000('0xad')];_0x222b54+=0x1){_0x589102=this[_0x3000('0xd')][_0x570ce8['uniqueid']][_0x222b54];if(this[_0x3000('0x10')][_0x589102[_0x3000('0x5a')]]){if(_0x589102[_0x3000('0x7d')]){this['voiceQueues'][_0x589102[_0x3000('0x5a')]][_0x3000('0x51')]+=0x1;}if(_0x589102['queuecallerabandon']){this['voiceQueues'][_0x589102['queue']]['abandoned']+=0x1;}this[_0x3000('0x10')][_0x589102[_0x3000('0x5a')]][_0x3000('0xae')]+=moment(_0x589102[_0x3000('0x77')])[_0x3000('0xaf')](_0x589102['queuecallerjoinAt'],_0x3000('0x86'))||0x0;if(_0x222b54===this[_0x3000('0xd')][_0x570ce8[_0x3000('0x65')]][_0x3000('0xad')]-0x1){this[_0x3000('0x10')][_0x589102[_0x3000('0x5a')]][_0x3000('0x4f')]+=moment()[_0x3000('0xb0')](0x0)['diff'](_0x589102['queuecallerjoinAt'],_0x3000('0x86'));this[_0x3000('0x10')][_0x589102['queue']][_0x3000('0x50')]+=0x1;if(_0x589102[_0x3000('0x6e')]){this['voiceQueues'][_0x589102[_0x3000('0x5a')]][_0x3000('0x4c')]+=0x1;this[_0x3000('0x10')][_0x589102['queue']][_0x3000('0xb1')]+=moment()[_0x3000('0xb0')](0x0)[_0x3000('0xaf')](_0x589102['queuecallerleaveAt'],_0x3000('0x86'));_0x589102[_0x3000('0xb2')]=moment()[_0x3000('0x46')](_0x3000('0x67'));_0x589102['queuecallerexit']=![];_0x589102[_0x3000('0x7e')]=null;}if(_0x589102[_0x3000('0x7d')]){_0x589102[_0x3000('0xb3')]=_0x3000('0x51');ami['emit']('custom:queuecallerunmanaged',_0x589102);}if(_0x589102[_0x3000('0x16')]){_0x589102['lastevent']='abandoned';ami[_0x3000('0x3f')]('custom:queuecallerabandon',_0x589102);}}else{this[_0x3000('0x10')][_0x589102[_0x3000('0x5a')]][_0x3000('0x4f')]+=this[_0x3000('0x10')][_0x589102[_0x3000('0x5a')]][_0x3000('0xae')];}this[_0x3000('0xf')][_0x570ce8[_0x3000('0x65')]]=_0x589102;this[_0x3000('0x3d')](_0x589102);this[_0x3000('0x48')](this[_0x3000('0x10')][_0x589102[_0x3000('0x5a')]]);}}ami[_0x3000('0x3f')](_0x3000('0xb4'),this['queueReports'][_0x570ce8[_0x3000('0x65')]]);delete this[_0x3000('0xd')][_0x570ce8[_0x3000('0x65')]];delete this[_0x3000('0xf')][_0x570ce8[_0x3000('0x65')]];}if(this[_0x3000('0x99')][_0x570ce8[_0x3000('0x65')]]){delete this[_0x3000('0x99')][_0x570ce8['uniqueid']];}}}catch(_0x367893){logger['error'](_0x3000('0xb5'),util[_0x3000('0x3e')](_0x367893,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0xb6')]=function(_0x31ccc8){try{if(this['isNotNull'](_0x31ccc8)){var _0x2cfd24;if(this['queueReports'][_0x31ccc8['transfereeuniqueid']]){_0x2cfd24=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x31ccc8['transfereeuniqueid']]);_0x2cfd24[_0x3000('0x89')]=_0x31ccc8[_0x3000('0xb7')];_0x2cfd24[_0x3000('0x8b')]=_0x31ccc8[_0x3000('0xb8')];_0x2cfd24[_0x3000('0x72')]=_0x3000('0xb9');_0x2cfd24[_0x3000('0x7f')]=!![];_0x2cfd24[_0x3000('0x87')]='ATTENDED';if(this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xb8')]]){var _0xd8da10=this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xb8')]];this[_0x3000('0xd')][_0x31ccc8['secondtransfereruniqueid']]=this[_0x3000('0xd')][_0x31ccc8['transfereeuniqueid']];this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xba')]]=_0xd8da10;var _0x16952c=_['last'](this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xba')]]);_0x16952c[_0x3000('0xbb')]=!![];}}else if(this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbc')]]){_0x2cfd24=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbc')]]);_0x2cfd24[_0x3000('0x89')]=_0x31ccc8[_0x3000('0xbd')];_0x2cfd24['transferuniqueid']=_0x31ccc8[_0x3000('0xbe')];_0x2cfd24[_0x3000('0x72')]=_0x3000('0xb9');_0x2cfd24[_0x3000('0x7f')]=!![];_0x2cfd24[_0x3000('0x87')]=_0x3000('0xbf');if(this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbe')]]){var _0xd8da10=this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbe')]];this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbe')]]=this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbc')]];this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbc')]]=_0xd8da10;var _0x16952c=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x31ccc8[_0x3000('0xbc')]]);_0x16952c['switch']=!![];}}}}catch(_0x433f63){logger[_0x3000('0x37')]('[syncAttendedTransfer][VoiceQueueReport]',util['inspect'](_0x433f63,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x28')]=function(_0x3b339f){try{if(this[_0x3000('0x55')](_0x3b339f)){if(this['queueReports'][_0x3b339f['transfereeuniqueid']]){var _0x1e6094=_['last'](this[_0x3000('0xd')][_0x3b339f['transfereeuniqueid']]);_0x1e6094[_0x3000('0x72')]=_0x3000('0xc0');_0x1e6094[_0x3000('0x7f')]=!![];_0x1e6094[_0x3000('0x87')]='BLIND';_0x1e6094['transferexten']=_0x3b339f[_0x3000('0xc1')];_0x1e6094['transferuniqueid']=_0x3b339f['transfereeuniqueid'];this[_0x3000('0x20')]({'event':'BlindTransfer','uniqueid':_0x3b339f[_0x3000('0xba')],'context':_0x3b339f[_0x3000('0xc2')],'channel':_0x3b339f[_0x3000('0xc3')]});}}}catch(_0xe6b507){logger[_0x3000('0x37')]('[syncBlindTransfer][VoiceQueueReport]',util[_0x3000('0x3e')](_0xe6b507,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3000('0x3a')][_0x3000('0x24')]=function(_0x5170b8){try{if(this['isNotNull'](_0x5170b8)){if(this[_0x3000('0xd')][_0x5170b8['uniqueid']]){var _0x11b6ad=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x5170b8[_0x3000('0x65')]]);if(!_[_0x3000('0x32')](_0x11b6ad['queuecallerleaveAt'])){_0x11b6ad[_0x3000('0xc4')]=moment()[_0x3000('0x46')](_0x3000('0x67'));}}}}catch(_0x5a04e0){logger[_0x3000('0x37')]('[syncMusicOnHoldStart][VoiceQueueReport]',util[_0x3000('0x3e')](_0x5a04e0,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x3000('0x26')]=function(_0x7aa082){try{if(this[_0x3000('0x55')](_0x7aa082)){if(this[_0x3000('0xd')][_0x7aa082[_0x3000('0x65')]]){var _0x5df5da=_[_0x3000('0x6d')](this[_0x3000('0xd')][_0x7aa082[_0x3000('0x65')]]);if(!_['isNil'](_0x5df5da[_0x3000('0xc4')])){_0x5df5da[_0x3000('0xc5')]+=moment()[_0x3000('0xb0')](0x0)['diff'](_0x5df5da['mohstarttime'],_0x3000('0x86'));delete _0x5df5da[_0x3000('0xc4')];}}}}catch(_0x215234){logger[_0x3000('0x37')](_0x3000('0xc6'),util[_0x3000('0x3e')](_0x215234,{'showHidden':![],'depth':null}));}};module[_0x3000('0xc7')]=VoiceQueueReport;