Built motion from commit (unavailable).|2.5.3
[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 _0xd738=['[syncBlindTransfer][VoiceQueueReport]','mohstarttime','[syncMusicOnHoldStart][VoiceQueueReport]','syncMusicOnHoldStop','mohtime','[syncMusicOnHoldStop][VoiceQueueReport]','exports','lodash','moment','bluebird','md5','ioredis','../../../config/environment','../../../config/logger','../ami','../model/queueReport','redis','prototype','tail','finally','sequence','queueReports','agents','channels','queueChannels','voiceQueues','flagQueueSummary','campaigns','variables','queuesummary','syncQueueSummary','bind','queuecallerjoin','syncQueueCallerJoin','syncQueueCallerAbandon','syncQueueCallerLeave','syncAgentComplete','agentconnect','varset','hangup','syncHangup','fullybooted','musiconholdstart','syncMusicOnHoldStart','musiconholdstop','attendedtransfer','blindtransfer','syncBlindTransfer','loopQueueSummary','hasOwnProperty','originated','talking','pTalking','waiting','queueStatusComplete','unlockRR','clearZombieChannels','switch','isNil','Action','status','catch','message','No\x20such\x20channel','error','syncFullyBooted','[FullyBooted]\x20clear\x20realtime','clearQueueReport','isEmpty','emitVoiceQueueChannelRemove','inspect','emit','format','voice:queue:%s','name','voice_queue_channel:save','info','[DEBUG]\x20Emit\x20voice_queue_channel:remove\x20event','voice_queue_channel:remove','type','strategy','available','loggedIn','sumBillable','sumDuration','sumHoldTime','total','unmanaged','abandoned','Trunk','active','callerid','Interval','stringify','voice_queue:save','isNotNull','isUndefined','loopQueueShow','queues','[queues]','then','[queuesummary]','queue','countBy','callers','toNumber','loggedin','custom:queuesummary','[syncQueueSummary][VoiceQueueReport]','syncNewExten','uniqueid','inbound','queuecallerjoinAt','YYYY-MM-DD\x20HH:mm:ss','position','pick','emitVoiceQueueChannelSave','last','queuecallercomplete','queuecallercompleteAt','originalposition','queuecallerabandon','queuecallerabandonAt','queuecallerexitreason','ABANDONED','lastAssignedTo','[syncQueueCallerAbandon][VoiceQueueReport]','queuecallerleaveAt','connectedlinenum','connectedlinename','[syncQueueCallerLeave][VoiceQueueReport]','[syncAgentConnect][VoiceQueueReport]','membername','holdtime','queuecallerexit','queuecallerexitAt','transfer','reason','COMPLETED','startsWith','toLowerCase','local/','seconds','FORWARDTRANSFER','transfertype','FORWARD','destexten','transferuniqueid','COMPLETEDBY','toUpperCase','[syncAgentComplete][VoiceQueueReport]','syncVarSet','addVariable','variable','queuestatus','value','CONTINUE','lastevent','timeout','queueposition','EXITWITHKEY','[syncVarSet][VoiceQueueReport]','rtpaudioqosjitter','rtpaudioqoslossbridged','rtpaudioqosrttbridged','sipcallid','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberlastcall','memberpenalty','length','diff','milliseconds','answered','custom:queuecallerunmanaged','custom:queuecallerabandon','emitVoiceQueueSummary','syncAttendedTransfer','transfereeuniqueid','transferexten','secondtransfererexten','secondtransfereruniqueid','ATTENDEDTRANSFER','transfertargetuniqueid','origtransfereruniqueid','[syncAttendedTransfer][VoiceQueueReport]','BLINDTRANSFER','BLIND','extension','BlindTransfer','transfererchannel'];(function(_0x1f119f,_0x17df65){var _0x26c3b6=function(_0x5e561b){while(--_0x5e561b){_0x1f119f['push'](_0x1f119f['shift']());}};_0x26c3b6(++_0x17df65);}(_0xd738,0x18d));var _0x8d73=function(_0x3e0312,_0x103eb7){_0x3e0312=_0x3e0312-0x0;var _0x13221a=_0xd738[_0x3e0312];return _0x13221a;};'use strict';var _=require(_0x8d73('0x0'));var moment=require(_0x8d73('0x1'));var BPromise=require(_0x8d73('0x2'));var util=require('util');var md5=require(_0x8d73('0x3'));var Redis=require(_0x8d73('0x4'));var config=require(_0x8d73('0x5'));var logger=require(_0x8d73('0x6'))('ami');var ami=require(_0x8d73('0x7'));var QueueReport=require(_0x8d73('0x8'));config['redis']=_['defaults'](config[_0x8d73('0x9')],{'host':'localhost','port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0x8d73('0x9')]));var Sequence=function(){};Sequence[_0x8d73('0xa')]['enqueue']=function(_0x48fda8){this['tail']=this[_0x8d73('0xb')]?this[_0x8d73('0xb')][_0x8d73('0xc')](_0x48fda8):_0x48fda8();};function VoiceQueueReport(_0x3236c1){this[_0x8d73('0xd')]=new Sequence();this[_0x8d73('0xe')]={};this[_0x8d73('0xf')]=_0x3236c1['agents'];this[_0x8d73('0x10')]=_0x3236c1[_0x8d73('0x11')];this[_0x8d73('0x12')]=_0x3236c1[_0x8d73('0x12')];this[_0x8d73('0x13')]=!![];this[_0x8d73('0x14')]=_0x3236c1['campaigns'];this[_0x8d73('0x15')]={};ami['on'](_0x8d73('0x16'),this[_0x8d73('0x17')][_0x8d73('0x18')](this));ami['on']('queuesummarycomplete',this['syncQueueSummaryComplete'][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x19'),this[_0x8d73('0x1a')][_0x8d73('0x18')](this));ami['on']('queuecallerabandon',this[_0x8d73('0x1b')][_0x8d73('0x18')](this));ami['on']('queuecallerleave',this[_0x8d73('0x1c')][_0x8d73('0x18')](this));ami['on']('agentcomplete',this[_0x8d73('0x1d')][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x1e'),this['syncAgentConnect'][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x1f'),this['syncVarSet'][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x20'),this[_0x8d73('0x21')][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x22'),this['syncFullyBooted'][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x23'),this[_0x8d73('0x24')][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x25'),this['syncMusicOnHoldStop']['bind'](this));ami['on'](_0x8d73('0x26'),this['syncAttendedTransfer'][_0x8d73('0x18')](this));ami['on'](_0x8d73('0x27'),this[_0x8d73('0x28')][_0x8d73('0x18')](this));this[_0x8d73('0x29')]();this['loopQueueShow']();}function isNotNull(_0x4fa2d5){return _0x4fa2d5!==null&&!_['isUndefined'](_0x4fa2d5);}function clearChannels(_0x292a89){if(!_['isEmpty'](_0x292a89)){for(var _0x2fce11 in _0x292a89){if(_0x292a89[_0x8d73('0x2a')](_0x2fce11)){delete _0x292a89[_0x2fce11];}}}}function clearCampaigns(_0x3ecb60){if(!_['isEmpty'](_0x3ecb60)){for(var _0x433fec in _0x3ecb60){if(_0x3ecb60[_0x8d73('0x2a')](_0x433fec)){_0x3ecb60[_0x433fec][_0x8d73('0x2b')]=0x0;}}}}function clearVoiceQueues(_0x47fa4b){if(!_['isEmpty'](_0x47fa4b)){for(var _0x11c164 in _0x47fa4b){if(_0x47fa4b['hasOwnProperty'](_0x11c164)){_0x47fa4b[_0x11c164][_0x8d73('0x2b')]=0x0;_0x47fa4b[_0x11c164][_0x8d73('0x2c')]=0x0;_0x47fa4b[_0x11c164][_0x8d73('0x2d')]=0x0;_0x47fa4b[_0x11c164][_0x8d73('0x2e')]=0x0;_0x47fa4b[_0x11c164][_0x8d73('0x2f')]=!![];}}}}function clearAgentBooked(_0x4470f7){if(!_['isEmpty'](_0x4470f7)){for(var _0x1580c2 in _0x4470f7){if(_0x4470f7['hasOwnProperty'](_0x1580c2)){_0x4470f7[_0x1580c2][_0x8d73('0x30')]=!![];}}}}VoiceQueueReport['prototype'][_0x8d73('0x31')]=function(){var _0x2bbffb=this;for(var _0x4cfaae in this['channels']){if(this[_0x8d73('0x10')][_0x8d73('0x2a')](_0x4cfaae)&&!this['channels'][_0x4cfaae][_0x8d73('0x32')]){this['sequence']['enqueue'](function(){if(!_[_0x8d73('0x33')](_0x2bbffb[_0x8d73('0x10')][_0x4cfaae])){return ami[_0x8d73('0x34')]({'action':_0x8d73('0x35'),'channel':_0x2bbffb[_0x8d73('0x10')][_0x4cfaae]['channel']})[_0x8d73('0x36')](function(_0x168a35){if(_0x168a35[_0x8d73('0x37')]===_0x8d73('0x38')){setTimeout(function(){if(_0x2bbffb[_0x8d73('0x10')][_0x4cfaae]){delete _0x2bbffb[_0x8d73('0x10')][_0x4cfaae];logger[_0x8d73('0x39')]('[voiceQueueReport][checkChannel]',_0x4cfaae);}if(_0x2bbffb[_0x8d73('0xe')][_0x4cfaae]){delete _0x2bbffb[_0x8d73('0xe')][_0x4cfaae];logger['error']('[voiceQueueReport][checkQueueReport]',_0x4cfaae);}if(_0x2bbffb[_0x8d73('0x15')][_0x4cfaae]){delete _0x2bbffb[_0x8d73('0x15')][_0x4cfaae];logger['error']('[voiceQueueReport][checkVariables]',_0x4cfaae);}},0x1f40);}});}});}}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x3a')]=function(){logger[_0x8d73('0x39')](_0x8d73('0x3b'));clearChannels(this['channels']);this[_0x8d73('0x3c')](this[_0x8d73('0xe')]);clearAgentBooked(this[_0x8d73('0xf')]);clearVoiceQueues(this[_0x8d73('0x12')]);clearCampaigns(this[_0x8d73('0x14')]);};VoiceQueueReport['prototype']['clearQueueReport']=function(_0x280927){var _0x52e359=this;if(!_[_0x8d73('0x3d')](_0x280927)){for(var _0x1d0725 in _0x280927){if(_0x280927[_0x8d73('0x2a')](_0x1d0725)){_0x52e359[_0x8d73('0x3e')](_0x280927[_0x1d0725]);delete _0x280927[_0x1d0725];}}}};function loggerCatch(_0x41b6fd){return function(_0x40cb8c){logger[_0x8d73('0x39')](_0x41b6fd,util[_0x8d73('0x3f')](_0x40cb8c,{'showHidden':![],'depth':null}));};}VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x40')]=function(_0x34b5fe,_0x1b534b,_0x1c5864){io['to'](_0x34b5fe)[_0x8d73('0x40')](_0x1b534b,_0x1c5864);};VoiceQueueReport[_0x8d73('0xa')]['emitVoiceQueueChannelSave']=function(_0x435930){this[_0x8d73('0x40')](util[_0x8d73('0x41')](_0x8d73('0x42'),_0x435930[_0x8d73('0x43')]),_0x8d73('0x44'),_0x435930);};VoiceQueueReport['prototype'][_0x8d73('0x3e')]=function(_0x42c502){logger[_0x8d73('0x45')](_0x8d73('0x46'),JSON['stringify'](_0x42c502));this['emit'](util[_0x8d73('0x41')](_0x8d73('0x42'),_0x42c502[_0x8d73('0x43')]),_0x8d73('0x47'),_0x42c502);};VoiceQueueReport[_0x8d73('0xa')]['emitVoiceQueueSummary']=function(_0x37df5a){if(_0x37df5a[_0x8d73('0x48')]==='inbound'){var _0x5f5d2a={'id':_0x37df5a['id'],'name':_0x37df5a[_0x8d73('0x43')],'strategy':_0x37df5a[_0x8d73('0x49')],'answered':_0x37df5a['answered'],'available':_0x37df5a[_0x8d73('0x4a')],'loggedIn':_0x37df5a[_0x8d73('0x4b')],'pTalking':_0x37df5a[_0x8d73('0x2d')],'sumBillable':_0x37df5a[_0x8d73('0x4c')],'sumDuration':_0x37df5a[_0x8d73('0x4d')],'sumHoldTime':_0x37df5a[_0x8d73('0x4e')]||0x0,'talking':_0x37df5a[_0x8d73('0x2c')],'total':_0x37df5a[_0x8d73('0x4f')],'type':_0x37df5a[_0x8d73('0x48')],'unmanaged':_0x37df5a[_0x8d73('0x50')],'abandoned':_0x37df5a[_0x8d73('0x51')],'waiting':_0x37df5a[_0x8d73('0x2e')]};if(_0x37df5a[_0x8d73('0x52')]){_0x5f5d2a[_0x8d73('0x52')]={'id':_0x37df5a[_0x8d73('0x52')]['id'],'name':_0x37df5a[_0x8d73('0x52')][_0x8d73('0x43')],'active':_0x37df5a['Trunk'][_0x8d73('0x53')],'callerid':_0x37df5a[_0x8d73('0x52')][_0x8d73('0x54')]};}if(_0x37df5a[_0x8d73('0x55')]){_0x5f5d2a['Interval']={'id':_0x37df5a['Interval']['id'],'name':_0x37df5a[_0x8d73('0x55')][_0x8d73('0x43')]};}var _0x5e43f7=md5(JSON[_0x8d73('0x56')](_0x5f5d2a));if(_0x37df5a[_0x8d73('0x3')]!==_0x5e43f7){_0x37df5a[_0x8d73('0x3')]=_0x5e43f7;this['emit'](util[_0x8d73('0x41')](_0x8d73('0x42'),_0x5f5d2a[_0x8d73('0x43')]),_0x8d73('0x57'),_0x5f5d2a);}}};VoiceQueueReport['prototype'][_0x8d73('0x58')]=function(_0x3c802d){return _0x3c802d!==null&&!_[_0x8d73('0x59')](_0x3c802d);};VoiceQueueReport['prototype'][_0x8d73('0x5a')]=function(){var _0x227104=this;setInterval(function(){_0x227104[_0x8d73('0x31')]();ami[_0x8d73('0x34')]({'action':_0x8d73('0x5b')})[_0x8d73('0x36')](loggerCatch(_0x8d73('0x5c')));},0x2710);};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x29')]=function(){var _0x271821=this;setInterval(function(){if(_0x271821[_0x8d73('0x13')]){return ami[_0x8d73('0x34')]({'action':_0x8d73('0x16')})[_0x8d73('0x5d')](function(_0x479081){_0x271821['flagQueueSummary']=![];})[_0x8d73('0x36')](loggerCatch(_0x8d73('0x5e')));}},0x3e8);};VoiceQueueReport['prototype']['syncQueueSummary']=function(_0x14707c){try{if(this['isNotNull'](_0x14707c)&&this[_0x8d73('0x58')](_0x14707c[_0x8d73('0x5f')])){if(this['voiceQueues'][_0x14707c[_0x8d73('0x5f')]]){var _0x463a32=_[_0x8d73('0x60')](this[_0x8d73('0x10')],_0x8d73('0x5f'))[_0x14707c['queue']]||0x0;var _0x5ebb0b=_0x463a32-_0x14707c[_0x8d73('0x61')];if(this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]][_0x8d73('0x2e')]!==_[_0x8d73('0x62')](_0x14707c[_0x8d73('0x61')])||this[_0x8d73('0x12')][_0x14707c['queue']][_0x8d73('0x4b')]!==_[_0x8d73('0x62')](_0x14707c[_0x8d73('0x63')])||this[_0x8d73('0x12')][_0x14707c['queue']][_0x8d73('0x4a')]!==_[_0x8d73('0x62')](_0x14707c['available'])||this[_0x8d73('0x12')][_0x14707c['queue']][_0x8d73('0x2c')]!==_0x5ebb0b){this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]][_0x8d73('0x2e')]=_['toNumber'](_0x14707c[_0x8d73('0x61')]);this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]][_0x8d73('0x4b')]=_[_0x8d73('0x62')](_0x14707c['loggedin']);this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]][_0x8d73('0x4a')]=_[_0x8d73('0x62')](_0x14707c['available']);this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]]['talking']=_0x5ebb0b>0x0?_0x5ebb0b:0x0;this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]]['talking']=this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]][_0x8d73('0x2c')]>_['toNumber'](_0x14707c[_0x8d73('0x63')])?_[_0x8d73('0x62')](_0x14707c[_0x8d73('0x63')]):this[_0x8d73('0x12')][_0x14707c[_0x8d73('0x5f')]][_0x8d73('0x2c')];this['emitVoiceQueueSummary'](this[_0x8d73('0x12')][_0x14707c['queue']]);}ami['emit'](_0x8d73('0x64'),this['voiceQueues'][_0x14707c['queue']]);}}}catch(_0x35b149){logger[_0x8d73('0x39')](_0x8d73('0x65'),util[_0x8d73('0x3f')](_0x35b149,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')]['syncQueueSummaryComplete']=function(_0x5105db){this[_0x8d73('0x13')]=!![];};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x66')]=function(_0x387306){};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x1a')]=function(_0x59a599){try{if(this['isNotNull'](_0x59a599)){if(_[_0x8d73('0x59')](this[_0x8d73('0xe')][_0x59a599[_0x8d73('0x67')]])){this['queueReports'][_0x59a599[_0x8d73('0x67')]]=[];this['channels'][_0x59a599[_0x8d73('0x67')]]={};}var _0x1a9c87=new QueueReport();_0x1a9c87[_0x8d73('0x43')]=_0x59a599[_0x8d73('0x5f')];_0x1a9c87['type']=this[_0x8d73('0x12')][_0x1a9c87[_0x8d73('0x43')]]&&this[_0x8d73('0x12')][_0x1a9c87[_0x8d73('0x43')]][_0x8d73('0x48')]?this[_0x8d73('0x12')][_0x1a9c87[_0x8d73('0x43')]][_0x8d73('0x48')]||'inbound':_0x8d73('0x68');_0x1a9c87['queue']=_0x59a599[_0x8d73('0x5f')];_0x1a9c87[_0x8d73('0x69')]=moment()[_0x8d73('0x41')](_0x8d73('0x6a'));_0x1a9c87[_0x8d73('0x6b')]=_0x59a599[_0x8d73('0x6b')];_0x1a9c87['count']=_0x59a599['count'];_['merge'](_0x1a9c87,_[_0x8d73('0x6c')](_0x59a599,_['keys'](_0x1a9c87)));this[_0x8d73('0xe')][_0x59a599[_0x8d73('0x67')]]['push'](_0x1a9c87);this[_0x8d73('0x10')][_0x59a599[_0x8d73('0x67')]]=_0x1a9c87;this[_0x8d73('0x6d')](_0x1a9c87);}}catch(_0x5afeac){logger['error']('[syncQueueCallerJoin][VoiceQueueReport]',util['inspect'](_0x5afeac,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x1b')]=function(_0x593748){try{if(this[_0x8d73('0x58')](_0x593748)){if(this['queueReports'][_0x593748[_0x8d73('0x67')]]){var _0x3adda3=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x593748[_0x8d73('0x67')]]);_0x3adda3[_0x8d73('0x6f')]=![];_0x3adda3[_0x8d73('0x70')]=null;_0x3adda3['holdtime']=_0x593748['holdtime'];_0x3adda3['originalposition']=_0x593748[_0x8d73('0x71')];_0x3adda3[_0x8d73('0x72')]=!![];_0x3adda3[_0x8d73('0x73')]=moment()['format']('YYYY-MM-DD\x20HH:mm:ss');_0x3adda3[_0x8d73('0x74')]=_0x8d73('0x75');_0x3adda3[_0x8d73('0x76')]=null;this['channels'][_0x593748[_0x8d73('0x67')]]=_0x3adda3;this['emitVoiceQueueChannelRemove'](_0x3adda3);}}}catch(_0x53d629){logger[_0x8d73('0x39')](_0x8d73('0x77'),util[_0x8d73('0x3f')](_0x53d629,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x1c')]=function(_0x55dbfa){try{if(this[_0x8d73('0x58')](_0x55dbfa)){if(this[_0x8d73('0xe')][_0x55dbfa[_0x8d73('0x67')]]){var _0x4a8195=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x55dbfa['uniqueid']]);_0x4a8195[_0x8d73('0x78')]=moment()[_0x8d73('0x41')](_0x8d73('0x6a'));_0x4a8195[_0x8d73('0x79')]=_0x55dbfa[_0x8d73('0x79')];_0x4a8195[_0x8d73('0x7a')]=_0x55dbfa[_0x8d73('0x7a')];this[_0x8d73('0x10')][_0x55dbfa[_0x8d73('0x67')]]=_0x4a8195;this[_0x8d73('0x6d')](_0x4a8195);}}}catch(_0x255ee8){logger[_0x8d73('0x39')](_0x8d73('0x7b'),util[_0x8d73('0x3f')](_0x255ee8,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')]['syncAgentConnect']=function(_0x2d874f){try{if(this[_0x8d73('0x58')](_0x2d874f)){if(this['queueReports'][_0x2d874f[_0x8d73('0x67')]]){var _0x461830=_['last'](this['queueReports'][_0x2d874f['uniqueid']]);_0x461830[_0x8d73('0x6f')]=!![];_0x461830['queuecallerexitreason']='COMPLETEDBYAGENT';}}}catch(_0x24c066){logger[_0x8d73('0x39')](_0x8d73('0x7c'),util[_0x8d73('0x3f')](_0x24c066,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x1d')]=function(_0x2af279){try{if(this[_0x8d73('0x58')](_0x2af279)){if(this[_0x8d73('0xe')][_0x2af279[_0x8d73('0x67')]]){var _0x42f79f=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x2af279[_0x8d73('0x67')]]);_0x42f79f[_0x8d73('0x72')]=![];_0x42f79f['queuecallerabandonAt']=null;_0x42f79f['assigned']=!![];_0x42f79f[_0x8d73('0x76')]=_0x2af279[_0x8d73('0x7d')];_0x42f79f['holdtime']=_0x2af279[_0x8d73('0x7e')];_0x42f79f[_0x8d73('0x6f')]=!![];_0x42f79f[_0x8d73('0x7f')]=![];_0x42f79f[_0x8d73('0x80')]=null;if(!_0x42f79f[_0x8d73('0x81')]){if(_0x2af279[_0x8d73('0x82')]=='transfer'){_0x42f79f[_0x8d73('0x74')]=_0x8d73('0x83');}else{if(_[_0x8d73('0x84')](_0x2af279['channel'][_0x8d73('0x85')](),_0x8d73('0x86'))){if(this[_0x8d73('0xe')][_0x2af279['linkedid']]){var _0x25477d=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x2af279['linkedid']]);_0x25477d[_0x8d73('0x6f')]=![];_0x25477d[_0x8d73('0x7f')]=!![];_0x25477d[_0x8d73('0x80')]=moment(_0x42f79f[_0x8d73('0x69')])['add'](_0x2af279[_0x8d73('0x7e')],_0x8d73('0x87'))[_0x8d73('0x41')](_0x8d73('0x6a'));_0x25477d[_0x8d73('0x74')]=_0x8d73('0x88');_0x25477d[_0x8d73('0x81')]=!![];_0x25477d[_0x8d73('0x89')]=_0x8d73('0x8a');_0x25477d['transferexten']=_0x2af279[_0x8d73('0x8b')];_0x25477d[_0x8d73('0x8c')]=_0x2af279[_0x8d73('0x67')];var _0x11ef6c=this['queueReports'][_0x2af279['linkedid']];this[_0x8d73('0xe')][_0x2af279['linkedid']]=this[_0x8d73('0xe')][_0x2af279[_0x8d73('0x67')]];this[_0x8d73('0xe')][_0x2af279[_0x8d73('0x67')]]=_0x11ef6c;}}else{_0x42f79f[_0x8d73('0x74')]=_0x8d73('0x8d')+_0x2af279[_0x8d73('0x82')][_0x8d73('0x8e')]();}}}this[_0x8d73('0x10')][_0x2af279[_0x8d73('0x67')]]=_0x42f79f;this['emitVoiceQueueChannelRemove'](_0x42f79f);}}}catch(_0x32d55b){logger[_0x8d73('0x39')](_0x8d73('0x8f'),util['inspect'](_0x32d55b,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x90')]=function(_0x12a7fb){try{if(this[_0x8d73('0x58')](_0x12a7fb)){this[_0x8d73('0x91')](_0x12a7fb[_0x8d73('0x67')],_['keys'](_0x12a7fb[_0x8d73('0x92')])[0x0],_0x12a7fb['value']);if(this[_0x8d73('0xe')][_0x12a7fb[_0x8d73('0x67')]]){var _0x299b4d=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x12a7fb[_0x8d73('0x67')]]);if(_0x299b4d){if(this[_0x8d73('0x58')](_0x12a7fb[_0x8d73('0x92')])&&this['isNotNull'](_0x12a7fb[_0x8d73('0x92')][_0x8d73('0x93')])){switch(_0x12a7fb[_0x8d73('0x94')]){case _0x8d73('0x95'):_0x299b4d[_0x8d73('0x7f')]=![];_0x299b4d['queuecallerexitAt']=null;break;case'TIMEOUT':_0x299b4d[_0x8d73('0x96')]=_0x8d73('0x97');ami[_0x8d73('0x40')]('custom:timeout',_0x299b4d);break;default:_0x299b4d[_0x8d73('0x7f')]=!![];_0x299b4d['queuecallerexitAt']=moment()[_0x8d73('0x41')](_0x8d73('0x6a'));_0x299b4d['queuecallerleaveAt']=moment()['format'](_0x8d73('0x6a'));}_0x299b4d[_0x8d73('0x72')]=![];_0x299b4d[_0x8d73('0x73')]=null;_0x299b4d[_0x8d73('0x74')]=_0x12a7fb[_0x8d73('0x94')];this[_0x8d73('0x10')][_0x12a7fb[_0x8d73('0x67')]]=_0x299b4d;this[_0x8d73('0x3e')](_0x299b4d);}else if(this['isNotNull'](_0x12a7fb[_0x8d73('0x92')])&&this[_0x8d73('0x58')](_0x12a7fb['variable'][_0x8d73('0x98')])){if(!_0x299b4d[_0x8d73('0x72')]){_0x299b4d[_0x8d73('0x7f')]=!![];_0x299b4d[_0x8d73('0x80')]=moment()[_0x8d73('0x41')]('YYYY-MM-DD\x20HH:mm:ss');_0x299b4d['queuecallerexitreason']=_0x8d73('0x99');_0x299b4d[_0x8d73('0x78')]=moment()[_0x8d73('0x41')](_0x8d73('0x6a'));this[_0x8d73('0x10')][_0x12a7fb['uniqueid']]=_0x299b4d;}}_0x299b4d['variables']=this[_0x8d73('0x15')][_0x12a7fb[_0x8d73('0x67')]];}}}}catch(_0x1fa8ab){logger['error'](_0x8d73('0x9a'),util[_0x8d73('0x3f')](_0x1fa8ab,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x91')]=function(_0x4c7e9a,_0x24a7ce,_0x350842){var _0x1684ae=['rtpaudioqos','rtpaudioqosbridged',_0x8d73('0x9b'),'rtpaudioqosjitterbridged','rtpaudioqosloss',_0x8d73('0x9c'),'rtpaudioqosrtt',_0x8d73('0x9d'),_0x8d73('0x9e'),_0x8d73('0x9f'),_0x8d73('0xa0'),_0x8d73('0xa1'),_0x8d73('0xa2'),_0x8d73('0xa3'),_0x8d73('0xa4'),_0x8d73('0xa5'),_0x8d73('0x7d'),_0x8d73('0xa6'),'memberrealtime'];if(!_['isNil'](_0x24a7ce)&&!_['includes'](_0x1684ae,_0x24a7ce)){if(_['isUndefined'](this['variables'][_0x4c7e9a])){this[_0x8d73('0x15')][_0x4c7e9a]={};}this['variables'][_0x4c7e9a][_0x24a7ce]=_0x350842;}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x21')]=function(_0x4b7463){try{if(this[_0x8d73('0x58')](_0x4b7463)){if(this[_0x8d73('0xe')][_0x4b7463[_0x8d73('0x67')]]){for(var _0x493903=0x0,_0x1eb4e3={};_0x493903<this[_0x8d73('0xe')][_0x4b7463['uniqueid']][_0x8d73('0xa7')];_0x493903+=0x1){_0x1eb4e3=this[_0x8d73('0xe')][_0x4b7463[_0x8d73('0x67')]][_0x493903];if(this[_0x8d73('0x12')][_0x1eb4e3[_0x8d73('0x5f')]]){if(_0x1eb4e3[_0x8d73('0x7f')]){this[_0x8d73('0x12')][_0x1eb4e3[_0x8d73('0x5f')]][_0x8d73('0x50')]+=0x1;}if(_0x1eb4e3[_0x8d73('0x72')]){this[_0x8d73('0x12')][_0x1eb4e3[_0x8d73('0x5f')]][_0x8d73('0x51')]+=0x1;}this[_0x8d73('0x12')][_0x1eb4e3['queue']][_0x8d73('0x4e')]+=moment(_0x1eb4e3[_0x8d73('0x78')])[_0x8d73('0xa8')](_0x1eb4e3[_0x8d73('0x69')],_0x8d73('0x87'))||0x0;if(_0x493903===this[_0x8d73('0xe')][_0x4b7463['uniqueid']][_0x8d73('0xa7')]-0x1){this[_0x8d73('0x12')][_0x1eb4e3[_0x8d73('0x5f')]]['sumDuration']+=moment()[_0x8d73('0xa9')](0x0)['diff'](_0x1eb4e3['queuecallerjoinAt'],_0x8d73('0x87'));this['voiceQueues'][_0x1eb4e3[_0x8d73('0x5f')]][_0x8d73('0x4f')]+=0x1;if(_0x1eb4e3[_0x8d73('0x6f')]){this[_0x8d73('0x12')][_0x1eb4e3[_0x8d73('0x5f')]][_0x8d73('0xaa')]+=0x1;this[_0x8d73('0x12')][_0x1eb4e3['queue']][_0x8d73('0x4c')]+=moment()['milliseconds'](0x0)[_0x8d73('0xa8')](_0x1eb4e3[_0x8d73('0x78')],_0x8d73('0x87'));_0x1eb4e3[_0x8d73('0x70')]=moment()[_0x8d73('0x41')](_0x8d73('0x6a'));_0x1eb4e3[_0x8d73('0x7f')]=![];_0x1eb4e3[_0x8d73('0x80')]=null;}if(_0x1eb4e3[_0x8d73('0x7f')]){_0x1eb4e3[_0x8d73('0x96')]=_0x8d73('0x50');ami[_0x8d73('0x40')](_0x8d73('0xab'),_0x1eb4e3);}if(_0x1eb4e3[_0x8d73('0x72')]){_0x1eb4e3[_0x8d73('0x96')]=_0x8d73('0x51');ami[_0x8d73('0x40')](_0x8d73('0xac'),_0x1eb4e3);}}else{this[_0x8d73('0x12')][_0x1eb4e3[_0x8d73('0x5f')]][_0x8d73('0x4d')]+=this['voiceQueues'][_0x1eb4e3['queue']][_0x8d73('0x4e')];}this[_0x8d73('0x10')][_0x4b7463[_0x8d73('0x67')]]=_0x1eb4e3;this[_0x8d73('0x3e')](_0x1eb4e3);this[_0x8d73('0xad')](this[_0x8d73('0x12')][_0x1eb4e3['queue']]);}}ami[_0x8d73('0x40')]('custom:voiceQueueReport',this[_0x8d73('0xe')][_0x4b7463[_0x8d73('0x67')]]);delete this[_0x8d73('0xe')][_0x4b7463['uniqueid']];delete this[_0x8d73('0x10')][_0x4b7463[_0x8d73('0x67')]];}if(this[_0x8d73('0x15')][_0x4b7463[_0x8d73('0x67')]]){delete this[_0x8d73('0x15')][_0x4b7463[_0x8d73('0x67')]];}}}catch(_0x1e8cab){logger[_0x8d73('0x39')]('[syncHangup][VoiceQueueReport]',util['inspect'](_0x1e8cab,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x8d73('0xae')]=function(_0x2e8891){try{if(this[_0x8d73('0x58')](_0x2e8891)){var _0x1ce1f8;if(this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xaf')]]){_0x1ce1f8=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xaf')]]);_0x1ce1f8[_0x8d73('0xb0')]=_0x2e8891[_0x8d73('0xb1')];_0x1ce1f8['transferuniqueid']=_0x2e8891[_0x8d73('0xb2')];_0x1ce1f8['queuecallerexitreason']=_0x8d73('0xb3');_0x1ce1f8[_0x8d73('0x81')]=!![];_0x1ce1f8[_0x8d73('0x89')]='ATTENDED';if(this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xb2')]]){var _0x51ad5e=this['queueReports'][_0x2e8891['secondtransfereruniqueid']];this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xb2')]]=this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xaf')]];this[_0x8d73('0xe')][_0x2e8891['transfereeuniqueid']]=_0x51ad5e;var _0x5c6758=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xaf')]]);_0x5c6758[_0x8d73('0x32')]=!![];}}else if(this['queueReports'][_0x2e8891['transfertargetuniqueid']]){_0x1ce1f8=_['last'](this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xb4')]]);_0x1ce1f8[_0x8d73('0xb0')]=_0x2e8891['origtransfererexten'];_0x1ce1f8[_0x8d73('0x8c')]=_0x2e8891[_0x8d73('0xb5')];_0x1ce1f8[_0x8d73('0x74')]=_0x8d73('0xb3');_0x1ce1f8[_0x8d73('0x81')]=!![];_0x1ce1f8[_0x8d73('0x89')]='ATTENDED';if(this[_0x8d73('0xe')][_0x2e8891['origtransfereruniqueid']]){var _0x51ad5e=this[_0x8d73('0xe')][_0x2e8891['origtransfereruniqueid']];this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xb5')]]=this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xb4')]];this[_0x8d73('0xe')][_0x2e8891[_0x8d73('0xb4')]]=_0x51ad5e;var _0x5c6758=_[_0x8d73('0x6e')](this['queueReports'][_0x2e8891[_0x8d73('0xb4')]]);_0x5c6758[_0x8d73('0x32')]=!![];}}}}catch(_0x594c76){logger[_0x8d73('0x39')](_0x8d73('0xb6'),util[_0x8d73('0x3f')](_0x594c76,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x8d73('0x28')]=function(_0x375012){try{if(this[_0x8d73('0x58')](_0x375012)){if(this[_0x8d73('0xe')][_0x375012['transfereeuniqueid']]){var _0x495042=_['last'](this[_0x8d73('0xe')][_0x375012[_0x8d73('0xaf')]]);_0x495042[_0x8d73('0x74')]=_0x8d73('0xb7');_0x495042[_0x8d73('0x81')]=!![];_0x495042[_0x8d73('0x89')]=_0x8d73('0xb8');_0x495042[_0x8d73('0xb0')]=_0x375012[_0x8d73('0xb9')];_0x495042[_0x8d73('0x8c')]=_0x375012[_0x8d73('0xaf')];this['syncHangup']({'event':_0x8d73('0xba'),'uniqueid':_0x375012[_0x8d73('0xaf')],'context':_0x375012['context'],'channel':_0x375012[_0x8d73('0xbb')]});}}}catch(_0x1fa3c0){logger[_0x8d73('0x39')](_0x8d73('0xbc'),util[_0x8d73('0x3f')](_0x1fa3c0,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x8d73('0xa')][_0x8d73('0x24')]=function(_0x3c7038){try{if(this[_0x8d73('0x58')](_0x3c7038)){if(this[_0x8d73('0xe')][_0x3c7038[_0x8d73('0x67')]]){var _0x3f2227=_[_0x8d73('0x6e')](this[_0x8d73('0xe')][_0x3c7038[_0x8d73('0x67')]]);if(!_['isNil'](_0x3f2227['queuecallerleaveAt'])){_0x3f2227[_0x8d73('0xbd')]=moment()[_0x8d73('0x41')](_0x8d73('0x6a'));}}}}catch(_0x367b91){logger[_0x8d73('0x39')](_0x8d73('0xbe'),util[_0x8d73('0x3f')](_0x367b91,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x8d73('0xbf')]=function(_0x1ead7d){try{if(this[_0x8d73('0x58')](_0x1ead7d)){if(this[_0x8d73('0xe')][_0x1ead7d['uniqueid']]){var _0x1e4415=_['last'](this['queueReports'][_0x1ead7d[_0x8d73('0x67')]]);if(!_['isNil'](_0x1e4415[_0x8d73('0xbd')])){_0x1e4415[_0x8d73('0xc0')]+=moment()[_0x8d73('0xa9')](0x0)[_0x8d73('0xa8')](_0x1e4415['mohstarttime'],_0x8d73('0x87'));delete _0x1e4415[_0x8d73('0xbd')];}}}}catch(_0x43ea1f){logger[_0x8d73('0x39')](_0x8d73('0xc1'),util[_0x8d73('0x3f')](_0x43ea1f,{'showHidden':![],'depth':null}));}};module[_0x8d73('0xc2')]=VoiceQueueReport;