Built motion from commit (unavailable).|2.5.4
[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 _0x0231=['[syncQueueCallerLeave][VoiceQueueReport]','syncAgentConnect','COMPLETEDBYAGENT','[syncAgentConnect][VoiceQueueReport]','queuecallerexit','transfer','reason','toLowerCase','local/','linkedid','queuecallerexitAt','FORWARDTRANSFER','destexten','transferuniqueid','COMPLETEDBY','toUpperCase','emitVoiceQueueChannelRemove','syncVarSet','addVariable','keys','variable','value','CONTINUE','TIMEOUT','lastevent','custom:timeout','queueposition','EXITWITHKEY','rtpaudioqos','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrttbridged','sipcallid','sipuri','bridgepvtcallid','membercalls','memberdynamic','memberlastcall','membername','memberrealtime','isNil','includes','length','diff','seconds','milliseconds','custom:queuecallerunmanaged','custom:queuecallerabandon','custom:voiceQueueReport','[syncHangup][VoiceQueueReport]','transfereeuniqueid','transferexten','secondtransfereruniqueid','transfertargetuniqueid','ATTENDEDTRANSFER','ATTENDED','origtransfereruniqueid','BLINDTRANSFER','transfertype','BLIND','extension','BlindTransfer','transfererchannel','[syncBlindTransfer][VoiceQueueReport]','mohstarttime','[syncMusicOnHoldStart][VoiceQueueReport]','mohtime','[syncMusicOnHoldStop][VoiceQueueReport]','moment','bluebird','util','../../../config/environment','../../../config/logger','../model/queueReport','redis','localhost','prototype','tail','sequence','agents','queueChannels','campaigns','variables','queuesummary','syncQueueSummary','bind','queuecallerjoin','syncQueueCallerJoin','syncQueueCallerAbandon','queuecallerleave','syncQueueCallerLeave','agentcomplete','syncAgentComplete','varset','hangup','syncHangup','fullybooted','musiconholdstart','syncMusicOnHoldStart','musiconholdstop','syncMusicOnHoldStop','attendedtransfer','syncAttendedTransfer','blindtransfer','syncBlindTransfer','loopQueueShow','isEmpty','hasOwnProperty','originated','talking','pTalking','queueStatusComplete','clearZombieChannels','channels','switch','enqueue','channel','catch','message','error','queueReports','[FullyBooted]\x20clear\x20realtime','clearQueueReport','voiceQueues','inspect','emit','emitVoiceQueueChannelSave','format','voice:queue:%s','name','voice_queue_channel:save','info','stringify','emitVoiceQueueSummary','type','answered','loggedIn','sumBillable','sumDuration','sumHoldTime','total','unmanaged','abandoned','waiting','Trunk','active','Interval','md5','voice_queue:save','isNotNull','isUndefined','Action','[queues]','loopQueueSummary','flagQueueSummary','then','[queuesummary]','queue','countBy','callers','toNumber','loggedin','available','custom:queuesummary','[syncQueueSummary][VoiceQueueReport]','syncQueueSummaryComplete','syncNewExten','uniqueid','inbound','queuecallerjoinAt','YYYY-MM-DD\x20HH:mm:ss','position','count','merge','pick','[syncQueueCallerJoin][VoiceQueueReport]','last','queuecallercomplete','queuecallercompleteAt','holdtime','originalposition','queuecallerabandon','queuecallerabandonAt','queuecallerexitreason','ABANDONED','lastAssignedTo','[syncQueueCallerAbandon][VoiceQueueReport]','queuecallerleaveAt','connectedlinenum','connectedlinename'];(function(_0x478a06,_0x5c4d68){var _0x1e6462=function(_0x53496c){while(--_0x53496c){_0x478a06['push'](_0x478a06['shift']());}};_0x1e6462(++_0x5c4d68);}(_0x0231,0x1c6));var _0x1023=function(_0x1f9f37,_0x18776e){_0x1f9f37=_0x1f9f37-0x0;var _0x21c080=_0x0231[_0x1f9f37];return _0x21c080;};'use strict';var _=require('lodash');var moment=require(_0x1023('0x0'));var BPromise=require(_0x1023('0x1'));var util=require(_0x1023('0x2'));var md5=require('md5');var Redis=require('ioredis');var config=require(_0x1023('0x3'));var logger=require(_0x1023('0x4'))('ami');var ami=require('../ami');var QueueReport=require(_0x1023('0x5'));config[_0x1023('0x6')]=_['defaults'](config[_0x1023('0x6')],{'host':_0x1023('0x7'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0x1023('0x6')]));var Sequence=function(){};Sequence[_0x1023('0x8')]['enqueue']=function(_0x460035){this['tail']=this['tail']?this[_0x1023('0x9')]['finally'](_0x460035):_0x460035();};function VoiceQueueReport(_0x50afa9){this[_0x1023('0xa')]=new Sequence();this['queueReports']={};this[_0x1023('0xb')]=_0x50afa9['agents'];this['channels']=_0x50afa9[_0x1023('0xc')];this['voiceQueues']=_0x50afa9['voiceQueues'];this['flagQueueSummary']=!![];this['campaigns']=_0x50afa9[_0x1023('0xd')];this[_0x1023('0xe')]={};ami['on'](_0x1023('0xf'),this[_0x1023('0x10')][_0x1023('0x11')](this));ami['on']('queuesummarycomplete',this['syncQueueSummaryComplete'][_0x1023('0x11')](this));ami['on'](_0x1023('0x12'),this[_0x1023('0x13')]['bind'](this));ami['on']('queuecallerabandon',this[_0x1023('0x14')]['bind'](this));ami['on'](_0x1023('0x15'),this[_0x1023('0x16')][_0x1023('0x11')](this));ami['on'](_0x1023('0x17'),this[_0x1023('0x18')][_0x1023('0x11')](this));ami['on']('agentconnect',this['syncAgentConnect'][_0x1023('0x11')](this));ami['on'](_0x1023('0x19'),this['syncVarSet']['bind'](this));ami['on'](_0x1023('0x1a'),this[_0x1023('0x1b')][_0x1023('0x11')](this));ami['on'](_0x1023('0x1c'),this['syncFullyBooted'][_0x1023('0x11')](this));ami['on'](_0x1023('0x1d'),this[_0x1023('0x1e')]['bind'](this));ami['on'](_0x1023('0x1f'),this[_0x1023('0x20')][_0x1023('0x11')](this));ami['on'](_0x1023('0x21'),this[_0x1023('0x22')][_0x1023('0x11')](this));ami['on'](_0x1023('0x23'),this[_0x1023('0x24')][_0x1023('0x11')](this));this['loopQueueSummary']();this[_0x1023('0x25')]();}function isNotNull(_0x302f7f){return _0x302f7f!==null&&!_['isUndefined'](_0x302f7f);}function clearChannels(_0x4b94da){if(!_[_0x1023('0x26')](_0x4b94da)){for(var _0x22b1c1 in _0x4b94da){if(_0x4b94da[_0x1023('0x27')](_0x22b1c1)){delete _0x4b94da[_0x22b1c1];}}}}function clearCampaigns(_0xec19f3){if(!_[_0x1023('0x26')](_0xec19f3)){for(var _0x86f4a1 in _0xec19f3){if(_0xec19f3['hasOwnProperty'](_0x86f4a1)){_0xec19f3[_0x86f4a1][_0x1023('0x28')]=0x0;}}}}function clearVoiceQueues(_0x1770c3){if(!_[_0x1023('0x26')](_0x1770c3)){for(var _0x1367cb in _0x1770c3){if(_0x1770c3[_0x1023('0x27')](_0x1367cb)){_0x1770c3[_0x1367cb][_0x1023('0x28')]=0x0;_0x1770c3[_0x1367cb][_0x1023('0x29')]=0x0;_0x1770c3[_0x1367cb][_0x1023('0x2a')]=0x0;_0x1770c3[_0x1367cb]['waiting']=0x0;_0x1770c3[_0x1367cb][_0x1023('0x2b')]=!![];}}}}function clearAgentBooked(_0x328b84){if(!_[_0x1023('0x26')](_0x328b84)){for(var _0x576dee in _0x328b84){if(_0x328b84[_0x1023('0x27')](_0x576dee)){_0x328b84[_0x576dee]['unlockRR']=!![];}}}}VoiceQueueReport['prototype'][_0x1023('0x2c')]=function(){var _0x2ca7fa=this;for(var _0x180a2d in this['channels']){if(this['channels'][_0x1023('0x27')](_0x180a2d)&&!this[_0x1023('0x2d')][_0x180a2d][_0x1023('0x2e')]){this[_0x1023('0xa')][_0x1023('0x2f')](function(){if(!_['isNil'](_0x2ca7fa[_0x1023('0x2d')][_0x180a2d])){return ami['Action']({'action':'status','channel':_0x2ca7fa[_0x1023('0x2d')][_0x180a2d][_0x1023('0x30')]})[_0x1023('0x31')](function(_0x5a9def){if(_0x5a9def[_0x1023('0x32')]==='No\x20such\x20channel'){setTimeout(function(){if(_0x2ca7fa[_0x1023('0x2d')][_0x180a2d]){delete _0x2ca7fa[_0x1023('0x2d')][_0x180a2d];logger[_0x1023('0x33')]('[voiceQueueReport][checkChannel]',_0x180a2d);}if(_0x2ca7fa[_0x1023('0x34')][_0x180a2d]){delete _0x2ca7fa[_0x1023('0x34')][_0x180a2d];logger[_0x1023('0x33')]('[voiceQueueReport][checkQueueReport]',_0x180a2d);}if(_0x2ca7fa[_0x1023('0xe')][_0x180a2d]){delete _0x2ca7fa[_0x1023('0xe')][_0x180a2d];logger['error']('[voiceQueueReport][checkVariables]',_0x180a2d);}},0x1f40);}});}});}}};VoiceQueueReport['prototype']['syncFullyBooted']=function(){logger[_0x1023('0x33')](_0x1023('0x35'));clearChannels(this[_0x1023('0x2d')]);this[_0x1023('0x36')](this['queueReports']);clearAgentBooked(this['agents']);clearVoiceQueues(this[_0x1023('0x37')]);clearCampaigns(this[_0x1023('0xd')]);};VoiceQueueReport['prototype']['clearQueueReport']=function(_0x404ac7){var _0x1d9cae=this;if(!_[_0x1023('0x26')](_0x404ac7)){for(var _0x15eae1 in _0x404ac7){if(_0x404ac7[_0x1023('0x27')](_0x15eae1)){_0x1d9cae['emitVoiceQueueChannelRemove'](_0x404ac7[_0x15eae1]);delete _0x404ac7[_0x15eae1];}}}};function loggerCatch(_0x5918ba){return function(_0x25322d){logger[_0x1023('0x33')](_0x5918ba,util[_0x1023('0x38')](_0x25322d,{'showHidden':![],'depth':null}));};}VoiceQueueReport['prototype'][_0x1023('0x39')]=function(_0x26fe68,_0x3125e3,_0x15be13){io['to'](_0x26fe68)['emit'](_0x3125e3,_0x15be13);};VoiceQueueReport['prototype'][_0x1023('0x3a')]=function(_0x5197ce){this['emit'](util[_0x1023('0x3b')](_0x1023('0x3c'),_0x5197ce[_0x1023('0x3d')]),_0x1023('0x3e'),_0x5197ce);};VoiceQueueReport[_0x1023('0x8')]['emitVoiceQueueChannelRemove']=function(_0x502c42){logger[_0x1023('0x3f')]('[DEBUG]\x20Emit\x20voice_queue_channel:remove\x20event',JSON[_0x1023('0x40')](_0x502c42));this[_0x1023('0x39')](util['format'](_0x1023('0x3c'),_0x502c42[_0x1023('0x3d')]),'voice_queue_channel:remove',_0x502c42);};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x41')]=function(_0x5c3998){if(_0x5c3998[_0x1023('0x42')]==='inbound'){var _0x2fdb13={'id':_0x5c3998['id'],'name':_0x5c3998[_0x1023('0x3d')],'strategy':_0x5c3998['strategy'],'answered':_0x5c3998[_0x1023('0x43')],'available':_0x5c3998['available'],'loggedIn':_0x5c3998[_0x1023('0x44')],'pTalking':_0x5c3998['pTalking'],'sumBillable':_0x5c3998[_0x1023('0x45')],'sumDuration':_0x5c3998[_0x1023('0x46')],'sumHoldTime':_0x5c3998[_0x1023('0x47')]||0x0,'talking':_0x5c3998[_0x1023('0x29')],'total':_0x5c3998[_0x1023('0x48')],'type':_0x5c3998[_0x1023('0x42')],'unmanaged':_0x5c3998[_0x1023('0x49')],'abandoned':_0x5c3998[_0x1023('0x4a')],'waiting':_0x5c3998[_0x1023('0x4b')]};if(_0x5c3998[_0x1023('0x4c')]){_0x2fdb13[_0x1023('0x4c')]={'id':_0x5c3998[_0x1023('0x4c')]['id'],'name':_0x5c3998['Trunk'][_0x1023('0x3d')],'active':_0x5c3998[_0x1023('0x4c')][_0x1023('0x4d')],'callerid':_0x5c3998[_0x1023('0x4c')]['callerid']};}if(_0x5c3998[_0x1023('0x4e')]){_0x2fdb13['Interval']={'id':_0x5c3998['Interval']['id'],'name':_0x5c3998[_0x1023('0x4e')][_0x1023('0x3d')]};}var _0x3241fe=md5(JSON[_0x1023('0x40')](_0x2fdb13));if(_0x5c3998[_0x1023('0x4f')]!==_0x3241fe){_0x5c3998['md5']=_0x3241fe;this['emit'](util[_0x1023('0x3b')]('voice:queue:%s',_0x2fdb13[_0x1023('0x3d')]),_0x1023('0x50'),_0x2fdb13);}}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x51')]=function(_0xfd0b88){return _0xfd0b88!==null&&!_[_0x1023('0x52')](_0xfd0b88);};VoiceQueueReport[_0x1023('0x8')]['loopQueueShow']=function(){var _0x10bff0=this;setInterval(function(){_0x10bff0[_0x1023('0x2c')]();ami[_0x1023('0x53')]({'action':'queues'})['catch'](loggerCatch(_0x1023('0x54')));},0x2710);};VoiceQueueReport['prototype'][_0x1023('0x55')]=function(){var _0x2d3874=this;setInterval(function(){if(_0x2d3874[_0x1023('0x56')]){return ami[_0x1023('0x53')]({'action':'queuesummary'})[_0x1023('0x57')](function(_0x35ee6b){_0x2d3874[_0x1023('0x56')]=![];})[_0x1023('0x31')](loggerCatch(_0x1023('0x58')));}},0x3e8);};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x10')]=function(_0x51fbf7){try{if(this[_0x1023('0x51')](_0x51fbf7)&&this[_0x1023('0x51')](_0x51fbf7[_0x1023('0x59')])){if(this[_0x1023('0x37')][_0x51fbf7[_0x1023('0x59')]]){var _0xa2a38a=_[_0x1023('0x5a')](this[_0x1023('0x2d')],_0x1023('0x59'))[_0x51fbf7[_0x1023('0x59')]]||0x0;var _0x411f71=_0xa2a38a-_0x51fbf7[_0x1023('0x5b')];if(this[_0x1023('0x37')][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x4b')]!==_[_0x1023('0x5c')](_0x51fbf7['callers'])||this[_0x1023('0x37')][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x44')]!==_[_0x1023('0x5c')](_0x51fbf7[_0x1023('0x5d')])||this['voiceQueues'][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x5e')]!==_[_0x1023('0x5c')](_0x51fbf7[_0x1023('0x5e')])||this[_0x1023('0x37')][_0x51fbf7['queue']][_0x1023('0x29')]!==_0x411f71){this[_0x1023('0x37')][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x4b')]=_['toNumber'](_0x51fbf7[_0x1023('0x5b')]);this[_0x1023('0x37')][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x44')]=_['toNumber'](_0x51fbf7['loggedin']);this[_0x1023('0x37')][_0x51fbf7['queue']]['available']=_[_0x1023('0x5c')](_0x51fbf7[_0x1023('0x5e')]);this['voiceQueues'][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x29')]=_0x411f71>0x0?_0x411f71:0x0;this[_0x1023('0x37')][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x29')]=this[_0x1023('0x37')][_0x51fbf7['queue']][_0x1023('0x29')]>_[_0x1023('0x5c')](_0x51fbf7['loggedin'])?_[_0x1023('0x5c')](_0x51fbf7[_0x1023('0x5d')]):this['voiceQueues'][_0x51fbf7[_0x1023('0x59')]][_0x1023('0x29')];this[_0x1023('0x41')](this[_0x1023('0x37')][_0x51fbf7['queue']]);}ami[_0x1023('0x39')](_0x1023('0x5f'),this['voiceQueues'][_0x51fbf7[_0x1023('0x59')]]);}}}catch(_0x539558){logger[_0x1023('0x33')](_0x1023('0x60'),util[_0x1023('0x38')](_0x539558,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x61')]=function(_0x426417){this[_0x1023('0x56')]=!![];};VoiceQueueReport['prototype'][_0x1023('0x62')]=function(_0x25e9b9){};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x13')]=function(_0x18a7c8){try{if(this[_0x1023('0x51')](_0x18a7c8)){if(_[_0x1023('0x52')](this[_0x1023('0x34')][_0x18a7c8[_0x1023('0x63')]])){this[_0x1023('0x34')][_0x18a7c8['uniqueid']]=[];this['channels'][_0x18a7c8[_0x1023('0x63')]]={};}var _0x499e67=new QueueReport();_0x499e67['name']=_0x18a7c8['queue'];_0x499e67[_0x1023('0x42')]=this[_0x1023('0x37')][_0x499e67['name']]&&this[_0x1023('0x37')][_0x499e67[_0x1023('0x3d')]]['type']?this['voiceQueues'][_0x499e67[_0x1023('0x3d')]]['type']||_0x1023('0x64'):_0x1023('0x64');_0x499e67[_0x1023('0x59')]=_0x18a7c8[_0x1023('0x59')];_0x499e67[_0x1023('0x65')]=moment()[_0x1023('0x3b')](_0x1023('0x66'));_0x499e67['position']=_0x18a7c8[_0x1023('0x67')];_0x499e67['count']=_0x18a7c8[_0x1023('0x68')];_[_0x1023('0x69')](_0x499e67,_[_0x1023('0x6a')](_0x18a7c8,_['keys'](_0x499e67)));this['queueReports'][_0x18a7c8[_0x1023('0x63')]]['push'](_0x499e67);this[_0x1023('0x2d')][_0x18a7c8[_0x1023('0x63')]]=_0x499e67;this[_0x1023('0x3a')](_0x499e67);}}catch(_0x335e4e){logger[_0x1023('0x33')](_0x1023('0x6b'),util[_0x1023('0x38')](_0x335e4e,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x14')]=function(_0x1fa5fc){try{if(this[_0x1023('0x51')](_0x1fa5fc)){if(this[_0x1023('0x34')][_0x1fa5fc['uniqueid']]){var _0x46b0fa=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x1fa5fc['uniqueid']]);_0x46b0fa[_0x1023('0x6d')]=![];_0x46b0fa[_0x1023('0x6e')]=null;_0x46b0fa[_0x1023('0x6f')]=_0x1fa5fc[_0x1023('0x6f')];_0x46b0fa[_0x1023('0x70')]=_0x1fa5fc[_0x1023('0x70')];_0x46b0fa[_0x1023('0x71')]=!![];_0x46b0fa[_0x1023('0x72')]=moment()[_0x1023('0x3b')]('YYYY-MM-DD\x20HH:mm:ss');_0x46b0fa[_0x1023('0x73')]=_0x1023('0x74');_0x46b0fa[_0x1023('0x75')]=null;this['channels'][_0x1fa5fc['uniqueid']]=_0x46b0fa;this['emitVoiceQueueChannelRemove'](_0x46b0fa);}}}catch(_0x1c6a85){logger[_0x1023('0x33')](_0x1023('0x76'),util[_0x1023('0x38')](_0x1c6a85,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')]['syncQueueCallerLeave']=function(_0x56c7f4){try{if(this[_0x1023('0x51')](_0x56c7f4)){if(this[_0x1023('0x34')][_0x56c7f4[_0x1023('0x63')]]){var _0x125ab3=_[_0x1023('0x6c')](this['queueReports'][_0x56c7f4['uniqueid']]);_0x125ab3[_0x1023('0x77')]=moment()[_0x1023('0x3b')](_0x1023('0x66'));_0x125ab3[_0x1023('0x78')]=_0x56c7f4['connectedlinenum'];_0x125ab3[_0x1023('0x79')]=_0x56c7f4['connectedlinename'];this[_0x1023('0x2d')][_0x56c7f4[_0x1023('0x63')]]=_0x125ab3;this[_0x1023('0x3a')](_0x125ab3);}}}catch(_0xbe438b){logger[_0x1023('0x33')](_0x1023('0x7a'),util[_0x1023('0x38')](_0xbe438b,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x1023('0x7b')]=function(_0x28db54){try{if(this['isNotNull'](_0x28db54)){if(this[_0x1023('0x34')][_0x28db54['uniqueid']]){var _0x4d9159=_[_0x1023('0x6c')](this['queueReports'][_0x28db54[_0x1023('0x63')]]);_0x4d9159['queuecallercomplete']=!![];_0x4d9159['queuecallerexitreason']=_0x1023('0x7c');}}}catch(_0x158ca9){logger[_0x1023('0x33')](_0x1023('0x7d'),util[_0x1023('0x38')](_0x158ca9,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')]['syncAgentComplete']=function(_0x6aa8a8){try{if(this[_0x1023('0x51')](_0x6aa8a8)){if(this[_0x1023('0x34')][_0x6aa8a8[_0x1023('0x63')]]){var _0x17b1a0=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x6aa8a8[_0x1023('0x63')]]);_0x17b1a0[_0x1023('0x71')]=![];_0x17b1a0[_0x1023('0x72')]=null;_0x17b1a0['assigned']=!![];_0x17b1a0['lastAssignedTo']=_0x6aa8a8['membername'];_0x17b1a0['holdtime']=_0x6aa8a8[_0x1023('0x6f')];_0x17b1a0[_0x1023('0x6d')]=!![];_0x17b1a0[_0x1023('0x7e')]=![];_0x17b1a0['queuecallerexitAt']=null;if(!_0x17b1a0[_0x1023('0x7f')]){if(_0x6aa8a8[_0x1023('0x80')]==_0x1023('0x7f')){_0x17b1a0[_0x1023('0x73')]='COMPLETED';}else{if(_['startsWith'](_0x6aa8a8['channel'][_0x1023('0x81')](),_0x1023('0x82'))){if(this['queueReports'][_0x6aa8a8['linkedid']]){var _0x348381=_[_0x1023('0x6c')](this['queueReports'][_0x6aa8a8[_0x1023('0x83')]]);_0x348381[_0x1023('0x6d')]=![];_0x348381['queuecallerexit']=!![];_0x348381[_0x1023('0x84')]=moment(_0x17b1a0[_0x1023('0x65')])['add'](_0x6aa8a8[_0x1023('0x6f')],'seconds')[_0x1023('0x3b')](_0x1023('0x66'));_0x348381[_0x1023('0x73')]=_0x1023('0x85');_0x348381[_0x1023('0x7f')]=!![];_0x348381['transfertype']='FORWARD';_0x348381['transferexten']=_0x6aa8a8[_0x1023('0x86')];_0x348381[_0x1023('0x87')]=_0x6aa8a8['uniqueid'];var _0x160aed=this[_0x1023('0x34')][_0x6aa8a8[_0x1023('0x83')]];this[_0x1023('0x34')][_0x6aa8a8[_0x1023('0x83')]]=this[_0x1023('0x34')][_0x6aa8a8['uniqueid']];this[_0x1023('0x34')][_0x6aa8a8[_0x1023('0x63')]]=_0x160aed;}}else{_0x17b1a0['queuecallerexitreason']=_0x1023('0x88')+_0x6aa8a8[_0x1023('0x80')][_0x1023('0x89')]();}}}this[_0x1023('0x2d')][_0x6aa8a8['uniqueid']]=_0x17b1a0;this[_0x1023('0x8a')](_0x17b1a0);}}}catch(_0x284ba8){logger[_0x1023('0x33')]('[syncAgentComplete][VoiceQueueReport]',util[_0x1023('0x38')](_0x284ba8,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0x1023('0x8b')]=function(_0x3c2281){try{if(this['isNotNull'](_0x3c2281)){this[_0x1023('0x8c')](_0x3c2281[_0x1023('0x63')],_[_0x1023('0x8d')](_0x3c2281[_0x1023('0x8e')])[0x0],_0x3c2281[_0x1023('0x8f')]);if(this[_0x1023('0x34')][_0x3c2281['uniqueid']]){var _0x53496b=_['last'](this['queueReports'][_0x3c2281[_0x1023('0x63')]]);if(_0x53496b){if(this[_0x1023('0x51')](_0x3c2281['variable'])&&this[_0x1023('0x51')](_0x3c2281[_0x1023('0x8e')]['queuestatus'])){switch(_0x3c2281[_0x1023('0x8f')]){case _0x1023('0x90'):_0x53496b[_0x1023('0x7e')]=![];_0x53496b[_0x1023('0x84')]=null;break;case _0x1023('0x91'):_0x53496b[_0x1023('0x92')]='timeout';ami['emit'](_0x1023('0x93'),_0x53496b);break;default:_0x53496b[_0x1023('0x7e')]=!![];_0x53496b[_0x1023('0x84')]=moment()[_0x1023('0x3b')]('YYYY-MM-DD\x20HH:mm:ss');_0x53496b['queuecallerleaveAt']=moment()[_0x1023('0x3b')](_0x1023('0x66'));}_0x53496b[_0x1023('0x71')]=![];_0x53496b[_0x1023('0x72')]=null;_0x53496b[_0x1023('0x73')]=_0x3c2281[_0x1023('0x8f')];this[_0x1023('0x2d')][_0x3c2281[_0x1023('0x63')]]=_0x53496b;this[_0x1023('0x8a')](_0x53496b);}else if(this['isNotNull'](_0x3c2281[_0x1023('0x8e')])&&this[_0x1023('0x51')](_0x3c2281[_0x1023('0x8e')][_0x1023('0x94')])){if(!_0x53496b[_0x1023('0x71')]){_0x53496b[_0x1023('0x7e')]=!![];_0x53496b[_0x1023('0x84')]=moment()[_0x1023('0x3b')]('YYYY-MM-DD\x20HH:mm:ss');_0x53496b[_0x1023('0x73')]=_0x1023('0x95');_0x53496b[_0x1023('0x77')]=moment()[_0x1023('0x3b')](_0x1023('0x66'));this[_0x1023('0x2d')][_0x3c2281[_0x1023('0x63')]]=_0x53496b;}}_0x53496b['variables']=this[_0x1023('0xe')][_0x3c2281[_0x1023('0x63')]];}}}}catch(_0x81d73c){logger[_0x1023('0x33')]('[syncVarSet][VoiceQueueReport]',util['inspect'](_0x81d73c,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x8c')]=function(_0x22335c,_0x3c3868,_0x5d755c){var _0x42f0e3=[_0x1023('0x96'),'rtpaudioqosbridged',_0x1023('0x97'),_0x1023('0x98'),_0x1023('0x99'),_0x1023('0x9a'),'rtpaudioqosrtt',_0x1023('0x9b'),_0x1023('0x9c'),_0x1023('0x9d'),'bridgepeer',_0x1023('0x9e'),_0x1023('0x9f'),_0x1023('0xa0'),'memberinterface',_0x1023('0xa1'),_0x1023('0xa2'),'memberpenalty',_0x1023('0xa3')];if(!_[_0x1023('0xa4')](_0x3c3868)&&!_[_0x1023('0xa5')](_0x42f0e3,_0x3c3868)){if(_[_0x1023('0x52')](this[_0x1023('0xe')][_0x22335c])){this[_0x1023('0xe')][_0x22335c]={};}this['variables'][_0x22335c][_0x3c3868]=_0x5d755c;}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x1b')]=function(_0x31dc45){try{if(this[_0x1023('0x51')](_0x31dc45)){if(this[_0x1023('0x34')][_0x31dc45[_0x1023('0x63')]]){for(var _0x45ebe2=0x0,_0x524e07={};_0x45ebe2<this['queueReports'][_0x31dc45[_0x1023('0x63')]][_0x1023('0xa6')];_0x45ebe2+=0x1){_0x524e07=this[_0x1023('0x34')][_0x31dc45[_0x1023('0x63')]][_0x45ebe2];if(this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]]){if(_0x524e07[_0x1023('0x7e')]){this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]][_0x1023('0x49')]+=0x1;}if(_0x524e07['queuecallerabandon']){this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]]['abandoned']+=0x1;}this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]][_0x1023('0x47')]+=moment(_0x524e07[_0x1023('0x77')])[_0x1023('0xa7')](_0x524e07[_0x1023('0x65')],_0x1023('0xa8'))||0x0;if(_0x45ebe2===this[_0x1023('0x34')][_0x31dc45['uniqueid']][_0x1023('0xa6')]-0x1){this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]][_0x1023('0x46')]+=moment()[_0x1023('0xa9')](0x0)[_0x1023('0xa7')](_0x524e07[_0x1023('0x65')],_0x1023('0xa8'));this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]]['total']+=0x1;if(_0x524e07[_0x1023('0x6d')]){this[_0x1023('0x37')][_0x524e07['queue']]['answered']+=0x1;this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]][_0x1023('0x45')]+=moment()[_0x1023('0xa9')](0x0)[_0x1023('0xa7')](_0x524e07[_0x1023('0x77')],_0x1023('0xa8'));_0x524e07[_0x1023('0x6e')]=moment()[_0x1023('0x3b')](_0x1023('0x66'));_0x524e07['queuecallerexit']=![];_0x524e07[_0x1023('0x84')]=null;}if(_0x524e07[_0x1023('0x7e')]){_0x524e07[_0x1023('0x92')]=_0x1023('0x49');ami[_0x1023('0x39')](_0x1023('0xaa'),_0x524e07);}if(_0x524e07[_0x1023('0x71')]){_0x524e07['lastevent']=_0x1023('0x4a');ami[_0x1023('0x39')](_0x1023('0xab'),_0x524e07);}}else{this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]][_0x1023('0x46')]+=this['voiceQueues'][_0x524e07['queue']][_0x1023('0x47')];}this[_0x1023('0x2d')][_0x31dc45[_0x1023('0x63')]]=_0x524e07;this['emitVoiceQueueChannelRemove'](_0x524e07);this[_0x1023('0x41')](this[_0x1023('0x37')][_0x524e07[_0x1023('0x59')]]);}}ami[_0x1023('0x39')](_0x1023('0xac'),this[_0x1023('0x34')][_0x31dc45['uniqueid']]);delete this[_0x1023('0x34')][_0x31dc45[_0x1023('0x63')]];delete this[_0x1023('0x2d')][_0x31dc45[_0x1023('0x63')]];}if(this[_0x1023('0xe')][_0x31dc45[_0x1023('0x63')]]){delete this['variables'][_0x31dc45[_0x1023('0x63')]];}}}catch(_0x297d78){logger[_0x1023('0x33')](_0x1023('0xad'),util[_0x1023('0x38')](_0x297d78,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x22')]=function(_0x234c27){try{if(this['isNotNull'](_0x234c27)){var _0x5baf75;if(this[_0x1023('0x34')][_0x234c27['transfereeuniqueid']]){_0x5baf75=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x234c27[_0x1023('0xae')]]);_0x5baf75[_0x1023('0xaf')]=_0x234c27['secondtransfererexten'];_0x5baf75['transferuniqueid']=_0x234c27[_0x1023('0xb0')];_0x5baf75[_0x1023('0x73')]='ATTENDEDTRANSFER';_0x5baf75[_0x1023('0x7f')]=!![];_0x5baf75['transfertype']='ATTENDED';if(this[_0x1023('0x34')][_0x234c27[_0x1023('0xb0')]]){var _0x4f5b17=this[_0x1023('0x34')][_0x234c27[_0x1023('0xb0')]];this[_0x1023('0x34')][_0x234c27[_0x1023('0xb0')]]=this[_0x1023('0x34')][_0x234c27[_0x1023('0xae')]];this[_0x1023('0x34')][_0x234c27[_0x1023('0xae')]]=_0x4f5b17;var _0xd7efcb=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x234c27[_0x1023('0xae')]]);_0xd7efcb[_0x1023('0x2e')]=!![];}}else if(this['queueReports'][_0x234c27[_0x1023('0xb1')]]){_0x5baf75=_['last'](this['queueReports'][_0x234c27[_0x1023('0xb1')]]);_0x5baf75[_0x1023('0xaf')]=_0x234c27['origtransfererexten'];_0x5baf75[_0x1023('0x87')]=_0x234c27['origtransfereruniqueid'];_0x5baf75['queuecallerexitreason']=_0x1023('0xb2');_0x5baf75[_0x1023('0x7f')]=!![];_0x5baf75['transfertype']=_0x1023('0xb3');if(this[_0x1023('0x34')][_0x234c27[_0x1023('0xb4')]]){var _0x4f5b17=this[_0x1023('0x34')][_0x234c27[_0x1023('0xb4')]];this[_0x1023('0x34')][_0x234c27[_0x1023('0xb4')]]=this[_0x1023('0x34')][_0x234c27[_0x1023('0xb1')]];this['queueReports'][_0x234c27[_0x1023('0xb1')]]=_0x4f5b17;var _0xd7efcb=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x234c27['transfertargetuniqueid']]);_0xd7efcb['switch']=!![];}}}}catch(_0x5dcdcb){logger['error']('[syncAttendedTransfer][VoiceQueueReport]',util[_0x1023('0x38')](_0x5dcdcb,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x24')]=function(_0x161cfc){try{if(this['isNotNull'](_0x161cfc)){if(this[_0x1023('0x34')][_0x161cfc[_0x1023('0xae')]]){var _0x5c9b4d=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x161cfc[_0x1023('0xae')]]);_0x5c9b4d[_0x1023('0x73')]=_0x1023('0xb5');_0x5c9b4d[_0x1023('0x7f')]=!![];_0x5c9b4d[_0x1023('0xb6')]=_0x1023('0xb7');_0x5c9b4d['transferexten']=_0x161cfc[_0x1023('0xb8')];_0x5c9b4d[_0x1023('0x87')]=_0x161cfc[_0x1023('0xae')];this[_0x1023('0x1b')]({'event':_0x1023('0xb9'),'uniqueid':_0x161cfc[_0x1023('0xae')],'context':_0x161cfc['context'],'channel':_0x161cfc[_0x1023('0xba')]});}}}catch(_0x16851d){logger[_0x1023('0x33')](_0x1023('0xbb'),util['inspect'](_0x16851d,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x1e')]=function(_0x2bdda0){try{if(this['isNotNull'](_0x2bdda0)){if(this[_0x1023('0x34')][_0x2bdda0[_0x1023('0x63')]]){var _0x5c568c=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x2bdda0[_0x1023('0x63')]]);if(!_[_0x1023('0xa4')](_0x5c568c['queuecallerleaveAt'])){_0x5c568c[_0x1023('0xbc')]=moment()[_0x1023('0x3b')](_0x1023('0x66'));}}}}catch(_0x11700f){logger[_0x1023('0x33')](_0x1023('0xbd'),util[_0x1023('0x38')](_0x11700f,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0x1023('0x8')][_0x1023('0x20')]=function(_0x93a137){try{if(this[_0x1023('0x51')](_0x93a137)){if(this[_0x1023('0x34')][_0x93a137[_0x1023('0x63')]]){var _0x1cb2fa=_[_0x1023('0x6c')](this[_0x1023('0x34')][_0x93a137[_0x1023('0x63')]]);if(!_[_0x1023('0xa4')](_0x1cb2fa['mohstarttime'])){_0x1cb2fa[_0x1023('0xbe')]+=moment()[_0x1023('0xa9')](0x0)[_0x1023('0xa7')](_0x1cb2fa[_0x1023('0xbc')],_0x1023('0xa8'));delete _0x1cb2fa[_0x1023('0xbc')];}}}}catch(_0x36dadb){logger['error'](_0x1023('0xbf'),util[_0x1023('0x38')](_0x36dadb,{'showHidden':![],'depth':null}));}};module['exports']=VoiceQueueReport;