814840828716ce8c5be92652211370c2bf079b5e
[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 _0xea23=['ABANDONED','lastAssignedTo','last','connectedlinenum','connectedlinename','syncAgentConnect','queuecallerexitreason','COMPLETEDBYAGENT','[syncAgentConnect][VoiceQueueReport]','assigned','membername','transfer','reason','COMPLETED','startsWith','toLowerCase','linkedid','queuecallerexit','queuecallerexitAt','queuecallerjoinAt','add','seconds','FORWARDTRANSFER','transfertype','transferexten','toUpperCase','syncVarSet','keys','variable','value','queuestatus','CONTINUE','custom:timeout','queueposition','queuecallerleaveAt','[syncVarSet][VoiceQueueReport]','addVariable','rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','sipuri','bridgepeer','membercalls','memberinterface','memberlastcall','memberpenalty','memberrealtime','includes','diff','length','milliseconds','total','lastevent','custom:queuecallerabandon','[syncHangup][VoiceQueueReport]','transfereeuniqueid','secondtransfererexten','transferuniqueid','secondtransfereruniqueid','ATTENDED','transfertargetuniqueid','origtransfererexten','origtransfereruniqueid','ATTENDEDTRANSFER','[syncAttendedTransfer][VoiceQueueReport]','BLINDTRANSFER','BLIND','extension','BlindTransfer','context','transfererchannel','[syncBlindTransfer][VoiceQueueReport]','mohtime','[syncMusicOnHoldStop][VoiceQueueReport]','exports','moment','util','md5','ioredis','../../../config/environment','ami','../ami','../model/queueReport','redis','defaults','localhost','socket.io-emitter','prototype','enqueue','tail','finally','sequence','queueReports','agents','channels','queueChannels','voiceQueues','flagQueueSummary','variables','queuesummarycomplete','syncQueueSummaryComplete','bind','queuecallerabandon','syncQueueCallerAbandon','queuecallerleave','syncQueueCallerLeave','syncAgentComplete','agentconnect','varset','hangup','syncHangup','fullybooted','musiconholdstart','syncMusicOnHoldStart','syncMusicOnHoldStop','attendedtransfer','blindtransfer','syncBlindTransfer','loopQueueShow','isUndefined','isEmpty','hasOwnProperty','originated','talking','pTalking','waiting','clearZombieChannels','switch','isNil','Action','status','channel','catch','message','No\x20such\x20channel','error','[voiceQueueReport][checkQueueReport]','[voiceQueueReport][checkVariables]','syncFullyBooted','[FullyBooted]\x20clear\x20realtime','campaigns','clearQueueReport','emitVoiceQueueChannelRemove','inspect','emit','voice:queue:%s','name','voice_queue_channel:save','voice_queue_channel:remove','emitVoiceQueueSummary','type','inbound','answered','sumBillable','sumDuration','sumHoldTime','unmanaged','abandoned','Trunk','callerid','Interval','format','voice_queue:save','isNotNull','[queues]','loopQueueSummary','then','syncQueueSummary','queue','countBy','toNumber','callers','loggedin','available','loggedIn','custom:queuesummary','syncNewExten','syncQueueCallerJoin','uniqueid','YYYY-MM-DD\x20HH:mm:ss','position','count','merge','push','emitVoiceQueueChannelSave','queuecallercomplete','queuecallercompleteAt','holdtime','originalposition','queuecallerabandonAt'];(function(_0x17c487,_0x2b72f1){var _0x3feeb8=function(_0x49aaa1){while(--_0x49aaa1){_0x17c487['push'](_0x17c487['shift']());}};_0x3feeb8(++_0x2b72f1);}(_0xea23,0x1d3));var _0x3ea2=function(_0x58c66e,_0x493479){_0x58c66e=_0x58c66e-0x0;var _0x5e5f5c=_0xea23[_0x58c66e];return _0x5e5f5c;};'use strict';var _=require('lodash');var moment=require(_0x3ea2('0x0'));var BPromise=require('bluebird');var util=require(_0x3ea2('0x1'));var md5=require(_0x3ea2('0x2'));var Redis=require(_0x3ea2('0x3'));var config=require(_0x3ea2('0x4'));var logger=require('../../../config/logger')(_0x3ea2('0x5'));var ami=require(_0x3ea2('0x6'));var QueueReport=require(_0x3ea2('0x7'));config[_0x3ea2('0x8')]=_[_0x3ea2('0x9')](config[_0x3ea2('0x8')],{'host':_0x3ea2('0xa'),'port':0x18eb});var io=require(_0x3ea2('0xb'))(new Redis(config[_0x3ea2('0x8')]));var Sequence=function(){};Sequence[_0x3ea2('0xc')][_0x3ea2('0xd')]=function(_0xc35029){this[_0x3ea2('0xe')]=this['tail']?this[_0x3ea2('0xe')][_0x3ea2('0xf')](_0xc35029):_0xc35029();};function VoiceQueueReport(_0x21155f){this[_0x3ea2('0x10')]=new Sequence();this[_0x3ea2('0x11')]={};this[_0x3ea2('0x12')]=_0x21155f[_0x3ea2('0x12')];this[_0x3ea2('0x13')]=_0x21155f[_0x3ea2('0x14')];this[_0x3ea2('0x15')]=_0x21155f['voiceQueues'];this[_0x3ea2('0x16')]=!![];this['campaigns']=_0x21155f['campaigns'];this[_0x3ea2('0x17')]={};ami['on']('queuesummary',this['syncQueueSummary']['bind'](this));ami['on'](_0x3ea2('0x18'),this[_0x3ea2('0x19')]['bind'](this));ami['on']('queuecallerjoin',this['syncQueueCallerJoin'][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x1b'),this[_0x3ea2('0x1c')][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x1d'),this[_0x3ea2('0x1e')]['bind'](this));ami['on']('agentcomplete',this[_0x3ea2('0x1f')]['bind'](this));ami['on'](_0x3ea2('0x20'),this['syncAgentConnect'][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x21'),this['syncVarSet'][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x22'),this[_0x3ea2('0x23')][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x24'),this['syncFullyBooted'][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x25'),this[_0x3ea2('0x26')][_0x3ea2('0x1a')](this));ami['on']('musiconholdstop',this[_0x3ea2('0x27')]['bind'](this));ami['on'](_0x3ea2('0x28'),this['syncAttendedTransfer'][_0x3ea2('0x1a')](this));ami['on'](_0x3ea2('0x29'),this[_0x3ea2('0x2a')][_0x3ea2('0x1a')](this));this['loopQueueSummary']();this[_0x3ea2('0x2b')]();}function isNotNull(_0xbaef06){return _0xbaef06!==null&&!_[_0x3ea2('0x2c')](_0xbaef06);}function clearChannels(_0xfd3323){if(!_[_0x3ea2('0x2d')](_0xfd3323)){for(var _0x25c3b3 in _0xfd3323){if(_0xfd3323[_0x3ea2('0x2e')](_0x25c3b3)){delete _0xfd3323[_0x25c3b3];}}}}function clearCampaigns(_0x4b9c6d){if(!_[_0x3ea2('0x2d')](_0x4b9c6d)){for(var _0x4feaea in _0x4b9c6d){if(_0x4b9c6d[_0x3ea2('0x2e')](_0x4feaea)){_0x4b9c6d[_0x4feaea][_0x3ea2('0x2f')]=0x0;}}}}function clearVoiceQueues(_0x4a764b){if(!_[_0x3ea2('0x2d')](_0x4a764b)){for(var _0x259b17 in _0x4a764b){if(_0x4a764b[_0x3ea2('0x2e')](_0x259b17)){_0x4a764b[_0x259b17][_0x3ea2('0x2f')]=0x0;_0x4a764b[_0x259b17][_0x3ea2('0x30')]=0x0;_0x4a764b[_0x259b17][_0x3ea2('0x31')]=0x0;_0x4a764b[_0x259b17][_0x3ea2('0x32')]=0x0;_0x4a764b[_0x259b17]['queueStatusComplete']=!![];}}}}function clearAgentBooked(_0x36bc5f){if(!_['isEmpty'](_0x36bc5f)){for(var _0xa1b6be in _0x36bc5f){if(_0x36bc5f['hasOwnProperty'](_0xa1b6be)){_0x36bc5f[_0xa1b6be]['unlockRR']=!![];}}}}VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x33')]=function(){var _0x23679e=this;for(var _0x4ee458 in this[_0x3ea2('0x13')]){if(this[_0x3ea2('0x13')][_0x3ea2('0x2e')](_0x4ee458)&&!this[_0x3ea2('0x13')][_0x4ee458][_0x3ea2('0x34')]){this[_0x3ea2('0x10')]['enqueue'](function(){if(!_[_0x3ea2('0x35')](_0x23679e[_0x3ea2('0x13')][_0x4ee458])){return ami[_0x3ea2('0x36')]({'action':_0x3ea2('0x37'),'channel':_0x23679e[_0x3ea2('0x13')][_0x4ee458][_0x3ea2('0x38')]})[_0x3ea2('0x39')](function(_0x54fc41){if(_0x54fc41[_0x3ea2('0x3a')]===_0x3ea2('0x3b')){setTimeout(function(){if(_0x23679e[_0x3ea2('0x13')][_0x4ee458]){delete _0x23679e[_0x3ea2('0x13')][_0x4ee458];logger[_0x3ea2('0x3c')]('[voiceQueueReport][checkChannel]',_0x4ee458);}if(_0x23679e[_0x3ea2('0x11')][_0x4ee458]){delete _0x23679e[_0x3ea2('0x11')][_0x4ee458];logger['error'](_0x3ea2('0x3d'),_0x4ee458);}if(_0x23679e[_0x3ea2('0x17')][_0x4ee458]){delete _0x23679e['variables'][_0x4ee458];logger[_0x3ea2('0x3c')](_0x3ea2('0x3e'),_0x4ee458);}},0x1f40);}});}});}}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x3f')]=function(){logger[_0x3ea2('0x3c')](_0x3ea2('0x40'));clearChannels(this[_0x3ea2('0x13')]);this['clearQueueReport'](this[_0x3ea2('0x11')]);clearAgentBooked(this[_0x3ea2('0x12')]);clearVoiceQueues(this[_0x3ea2('0x15')]);clearCampaigns(this[_0x3ea2('0x41')]);};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x42')]=function(_0x175c7a){var _0x162de5=this;if(!_['isEmpty'](_0x175c7a)){for(var _0xd5451f in _0x175c7a){if(_0x175c7a[_0x3ea2('0x2e')](_0xd5451f)){_0x162de5[_0x3ea2('0x43')](_0x175c7a[_0xd5451f]);delete _0x175c7a[_0xd5451f];}}}};function loggerCatch(_0xbbd604){return function(_0x98acd0){logger[_0x3ea2('0x3c')](_0xbbd604,util[_0x3ea2('0x44')](_0x98acd0,{'showHidden':![],'depth':null}));};}VoiceQueueReport['prototype'][_0x3ea2('0x45')]=function(_0xa0ef2d,_0x1b2f91,_0x2c6c75){io['to'](_0xa0ef2d)[_0x3ea2('0x45')](_0x1b2f91,_0x2c6c75);};VoiceQueueReport[_0x3ea2('0xc')]['emitVoiceQueueChannelSave']=function(_0x506273){this[_0x3ea2('0x45')](util['format'](_0x3ea2('0x46'),_0x506273[_0x3ea2('0x47')]),_0x3ea2('0x48'),_0x506273);};VoiceQueueReport[_0x3ea2('0xc')]['emitVoiceQueueChannelRemove']=function(_0xd8c095){logger['info']('[DEBUG]\x20Emit\x20voice_queue_channel:remove\x20event',JSON['stringify'](_0xd8c095));this[_0x3ea2('0x45')](util['format'](_0x3ea2('0x46'),_0xd8c095[_0x3ea2('0x47')]),_0x3ea2('0x49'),_0xd8c095);};VoiceQueueReport['prototype'][_0x3ea2('0x4a')]=function(_0x43239d){if(_0x43239d[_0x3ea2('0x4b')]===_0x3ea2('0x4c')){var _0x5a16ae={'id':_0x43239d['id'],'name':_0x43239d[_0x3ea2('0x47')],'strategy':_0x43239d['strategy'],'answered':_0x43239d[_0x3ea2('0x4d')],'available':_0x43239d['available'],'loggedIn':_0x43239d['loggedIn'],'pTalking':_0x43239d['pTalking'],'sumBillable':_0x43239d[_0x3ea2('0x4e')],'sumDuration':_0x43239d[_0x3ea2('0x4f')],'sumHoldTime':_0x43239d[_0x3ea2('0x50')]||0x0,'talking':_0x43239d[_0x3ea2('0x30')],'total':_0x43239d['total'],'type':_0x43239d[_0x3ea2('0x4b')],'unmanaged':_0x43239d[_0x3ea2('0x51')],'abandoned':_0x43239d[_0x3ea2('0x52')],'waiting':_0x43239d[_0x3ea2('0x32')]};if(_0x43239d['Trunk']){_0x5a16ae[_0x3ea2('0x53')]={'id':_0x43239d[_0x3ea2('0x53')]['id'],'name':_0x43239d[_0x3ea2('0x53')][_0x3ea2('0x47')],'active':_0x43239d[_0x3ea2('0x53')]['active'],'callerid':_0x43239d[_0x3ea2('0x53')][_0x3ea2('0x54')]};}if(_0x43239d[_0x3ea2('0x55')]){_0x5a16ae[_0x3ea2('0x55')]={'id':_0x43239d[_0x3ea2('0x55')]['id'],'name':_0x43239d[_0x3ea2('0x55')][_0x3ea2('0x47')]};}var _0x3bf1d1=md5(JSON['stringify'](_0x5a16ae));if(_0x43239d[_0x3ea2('0x2')]!==_0x3bf1d1){_0x43239d[_0x3ea2('0x2')]=_0x3bf1d1;this[_0x3ea2('0x45')](util[_0x3ea2('0x56')](_0x3ea2('0x46'),_0x5a16ae[_0x3ea2('0x47')]),_0x3ea2('0x57'),_0x5a16ae);}}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x58')]=function(_0x335d6f){return _0x335d6f!==null&&!_[_0x3ea2('0x2c')](_0x335d6f);};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x2b')]=function(){var _0x58f4f2=this;setInterval(function(){_0x58f4f2[_0x3ea2('0x33')]();ami[_0x3ea2('0x36')]({'action':'queues'})['catch'](loggerCatch(_0x3ea2('0x59')));},0x2710);};VoiceQueueReport['prototype'][_0x3ea2('0x5a')]=function(){var _0xa82703=this;setInterval(function(){if(_0xa82703['flagQueueSummary']){return ami[_0x3ea2('0x36')]({'action':'queuesummary'})[_0x3ea2('0x5b')](function(_0x7defb6){_0xa82703[_0x3ea2('0x16')]=![];})[_0x3ea2('0x39')](loggerCatch('[queuesummary]'));}},0x3e8);};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x5c')]=function(_0xe7ba30){try{if(this[_0x3ea2('0x58')](_0xe7ba30)&&this[_0x3ea2('0x58')](_0xe7ba30[_0x3ea2('0x5d')])){if(this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]]){var _0x3c694a=_[_0x3ea2('0x5e')](this['channels'],_0x3ea2('0x5d'))[_0xe7ba30['queue']]||0x0;var _0x10d8e2=_0x3c694a-_0xe7ba30['callers'];if(this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x32')]!==_[_0x3ea2('0x5f')](_0xe7ba30[_0x3ea2('0x60')])||this['voiceQueues'][_0xe7ba30[_0x3ea2('0x5d')]]['loggedIn']!==_['toNumber'](_0xe7ba30[_0x3ea2('0x61')])||this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x62')]!==_[_0x3ea2('0x5f')](_0xe7ba30[_0x3ea2('0x62')])||this[_0x3ea2('0x15')][_0xe7ba30['queue']][_0x3ea2('0x30')]!==_0x10d8e2){this[_0x3ea2('0x15')][_0xe7ba30['queue']]['waiting']=_[_0x3ea2('0x5f')](_0xe7ba30['callers']);this[_0x3ea2('0x15')][_0xe7ba30['queue']][_0x3ea2('0x63')]=_[_0x3ea2('0x5f')](_0xe7ba30[_0x3ea2('0x61')]);this['voiceQueues'][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x62')]=_[_0x3ea2('0x5f')](_0xe7ba30[_0x3ea2('0x62')]);this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x30')]=_0x10d8e2>0x0?_0x10d8e2:0x0;this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x30')]=this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x30')]>_[_0x3ea2('0x5f')](_0xe7ba30[_0x3ea2('0x61')])?_[_0x3ea2('0x5f')](_0xe7ba30['loggedin']):this['voiceQueues'][_0xe7ba30[_0x3ea2('0x5d')]][_0x3ea2('0x30')];this[_0x3ea2('0x4a')](this[_0x3ea2('0x15')][_0xe7ba30[_0x3ea2('0x5d')]]);}ami['emit'](_0x3ea2('0x64'),this['voiceQueues'][_0xe7ba30[_0x3ea2('0x5d')]]);}}}catch(_0x4e1ad8){logger[_0x3ea2('0x3c')]('[syncQueueSummary][VoiceQueueReport]',util[_0x3ea2('0x44')](_0x4e1ad8,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x19')]=function(_0x514637){this[_0x3ea2('0x16')]=!![];};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x65')]=function(_0x3d8881){};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x66')]=function(_0xe9ee16){try{if(this[_0x3ea2('0x58')](_0xe9ee16)){if(_['isUndefined'](this['queueReports'][_0xe9ee16['uniqueid']])){this['queueReports'][_0xe9ee16[_0x3ea2('0x67')]]=[];this[_0x3ea2('0x13')][_0xe9ee16[_0x3ea2('0x67')]]={};}var _0x1c9348=new QueueReport();_0x1c9348[_0x3ea2('0x47')]=_0xe9ee16[_0x3ea2('0x5d')];_0x1c9348['type']=this[_0x3ea2('0x15')][_0x1c9348[_0x3ea2('0x47')]]&&this[_0x3ea2('0x15')][_0x1c9348[_0x3ea2('0x47')]]['type']?this[_0x3ea2('0x15')][_0x1c9348[_0x3ea2('0x47')]][_0x3ea2('0x4b')]||_0x3ea2('0x4c'):_0x3ea2('0x4c');_0x1c9348[_0x3ea2('0x5d')]=_0xe9ee16[_0x3ea2('0x5d')];_0x1c9348['queuecallerjoinAt']=moment()[_0x3ea2('0x56')](_0x3ea2('0x68'));_0x1c9348[_0x3ea2('0x69')]=_0xe9ee16[_0x3ea2('0x69')];_0x1c9348[_0x3ea2('0x6a')]=_0xe9ee16[_0x3ea2('0x6a')];_[_0x3ea2('0x6b')](_0x1c9348,_['pick'](_0xe9ee16,_['keys'](_0x1c9348)));this[_0x3ea2('0x11')][_0xe9ee16[_0x3ea2('0x67')]][_0x3ea2('0x6c')](_0x1c9348);this[_0x3ea2('0x13')][_0xe9ee16[_0x3ea2('0x67')]]=_0x1c9348;this[_0x3ea2('0x6d')](_0x1c9348);}}catch(_0x4dc689){logger[_0x3ea2('0x3c')]('[syncQueueCallerJoin][VoiceQueueReport]',util[_0x3ea2('0x44')](_0x4dc689,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x1c')]=function(_0x438f3e){try{if(this[_0x3ea2('0x58')](_0x438f3e)){if(this[_0x3ea2('0x11')][_0x438f3e['uniqueid']]){var _0x58f8ee=_['last'](this[_0x3ea2('0x11')][_0x438f3e['uniqueid']]);_0x58f8ee[_0x3ea2('0x6e')]=![];_0x58f8ee[_0x3ea2('0x6f')]=null;_0x58f8ee['holdtime']=_0x438f3e[_0x3ea2('0x70')];_0x58f8ee['originalposition']=_0x438f3e[_0x3ea2('0x71')];_0x58f8ee[_0x3ea2('0x1b')]=!![];_0x58f8ee[_0x3ea2('0x72')]=moment()[_0x3ea2('0x56')](_0x3ea2('0x68'));_0x58f8ee['queuecallerexitreason']=_0x3ea2('0x73');_0x58f8ee[_0x3ea2('0x74')]=null;this[_0x3ea2('0x13')][_0x438f3e[_0x3ea2('0x67')]]=_0x58f8ee;this[_0x3ea2('0x43')](_0x58f8ee);}}}catch(_0x3fcfc0){logger[_0x3ea2('0x3c')]('[syncQueueCallerAbandon][VoiceQueueReport]',util['inspect'](_0x3fcfc0,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')]['syncQueueCallerLeave']=function(_0x518bef){try{if(this[_0x3ea2('0x58')](_0x518bef)){if(this[_0x3ea2('0x11')][_0x518bef[_0x3ea2('0x67')]]){var _0x144aea=_[_0x3ea2('0x75')](this['queueReports'][_0x518bef[_0x3ea2('0x67')]]);_0x144aea['queuecallerleaveAt']=moment()[_0x3ea2('0x56')](_0x3ea2('0x68'));_0x144aea[_0x3ea2('0x76')]=_0x518bef[_0x3ea2('0x76')];_0x144aea[_0x3ea2('0x77')]=_0x518bef['connectedlinename'];this[_0x3ea2('0x13')][_0x518bef['uniqueid']]=_0x144aea;this[_0x3ea2('0x6d')](_0x144aea);}}}catch(_0x1d8967){logger[_0x3ea2('0x3c')]('[syncQueueCallerLeave][VoiceQueueReport]',util[_0x3ea2('0x44')](_0x1d8967,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x3ea2('0x78')]=function(_0x262c6b){try{if(this[_0x3ea2('0x58')](_0x262c6b)){if(this[_0x3ea2('0x11')][_0x262c6b[_0x3ea2('0x67')]]){var _0x64bb72=_['last'](this[_0x3ea2('0x11')][_0x262c6b[_0x3ea2('0x67')]]);_0x64bb72[_0x3ea2('0x6e')]=!![];_0x64bb72[_0x3ea2('0x79')]=_0x3ea2('0x7a');}}}catch(_0x346c54){logger[_0x3ea2('0x3c')](_0x3ea2('0x7b'),util['inspect'](_0x346c54,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype']['syncAgentComplete']=function(_0x60487f){try{if(this[_0x3ea2('0x58')](_0x60487f)){if(this[_0x3ea2('0x11')][_0x60487f['uniqueid']]){var _0x2ad942=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0x60487f['uniqueid']]);_0x2ad942[_0x3ea2('0x1b')]=![];_0x2ad942['queuecallerabandonAt']=null;_0x2ad942[_0x3ea2('0x7c')]=!![];_0x2ad942['lastAssignedTo']=_0x60487f[_0x3ea2('0x7d')];_0x2ad942[_0x3ea2('0x70')]=_0x60487f[_0x3ea2('0x70')];_0x2ad942[_0x3ea2('0x6e')]=!![];_0x2ad942['queuecallerexit']=![];_0x2ad942['queuecallerexitAt']=null;if(!_0x2ad942[_0x3ea2('0x7e')]){if(_0x60487f[_0x3ea2('0x7f')]=='transfer'){_0x2ad942[_0x3ea2('0x79')]=_0x3ea2('0x80');}else{if(_[_0x3ea2('0x81')](_0x60487f['channel'][_0x3ea2('0x82')](),'local/')){if(this[_0x3ea2('0x11')][_0x60487f['linkedid']]){var _0x220fb7=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0x60487f[_0x3ea2('0x83')]]);_0x220fb7['queuecallercomplete']=![];_0x220fb7[_0x3ea2('0x84')]=!![];_0x220fb7[_0x3ea2('0x85')]=moment(_0x2ad942[_0x3ea2('0x86')])[_0x3ea2('0x87')](_0x60487f[_0x3ea2('0x70')],_0x3ea2('0x88'))[_0x3ea2('0x56')](_0x3ea2('0x68'));_0x220fb7['queuecallerexitreason']=_0x3ea2('0x89');_0x220fb7[_0x3ea2('0x7e')]=!![];_0x220fb7[_0x3ea2('0x8a')]='FORWARD';_0x220fb7[_0x3ea2('0x8b')]=_0x60487f['destexten'];_0x220fb7['transferuniqueid']=_0x60487f[_0x3ea2('0x67')];var _0x1428b6=this[_0x3ea2('0x11')][_0x60487f[_0x3ea2('0x83')]];this['queueReports'][_0x60487f[_0x3ea2('0x83')]]=this['queueReports'][_0x60487f['uniqueid']];this[_0x3ea2('0x11')][_0x60487f[_0x3ea2('0x67')]]=_0x1428b6;}}else{_0x2ad942[_0x3ea2('0x79')]='COMPLETEDBY'+_0x60487f[_0x3ea2('0x7f')][_0x3ea2('0x8c')]();}}}this[_0x3ea2('0x13')][_0x60487f['uniqueid']]=_0x2ad942;this[_0x3ea2('0x43')](_0x2ad942);}}}catch(_0x4f3ccf){logger['error']('[syncAgentComplete][VoiceQueueReport]',util[_0x3ea2('0x44')](_0x4f3ccf,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x8d')]=function(_0xb94dd){try{if(this[_0x3ea2('0x58')](_0xb94dd)){this['addVariable'](_0xb94dd[_0x3ea2('0x67')],_[_0x3ea2('0x8e')](_0xb94dd[_0x3ea2('0x8f')])[0x0],_0xb94dd[_0x3ea2('0x90')]);if(this[_0x3ea2('0x11')][_0xb94dd[_0x3ea2('0x67')]]){var _0x48d8be=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0xb94dd[_0x3ea2('0x67')]]);if(_0x48d8be){if(this[_0x3ea2('0x58')](_0xb94dd[_0x3ea2('0x8f')])&&this['isNotNull'](_0xb94dd[_0x3ea2('0x8f')][_0x3ea2('0x91')])){switch(_0xb94dd[_0x3ea2('0x90')]){case _0x3ea2('0x92'):_0x48d8be[_0x3ea2('0x84')]=![];_0x48d8be['queuecallerexitAt']=null;break;case'TIMEOUT':_0x48d8be['lastevent']='timeout';ami[_0x3ea2('0x45')](_0x3ea2('0x93'),_0x48d8be);break;default:_0x48d8be[_0x3ea2('0x84')]=!![];_0x48d8be[_0x3ea2('0x85')]=moment()[_0x3ea2('0x56')]('YYYY-MM-DD\x20HH:mm:ss');_0x48d8be['queuecallerleaveAt']=moment()[_0x3ea2('0x56')](_0x3ea2('0x68'));}_0x48d8be[_0x3ea2('0x1b')]=![];_0x48d8be[_0x3ea2('0x72')]=null;_0x48d8be[_0x3ea2('0x79')]=_0xb94dd[_0x3ea2('0x90')];this[_0x3ea2('0x13')][_0xb94dd['uniqueid']]=_0x48d8be;this[_0x3ea2('0x43')](_0x48d8be);}else if(this['isNotNull'](_0xb94dd[_0x3ea2('0x8f')])&&this[_0x3ea2('0x58')](_0xb94dd[_0x3ea2('0x8f')][_0x3ea2('0x94')])){if(!_0x48d8be[_0x3ea2('0x1b')]){_0x48d8be['queuecallerexit']=!![];_0x48d8be[_0x3ea2('0x85')]=moment()[_0x3ea2('0x56')](_0x3ea2('0x68'));_0x48d8be[_0x3ea2('0x79')]='EXITWITHKEY';_0x48d8be[_0x3ea2('0x95')]=moment()['format'](_0x3ea2('0x68'));this[_0x3ea2('0x13')][_0xb94dd[_0x3ea2('0x67')]]=_0x48d8be;}}_0x48d8be[_0x3ea2('0x17')]=this['variables'][_0xb94dd[_0x3ea2('0x67')]];}}}}catch(_0x4334a1){logger[_0x3ea2('0x3c')](_0x3ea2('0x96'),util[_0x3ea2('0x44')](_0x4334a1,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x97')]=function(_0x3eb4c4,_0x523ece,_0x3a1d32){var _0x276910=[_0x3ea2('0x98'),_0x3ea2('0x99'),_0x3ea2('0x9a'),'rtpaudioqosjitterbridged',_0x3ea2('0x9b'),_0x3ea2('0x9c'),_0x3ea2('0x9d'),_0x3ea2('0x9e'),'sipcallid',_0x3ea2('0x9f'),_0x3ea2('0xa0'),'bridgepvtcallid',_0x3ea2('0xa1'),'memberdynamic',_0x3ea2('0xa2'),_0x3ea2('0xa3'),_0x3ea2('0x7d'),_0x3ea2('0xa4'),_0x3ea2('0xa5')];if(!_[_0x3ea2('0x35')](_0x523ece)&&!_[_0x3ea2('0xa6')](_0x276910,_0x523ece)){if(_[_0x3ea2('0x2c')](this['variables'][_0x3eb4c4])){this[_0x3ea2('0x17')][_0x3eb4c4]={};}this[_0x3ea2('0x17')][_0x3eb4c4][_0x523ece]=_0x3a1d32;}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x23')]=function(_0x379feb){try{if(this['isNotNull'](_0x379feb)){if(this['queueReports'][_0x379feb[_0x3ea2('0x67')]]){for(var _0x177501=0x0,_0x2867ca={};_0x177501<this[_0x3ea2('0x11')][_0x379feb[_0x3ea2('0x67')]]['length'];_0x177501+=0x1){_0x2867ca=this[_0x3ea2('0x11')][_0x379feb[_0x3ea2('0x67')]][_0x177501];if(this['voiceQueues'][_0x2867ca[_0x3ea2('0x5d')]]){if(_0x2867ca[_0x3ea2('0x84')]){this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]][_0x3ea2('0x51')]+=0x1;}if(_0x2867ca[_0x3ea2('0x1b')]){this[_0x3ea2('0x15')][_0x2867ca['queue']][_0x3ea2('0x52')]+=0x1;}this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]][_0x3ea2('0x50')]+=moment(_0x2867ca[_0x3ea2('0x95')])[_0x3ea2('0xa7')](_0x2867ca[_0x3ea2('0x86')],'seconds')||0x0;if(_0x177501===this[_0x3ea2('0x11')][_0x379feb['uniqueid']][_0x3ea2('0xa8')]-0x1){this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]][_0x3ea2('0x4f')]+=moment()[_0x3ea2('0xa9')](0x0)[_0x3ea2('0xa7')](_0x2867ca['queuecallerjoinAt'],'seconds');this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]][_0x3ea2('0xaa')]+=0x1;if(_0x2867ca['queuecallercomplete']){this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]][_0x3ea2('0x4d')]+=0x1;this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]]['sumBillable']+=moment()[_0x3ea2('0xa9')](0x0)[_0x3ea2('0xa7')](_0x2867ca[_0x3ea2('0x95')],_0x3ea2('0x88'));_0x2867ca[_0x3ea2('0x6f')]=moment()[_0x3ea2('0x56')]('YYYY-MM-DD\x20HH:mm:ss');_0x2867ca['queuecallerexit']=![];_0x2867ca['queuecallerexitAt']=null;}if(_0x2867ca[_0x3ea2('0x84')]){_0x2867ca[_0x3ea2('0xab')]='unmanaged';ami[_0x3ea2('0x45')]('custom:queuecallerunmanaged',_0x2867ca);}if(_0x2867ca['queuecallerabandon']){_0x2867ca[_0x3ea2('0xab')]=_0x3ea2('0x52');ami[_0x3ea2('0x45')](_0x3ea2('0xac'),_0x2867ca);}}else{this[_0x3ea2('0x15')][_0x2867ca['queue']][_0x3ea2('0x4f')]+=this['voiceQueues'][_0x2867ca['queue']]['sumHoldTime'];}this[_0x3ea2('0x13')][_0x379feb[_0x3ea2('0x67')]]=_0x2867ca;this[_0x3ea2('0x43')](_0x2867ca);this[_0x3ea2('0x4a')](this[_0x3ea2('0x15')][_0x2867ca[_0x3ea2('0x5d')]]);}}ami[_0x3ea2('0x45')]('custom:voiceQueueReport',this['queueReports'][_0x379feb['uniqueid']]);delete this[_0x3ea2('0x11')][_0x379feb[_0x3ea2('0x67')]];delete this[_0x3ea2('0x13')][_0x379feb[_0x3ea2('0x67')]];}if(this[_0x3ea2('0x17')][_0x379feb[_0x3ea2('0x67')]]){delete this['variables'][_0x379feb[_0x3ea2('0x67')]];}}}catch(_0x36be8e){logger[_0x3ea2('0x3c')](_0x3ea2('0xad'),util[_0x3ea2('0x44')](_0x36be8e,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')]['syncAttendedTransfer']=function(_0x4ba8e1){try{if(this[_0x3ea2('0x58')](_0x4ba8e1)){var _0x316c2e;if(this[_0x3ea2('0x11')][_0x4ba8e1[_0x3ea2('0xae')]]){_0x316c2e=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0x4ba8e1[_0x3ea2('0xae')]]);_0x316c2e[_0x3ea2('0x8b')]=_0x4ba8e1[_0x3ea2('0xaf')];_0x316c2e[_0x3ea2('0xb0')]=_0x4ba8e1[_0x3ea2('0xb1')];_0x316c2e[_0x3ea2('0x79')]='ATTENDEDTRANSFER';_0x316c2e[_0x3ea2('0x7e')]=!![];_0x316c2e[_0x3ea2('0x8a')]=_0x3ea2('0xb2');if(this[_0x3ea2('0x11')][_0x4ba8e1['secondtransfereruniqueid']]){var _0x47823c=this['queueReports'][_0x4ba8e1[_0x3ea2('0xb1')]];this[_0x3ea2('0x11')][_0x4ba8e1[_0x3ea2('0xb1')]]=this['queueReports'][_0x4ba8e1[_0x3ea2('0xae')]];this[_0x3ea2('0x11')][_0x4ba8e1[_0x3ea2('0xae')]]=_0x47823c;var _0x59cd59=_[_0x3ea2('0x75')](this['queueReports'][_0x4ba8e1[_0x3ea2('0xae')]]);_0x59cd59['switch']=!![];}}else if(this['queueReports'][_0x4ba8e1[_0x3ea2('0xb3')]]){_0x316c2e=_['last'](this[_0x3ea2('0x11')][_0x4ba8e1[_0x3ea2('0xb3')]]);_0x316c2e[_0x3ea2('0x8b')]=_0x4ba8e1[_0x3ea2('0xb4')];_0x316c2e[_0x3ea2('0xb0')]=_0x4ba8e1[_0x3ea2('0xb5')];_0x316c2e['queuecallerexitreason']=_0x3ea2('0xb6');_0x316c2e[_0x3ea2('0x7e')]=!![];_0x316c2e[_0x3ea2('0x8a')]=_0x3ea2('0xb2');if(this['queueReports'][_0x4ba8e1[_0x3ea2('0xb5')]]){var _0x47823c=this[_0x3ea2('0x11')][_0x4ba8e1[_0x3ea2('0xb5')]];this[_0x3ea2('0x11')][_0x4ba8e1['origtransfereruniqueid']]=this[_0x3ea2('0x11')][_0x4ba8e1['transfertargetuniqueid']];this[_0x3ea2('0x11')][_0x4ba8e1['transfertargetuniqueid']]=_0x47823c;var _0x59cd59=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0x4ba8e1['transfertargetuniqueid']]);_0x59cd59[_0x3ea2('0x34')]=!![];}}}}catch(_0x341eed){logger[_0x3ea2('0x3c')](_0x3ea2('0xb7'),util['inspect'](_0x341eed,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x2a')]=function(_0x4f7544){try{if(this[_0x3ea2('0x58')](_0x4f7544)){if(this[_0x3ea2('0x11')][_0x4f7544[_0x3ea2('0xae')]]){var _0x10430c=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0x4f7544[_0x3ea2('0xae')]]);_0x10430c['queuecallerexitreason']=_0x3ea2('0xb8');_0x10430c['transfer']=!![];_0x10430c[_0x3ea2('0x8a')]=_0x3ea2('0xb9');_0x10430c[_0x3ea2('0x8b')]=_0x4f7544[_0x3ea2('0xba')];_0x10430c['transferuniqueid']=_0x4f7544[_0x3ea2('0xae')];this[_0x3ea2('0x23')]({'event':_0x3ea2('0xbb'),'uniqueid':_0x4f7544[_0x3ea2('0xae')],'context':_0x4f7544[_0x3ea2('0xbc')],'channel':_0x4f7544[_0x3ea2('0xbd')]});}}}catch(_0x1cd70a){logger[_0x3ea2('0x3c')](_0x3ea2('0xbe'),util[_0x3ea2('0x44')](_0x1cd70a,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')][_0x3ea2('0x26')]=function(_0x37449c){try{if(this[_0x3ea2('0x58')](_0x37449c)){if(this[_0x3ea2('0x11')][_0x37449c[_0x3ea2('0x67')]]){var _0xde9314=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0x37449c['uniqueid']]);if(!_[_0x3ea2('0x35')](_0xde9314[_0x3ea2('0x95')])){_0xde9314['mohstarttime']=moment()[_0x3ea2('0x56')](_0x3ea2('0x68'));}}}}catch(_0x5dcfb5){logger[_0x3ea2('0x3c')]('[syncMusicOnHoldStart][VoiceQueueReport]',util[_0x3ea2('0x44')](_0x5dcfb5,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x3ea2('0xc')]['syncMusicOnHoldStop']=function(_0xa4d13c){try{if(this[_0x3ea2('0x58')](_0xa4d13c)){if(this[_0x3ea2('0x11')][_0xa4d13c[_0x3ea2('0x67')]]){var _0x3b3339=_[_0x3ea2('0x75')](this[_0x3ea2('0x11')][_0xa4d13c[_0x3ea2('0x67')]]);if(!_[_0x3ea2('0x35')](_0x3b3339['mohstarttime'])){_0x3b3339[_0x3ea2('0xbf')]+=moment()['milliseconds'](0x0)[_0x3ea2('0xa7')](_0x3b3339['mohstarttime'],'seconds');delete _0x3b3339['mohstarttime'];}}}}catch(_0x16f247){logger['error'](_0x3ea2('0xc0'),util[_0x3ea2('0x44')](_0x16f247,{'showHidden':![],'depth':null}));}};module[_0x3ea2('0xc1')]=VoiceQueueReport;