Built motion from commit (unavailable).|2.5.6
[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 _0x0eda=['originated','talking','pTalking','waiting','queueStatusComplete','switch','Action','channel','catch','message','No\x20such\x20channel','error','[voiceQueueReport][checkChannel]','[voiceQueueReport][checkQueueReport]','variables','[voiceQueueReport][checkVariables]','syncFullyBooted','[FullyBooted]\x20clear\x20realtime','clearQueueReport','agents','emitVoiceQueueChannelRemove','inspect','emit','emitVoiceQueueChannelSave','format','name','[DEBUG]\x20Emit\x20voice_queue_channel:remove\x20event','stringify','voice:queue:%s','voice_queue_channel:remove','emitVoiceQueueSummary','type','strategy','answered','available','loggedIn','sumDuration','total','abandoned','Trunk','active','callerid','Interval','md5','isUndefined','queues','then','[queuesummary]','isNotNull','queue','countBy','callers','toNumber','loggedin','syncNewExten','uniqueid','inbound','queuecallerjoinAt','YYYY-MM-DD\x20HH:mm:ss','merge','keys','push','[syncQueueCallerJoin][VoiceQueueReport]','queuecallercompleteAt','holdtime','originalposition','queuecallerabandonAt','ABANDONED','lastAssignedTo','[syncQueueCallerAbandon][VoiceQueueReport]','queuecallerleaveAt','connectedlinenum','connectedlinename','[syncQueueCallerLeave][VoiceQueueReport]','syncAgentConnect','last','queuecallercomplete','COMPLETEDBYAGENT','[syncAgentConnect][VoiceQueueReport]','assigned','queuecallerexit','queuecallerexitAt','transfer','reason','queuecallerexitreason','COMPLETED','startsWith','local/','linkedid','add','seconds','FORWARDTRANSFER','transfertype','FORWARD','transferexten','destexten','COMPLETEDBY','[syncAgentComplete][VoiceQueueReport]','syncVarSet','addVariable','variable','value','TIMEOUT','lastevent','timeout','custom:timeout','queueposition','EXITWITHKEY','[syncVarSet][VoiceQueueReport]','rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrtt','sipcallid','sipuri','bridgepeer','membercalls','memberdynamic','memberinterface','memberpenalty','memberrealtime','includes','length','unmanaged','sumHoldTime','diff','milliseconds','sumBillable','custom:queuecallerunmanaged','custom:queuecallerabandon','transfereeuniqueid','secondtransfererexten','transferuniqueid','secondtransfereruniqueid','ATTENDEDTRANSFER','transfertargetuniqueid','origtransfererexten','origtransfereruniqueid','ATTENDED','[syncAttendedTransfer][VoiceQueueReport]','BLINDTRANSFER','BLIND','extension','syncHangup','BlindTransfer','transfererchannel','[syncBlindTransfer][VoiceQueueReport]','syncMusicOnHoldStart','isNil','mohstarttime','syncMusicOnHoldStop','[syncMusicOnHoldStop][VoiceQueueReport]','exports','moment','util','ioredis','../../../config/environment','../../../config/logger','ami','../model/queueReport','redis','defaults','localhost','prototype','enqueue','tail','finally','sequence','queueReports','channels','queueChannels','voiceQueues','flagQueueSummary','campaigns','queuesummary','syncQueueSummary','bind','syncQueueSummaryComplete','queuecallerjoin','syncQueueCallerJoin','queuecallerabandon','syncQueueCallerAbandon','queuecallerleave','syncQueueCallerLeave','agentconnect','hangup','musiconholdstart','musiconholdstop','syncAttendedTransfer','blindtransfer','syncBlindTransfer','loopQueueSummary','loopQueueShow','isEmpty','hasOwnProperty'];(function(_0x50a1bd,_0x282411){var _0x179d2e=function(_0x29ed64){while(--_0x29ed64){_0x50a1bd['push'](_0x50a1bd['shift']());}};_0x179d2e(++_0x282411);}(_0x0eda,0x9c));var _0xa0ed=function(_0x3ccd54,_0x478e23){_0x3ccd54=_0x3ccd54-0x0;var _0x2963c8=_0x0eda[_0x3ccd54];return _0x2963c8;};'use strict';var _=require('lodash');var moment=require(_0xa0ed('0x0'));var BPromise=require('bluebird');var util=require(_0xa0ed('0x1'));var md5=require('md5');var Redis=require(_0xa0ed('0x2'));var config=require(_0xa0ed('0x3'));var logger=require(_0xa0ed('0x4'))(_0xa0ed('0x5'));var ami=require('../ami');var QueueReport=require(_0xa0ed('0x6'));config[_0xa0ed('0x7')]=_[_0xa0ed('0x8')](config[_0xa0ed('0x7')],{'host':_0xa0ed('0x9'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0xa0ed('0x7')]));var Sequence=function(){};Sequence[_0xa0ed('0xa')][_0xa0ed('0xb')]=function(_0x353fef){this[_0xa0ed('0xc')]=this[_0xa0ed('0xc')]?this[_0xa0ed('0xc')][_0xa0ed('0xd')](_0x353fef):_0x353fef();};function VoiceQueueReport(_0x1a3d99){this[_0xa0ed('0xe')]=new Sequence();this[_0xa0ed('0xf')]={};this['agents']=_0x1a3d99['agents'];this[_0xa0ed('0x10')]=_0x1a3d99[_0xa0ed('0x11')];this[_0xa0ed('0x12')]=_0x1a3d99[_0xa0ed('0x12')];this[_0xa0ed('0x13')]=!![];this[_0xa0ed('0x14')]=_0x1a3d99[_0xa0ed('0x14')];this['variables']={};ami['on'](_0xa0ed('0x15'),this[_0xa0ed('0x16')][_0xa0ed('0x17')](this));ami['on']('queuesummarycomplete',this[_0xa0ed('0x18')]['bind'](this));ami['on'](_0xa0ed('0x19'),this[_0xa0ed('0x1a')][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x1b'),this[_0xa0ed('0x1c')][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x1d'),this[_0xa0ed('0x1e')][_0xa0ed('0x17')](this));ami['on']('agentcomplete',this['syncAgentComplete'][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x1f'),this['syncAgentConnect'][_0xa0ed('0x17')](this));ami['on']('varset',this['syncVarSet'][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x20'),this['syncHangup']['bind'](this));ami['on']('fullybooted',this['syncFullyBooted'][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x21'),this['syncMusicOnHoldStart'][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x22'),this['syncMusicOnHoldStop'][_0xa0ed('0x17')](this));ami['on']('attendedtransfer',this[_0xa0ed('0x23')][_0xa0ed('0x17')](this));ami['on'](_0xa0ed('0x24'),this[_0xa0ed('0x25')][_0xa0ed('0x17')](this));this[_0xa0ed('0x26')]();this[_0xa0ed('0x27')]();}function isNotNull(_0x274c6e){return _0x274c6e!==null&&!_['isUndefined'](_0x274c6e);}function clearChannels(_0xf9922b){if(!_['isEmpty'](_0xf9922b)){for(var _0x289b06 in _0xf9922b){if(_0xf9922b['hasOwnProperty'](_0x289b06)){delete _0xf9922b[_0x289b06];}}}}function clearCampaigns(_0x11a912){if(!_[_0xa0ed('0x28')](_0x11a912)){for(var _0x338e67 in _0x11a912){if(_0x11a912[_0xa0ed('0x29')](_0x338e67)){_0x11a912[_0x338e67][_0xa0ed('0x2a')]=0x0;}}}}function clearVoiceQueues(_0x318eb4){if(!_['isEmpty'](_0x318eb4)){for(var _0x2529cf in _0x318eb4){if(_0x318eb4[_0xa0ed('0x29')](_0x2529cf)){_0x318eb4[_0x2529cf][_0xa0ed('0x2a')]=0x0;_0x318eb4[_0x2529cf][_0xa0ed('0x2b')]=0x0;_0x318eb4[_0x2529cf][_0xa0ed('0x2c')]=0x0;_0x318eb4[_0x2529cf][_0xa0ed('0x2d')]=0x0;_0x318eb4[_0x2529cf][_0xa0ed('0x2e')]=!![];}}}}function clearAgentBooked(_0x21263e){if(!_['isEmpty'](_0x21263e)){for(var _0x21a6b6 in _0x21263e){if(_0x21263e[_0xa0ed('0x29')](_0x21a6b6)){_0x21263e[_0x21a6b6]['unlockRR']=!![];}}}}VoiceQueueReport[_0xa0ed('0xa')]['clearZombieChannels']=function(){var _0x28429e=this;for(var _0x237f29 in this[_0xa0ed('0x10')]){if(this[_0xa0ed('0x10')]['hasOwnProperty'](_0x237f29)&&!this['channels'][_0x237f29][_0xa0ed('0x2f')]){this[_0xa0ed('0xe')][_0xa0ed('0xb')](function(){if(!_['isNil'](_0x28429e[_0xa0ed('0x10')][_0x237f29])){return ami[_0xa0ed('0x30')]({'action':'status','channel':_0x28429e[_0xa0ed('0x10')][_0x237f29][_0xa0ed('0x31')]})[_0xa0ed('0x32')](function(_0x37b953){if(_0x37b953[_0xa0ed('0x33')]===_0xa0ed('0x34')){setTimeout(function(){if(_0x28429e[_0xa0ed('0x10')][_0x237f29]){delete _0x28429e[_0xa0ed('0x10')][_0x237f29];logger[_0xa0ed('0x35')](_0xa0ed('0x36'),_0x237f29);}if(_0x28429e[_0xa0ed('0xf')][_0x237f29]){delete _0x28429e['queueReports'][_0x237f29];logger[_0xa0ed('0x35')](_0xa0ed('0x37'),_0x237f29);}if(_0x28429e[_0xa0ed('0x38')][_0x237f29]){delete _0x28429e[_0xa0ed('0x38')][_0x237f29];logger['error'](_0xa0ed('0x39'),_0x237f29);}},0x1f40);}});}});}}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x3a')]=function(){logger[_0xa0ed('0x35')](_0xa0ed('0x3b'));clearChannels(this[_0xa0ed('0x10')]);this[_0xa0ed('0x3c')](this[_0xa0ed('0xf')]);clearAgentBooked(this[_0xa0ed('0x3d')]);clearVoiceQueues(this[_0xa0ed('0x12')]);clearCampaigns(this[_0xa0ed('0x14')]);};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x3c')]=function(_0xef901f){var _0x15edd7=this;if(!_[_0xa0ed('0x28')](_0xef901f)){for(var _0xd0942b in _0xef901f){if(_0xef901f[_0xa0ed('0x29')](_0xd0942b)){_0x15edd7[_0xa0ed('0x3e')](_0xef901f[_0xd0942b]);delete _0xef901f[_0xd0942b];}}}};function loggerCatch(_0x52566e){return function(_0x22ac7b){logger[_0xa0ed('0x35')](_0x52566e,util[_0xa0ed('0x3f')](_0x22ac7b,{'showHidden':![],'depth':null}));};}VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x40')]=function(_0x203de2,_0x40962d,_0x4250c3){io['to'](_0x203de2)[_0xa0ed('0x40')](_0x40962d,_0x4250c3);};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x41')]=function(_0x55bddd){this[_0xa0ed('0x40')](util[_0xa0ed('0x42')]('voice:queue:%s',_0x55bddd[_0xa0ed('0x43')]),'voice_queue_channel:save',_0x55bddd);};VoiceQueueReport['prototype']['emitVoiceQueueChannelRemove']=function(_0x97624a){logger['info'](_0xa0ed('0x44'),JSON[_0xa0ed('0x45')](_0x97624a));this[_0xa0ed('0x40')](util[_0xa0ed('0x42')](_0xa0ed('0x46'),_0x97624a[_0xa0ed('0x43')]),_0xa0ed('0x47'),_0x97624a);};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x48')]=function(_0x281d01){if(_0x281d01[_0xa0ed('0x49')]==='inbound'){var _0x5d9edf={'id':_0x281d01['id'],'name':_0x281d01[_0xa0ed('0x43')],'strategy':_0x281d01[_0xa0ed('0x4a')],'answered':_0x281d01[_0xa0ed('0x4b')],'available':_0x281d01[_0xa0ed('0x4c')],'loggedIn':_0x281d01[_0xa0ed('0x4d')],'pTalking':_0x281d01[_0xa0ed('0x2c')],'sumBillable':_0x281d01['sumBillable'],'sumDuration':_0x281d01[_0xa0ed('0x4e')],'sumHoldTime':_0x281d01['sumHoldTime']||0x0,'talking':_0x281d01[_0xa0ed('0x2b')],'total':_0x281d01[_0xa0ed('0x4f')],'type':_0x281d01['type'],'unmanaged':_0x281d01['unmanaged'],'abandoned':_0x281d01[_0xa0ed('0x50')],'waiting':_0x281d01['waiting']};if(_0x281d01[_0xa0ed('0x51')]){_0x5d9edf[_0xa0ed('0x51')]={'id':_0x281d01[_0xa0ed('0x51')]['id'],'name':_0x281d01[_0xa0ed('0x51')]['name'],'active':_0x281d01['Trunk'][_0xa0ed('0x52')],'callerid':_0x281d01[_0xa0ed('0x51')][_0xa0ed('0x53')]};}if(_0x281d01[_0xa0ed('0x54')]){_0x5d9edf[_0xa0ed('0x54')]={'id':_0x281d01[_0xa0ed('0x54')]['id'],'name':_0x281d01[_0xa0ed('0x54')][_0xa0ed('0x43')]};}var _0x101c4f=md5(JSON[_0xa0ed('0x45')](_0x5d9edf));if(_0x281d01[_0xa0ed('0x55')]!==_0x101c4f){_0x281d01['md5']=_0x101c4f;this['emit'](util[_0xa0ed('0x42')](_0xa0ed('0x46'),_0x5d9edf[_0xa0ed('0x43')]),'voice_queue:save',_0x5d9edf);}}};VoiceQueueReport[_0xa0ed('0xa')]['isNotNull']=function(_0x3be06f){return _0x3be06f!==null&&!_[_0xa0ed('0x56')](_0x3be06f);};VoiceQueueReport['prototype'][_0xa0ed('0x27')]=function(){var _0x4a5331=this;setInterval(function(){_0x4a5331['clearZombieChannels']();ami[_0xa0ed('0x30')]({'action':_0xa0ed('0x57')})[_0xa0ed('0x32')](loggerCatch('[queues]'));},0x2710);};VoiceQueueReport[_0xa0ed('0xa')]['loopQueueSummary']=function(){var _0x38f0b4=this;setInterval(function(){if(_0x38f0b4[_0xa0ed('0x13')]){return ami['Action']({'action':_0xa0ed('0x15')})[_0xa0ed('0x58')](function(_0x3ea7cd){_0x38f0b4[_0xa0ed('0x13')]=![];})[_0xa0ed('0x32')](loggerCatch(_0xa0ed('0x59')));}},0x3e8);};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x16')]=function(_0x4bc40d){try{if(this[_0xa0ed('0x5a')](_0x4bc40d)&&this['isNotNull'](_0x4bc40d[_0xa0ed('0x5b')])){if(this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]){var _0x2de92f=_[_0xa0ed('0x5c')](this[_0xa0ed('0x10')],_0xa0ed('0x5b'))[_0x4bc40d[_0xa0ed('0x5b')]]||0x0;var _0x3143a3=_0x2de92f-_0x4bc40d[_0xa0ed('0x5d')];if(this[_0xa0ed('0x12')][_0x4bc40d['queue']][_0xa0ed('0x2d')]!==_[_0xa0ed('0x5e')](_0x4bc40d['callers'])||this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]][_0xa0ed('0x4d')]!==_['toNumber'](_0x4bc40d['loggedin'])||this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]][_0xa0ed('0x4c')]!==_[_0xa0ed('0x5e')](_0x4bc40d['available'])||this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]['talking']!==_0x3143a3){this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]['waiting']=_[_0xa0ed('0x5e')](_0x4bc40d[_0xa0ed('0x5d')]);this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]][_0xa0ed('0x4d')]=_[_0xa0ed('0x5e')](_0x4bc40d[_0xa0ed('0x5f')]);this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]['available']=_['toNumber'](_0x4bc40d[_0xa0ed('0x4c')]);this['voiceQueues'][_0x4bc40d['queue']][_0xa0ed('0x2b')]=_0x3143a3>0x0?_0x3143a3:0x0;this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]['talking']=this['voiceQueues'][_0x4bc40d[_0xa0ed('0x5b')]][_0xa0ed('0x2b')]>_[_0xa0ed('0x5e')](_0x4bc40d[_0xa0ed('0x5f')])?_[_0xa0ed('0x5e')](_0x4bc40d[_0xa0ed('0x5f')]):this['voiceQueues'][_0x4bc40d['queue']][_0xa0ed('0x2b')];this['emitVoiceQueueSummary'](this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]);}ami['emit']('custom:queuesummary',this[_0xa0ed('0x12')][_0x4bc40d[_0xa0ed('0x5b')]]);}}}catch(_0x248cd4){logger[_0xa0ed('0x35')]('[syncQueueSummary][VoiceQueueReport]',util['inspect'](_0x248cd4,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x18')]=function(_0x17d003){this['flagQueueSummary']=!![];};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x60')]=function(_0x29f97e){};VoiceQueueReport[_0xa0ed('0xa')]['syncQueueCallerJoin']=function(_0x544bdf){try{if(this['isNotNull'](_0x544bdf)){if(_[_0xa0ed('0x56')](this[_0xa0ed('0xf')][_0x544bdf['uniqueid']])){this[_0xa0ed('0xf')][_0x544bdf[_0xa0ed('0x61')]]=[];this[_0xa0ed('0x10')][_0x544bdf[_0xa0ed('0x61')]]={};}var _0x131d75=new QueueReport();_0x131d75[_0xa0ed('0x43')]=_0x544bdf[_0xa0ed('0x5b')];_0x131d75[_0xa0ed('0x49')]=this[_0xa0ed('0x12')][_0x131d75['name']]&&this[_0xa0ed('0x12')][_0x131d75['name']][_0xa0ed('0x49')]?this[_0xa0ed('0x12')][_0x131d75['name']][_0xa0ed('0x49')]||'inbound':_0xa0ed('0x62');_0x131d75[_0xa0ed('0x5b')]=_0x544bdf[_0xa0ed('0x5b')];_0x131d75[_0xa0ed('0x63')]=moment()[_0xa0ed('0x42')](_0xa0ed('0x64'));_0x131d75['position']=_0x544bdf['position'];_0x131d75['count']=_0x544bdf['count'];_[_0xa0ed('0x65')](_0x131d75,_['pick'](_0x544bdf,_[_0xa0ed('0x66')](_0x131d75)));this[_0xa0ed('0xf')][_0x544bdf[_0xa0ed('0x61')]][_0xa0ed('0x67')](_0x131d75);this['channels'][_0x544bdf[_0xa0ed('0x61')]]=_0x131d75;this['emitVoiceQueueChannelSave'](_0x131d75);}}catch(_0x53dd27){logger['error'](_0xa0ed('0x68'),util[_0xa0ed('0x3f')](_0x53dd27,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x1c')]=function(_0x3e74c7){try{if(this[_0xa0ed('0x5a')](_0x3e74c7)){if(this['queueReports'][_0x3e74c7[_0xa0ed('0x61')]]){var _0x366522=_['last'](this[_0xa0ed('0xf')][_0x3e74c7[_0xa0ed('0x61')]]);_0x366522['queuecallercomplete']=![];_0x366522[_0xa0ed('0x69')]=null;_0x366522[_0xa0ed('0x6a')]=_0x3e74c7[_0xa0ed('0x6a')];_0x366522[_0xa0ed('0x6b')]=_0x3e74c7[_0xa0ed('0x6b')];_0x366522[_0xa0ed('0x1b')]=!![];_0x366522[_0xa0ed('0x6c')]=moment()[_0xa0ed('0x42')](_0xa0ed('0x64'));_0x366522['queuecallerexitreason']=_0xa0ed('0x6d');_0x366522[_0xa0ed('0x6e')]=null;this[_0xa0ed('0x10')][_0x3e74c7[_0xa0ed('0x61')]]=_0x366522;this['emitVoiceQueueChannelRemove'](_0x366522);}}}catch(_0x381116){logger[_0xa0ed('0x35')](_0xa0ed('0x6f'),util[_0xa0ed('0x3f')](_0x381116,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x1e')]=function(_0x3aa36a){try{if(this['isNotNull'](_0x3aa36a)){if(this[_0xa0ed('0xf')][_0x3aa36a['uniqueid']]){var _0x35e9e3=_['last'](this[_0xa0ed('0xf')][_0x3aa36a[_0xa0ed('0x61')]]);_0x35e9e3[_0xa0ed('0x70')]=moment()[_0xa0ed('0x42')](_0xa0ed('0x64'));_0x35e9e3[_0xa0ed('0x71')]=_0x3aa36a[_0xa0ed('0x71')];_0x35e9e3[_0xa0ed('0x72')]=_0x3aa36a[_0xa0ed('0x72')];this[_0xa0ed('0x10')][_0x3aa36a['uniqueid']]=_0x35e9e3;this['emitVoiceQueueChannelSave'](_0x35e9e3);}}}catch(_0x56d59f){logger[_0xa0ed('0x35')](_0xa0ed('0x73'),util[_0xa0ed('0x3f')](_0x56d59f,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0xa0ed('0x74')]=function(_0x352a33){try{if(this[_0xa0ed('0x5a')](_0x352a33)){if(this[_0xa0ed('0xf')][_0x352a33['uniqueid']]){var _0x3609d6=_[_0xa0ed('0x75')](this[_0xa0ed('0xf')][_0x352a33[_0xa0ed('0x61')]]);_0x3609d6[_0xa0ed('0x76')]=!![];_0x3609d6['queuecallerexitreason']=_0xa0ed('0x77');}}}catch(_0x3cd824){logger[_0xa0ed('0x35')](_0xa0ed('0x78'),util[_0xa0ed('0x3f')](_0x3cd824,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')]['syncAgentComplete']=function(_0x475706){try{if(this[_0xa0ed('0x5a')](_0x475706)){if(this[_0xa0ed('0xf')][_0x475706[_0xa0ed('0x61')]]){var _0x2b1f1d=_[_0xa0ed('0x75')](this[_0xa0ed('0xf')][_0x475706[_0xa0ed('0x61')]]);_0x2b1f1d[_0xa0ed('0x1b')]=![];_0x2b1f1d['queuecallerabandonAt']=null;_0x2b1f1d[_0xa0ed('0x79')]=!![];_0x2b1f1d[_0xa0ed('0x6e')]=_0x475706['membername'];_0x2b1f1d[_0xa0ed('0x6a')]=_0x475706['holdtime'];_0x2b1f1d[_0xa0ed('0x76')]=!![];_0x2b1f1d[_0xa0ed('0x7a')]=![];_0x2b1f1d[_0xa0ed('0x7b')]=null;if(!_0x2b1f1d[_0xa0ed('0x7c')]){if(_0x475706[_0xa0ed('0x7d')]==_0xa0ed('0x7c')){_0x2b1f1d[_0xa0ed('0x7e')]=_0xa0ed('0x7f');}else{if(_[_0xa0ed('0x80')](_0x475706[_0xa0ed('0x31')]['toLowerCase'](),_0xa0ed('0x81'))){if(this[_0xa0ed('0xf')][_0x475706[_0xa0ed('0x82')]]){var _0x5471b0=_[_0xa0ed('0x75')](this[_0xa0ed('0xf')][_0x475706[_0xa0ed('0x82')]]);_0x5471b0['queuecallercomplete']=![];_0x5471b0['queuecallerexit']=!![];_0x5471b0[_0xa0ed('0x7b')]=moment(_0x2b1f1d[_0xa0ed('0x63')])[_0xa0ed('0x83')](_0x475706[_0xa0ed('0x6a')],_0xa0ed('0x84'))[_0xa0ed('0x42')](_0xa0ed('0x64'));_0x5471b0[_0xa0ed('0x7e')]=_0xa0ed('0x85');_0x5471b0[_0xa0ed('0x7c')]=!![];_0x5471b0[_0xa0ed('0x86')]=_0xa0ed('0x87');_0x5471b0[_0xa0ed('0x88')]=_0x475706[_0xa0ed('0x89')];_0x5471b0['transferuniqueid']=_0x475706[_0xa0ed('0x61')];var _0x2c8151=this['queueReports'][_0x475706[_0xa0ed('0x82')]];this[_0xa0ed('0xf')][_0x475706['linkedid']]=this[_0xa0ed('0xf')][_0x475706[_0xa0ed('0x61')]];this[_0xa0ed('0xf')][_0x475706[_0xa0ed('0x61')]]=_0x2c8151;}}else{_0x2b1f1d[_0xa0ed('0x7e')]=_0xa0ed('0x8a')+_0x475706[_0xa0ed('0x7d')]['toUpperCase']();}}}this[_0xa0ed('0x10')][_0x475706[_0xa0ed('0x61')]]=_0x2b1f1d;this[_0xa0ed('0x3e')](_0x2b1f1d);}}}catch(_0xc037df){logger[_0xa0ed('0x35')](_0xa0ed('0x8b'),util[_0xa0ed('0x3f')](_0xc037df,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x8c')]=function(_0x40363f){try{if(this['isNotNull'](_0x40363f)){this[_0xa0ed('0x8d')](_0x40363f[_0xa0ed('0x61')],_[_0xa0ed('0x66')](_0x40363f[_0xa0ed('0x8e')])[0x0],_0x40363f[_0xa0ed('0x8f')]);if(this[_0xa0ed('0xf')][_0x40363f['uniqueid']]){var _0x472273=_['last'](this[_0xa0ed('0xf')][_0x40363f['uniqueid']]);if(_0x472273){if(this[_0xa0ed('0x5a')](_0x40363f['variable'])&&this['isNotNull'](_0x40363f['variable']['queuestatus'])){switch(_0x40363f['value']){case'CONTINUE':_0x472273[_0xa0ed('0x7a')]=![];_0x472273[_0xa0ed('0x7b')]=null;break;case _0xa0ed('0x90'):_0x472273[_0xa0ed('0x91')]=_0xa0ed('0x92');ami[_0xa0ed('0x40')](_0xa0ed('0x93'),_0x472273);break;default:_0x472273[_0xa0ed('0x7a')]=!![];_0x472273[_0xa0ed('0x7b')]=moment()[_0xa0ed('0x42')]('YYYY-MM-DD\x20HH:mm:ss');_0x472273[_0xa0ed('0x70')]=moment()[_0xa0ed('0x42')](_0xa0ed('0x64'));}_0x472273[_0xa0ed('0x1b')]=![];_0x472273['queuecallerabandonAt']=null;_0x472273[_0xa0ed('0x7e')]=_0x40363f[_0xa0ed('0x8f')];this[_0xa0ed('0x10')][_0x40363f[_0xa0ed('0x61')]]=_0x472273;this[_0xa0ed('0x3e')](_0x472273);}else if(this['isNotNull'](_0x40363f['variable'])&&this[_0xa0ed('0x5a')](_0x40363f[_0xa0ed('0x8e')][_0xa0ed('0x94')])){if(!_0x472273['queuecallerabandon']){_0x472273['queuecallerexit']=!![];_0x472273[_0xa0ed('0x7b')]=moment()[_0xa0ed('0x42')](_0xa0ed('0x64'));_0x472273['queuecallerexitreason']=_0xa0ed('0x95');_0x472273['queuecallerleaveAt']=moment()[_0xa0ed('0x42')](_0xa0ed('0x64'));this[_0xa0ed('0x10')][_0x40363f[_0xa0ed('0x61')]]=_0x472273;}}_0x472273[_0xa0ed('0x38')]=this['variables'][_0x40363f['uniqueid']];}}}}catch(_0x3552db){logger[_0xa0ed('0x35')](_0xa0ed('0x96'),util[_0xa0ed('0x3f')](_0x3552db,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype'][_0xa0ed('0x8d')]=function(_0x24ff31,_0x2a9058,_0x58baa9){var _0xc073c9=[_0xa0ed('0x97'),_0xa0ed('0x98'),_0xa0ed('0x99'),_0xa0ed('0x9a'),_0xa0ed('0x9b'),_0xa0ed('0x9c'),_0xa0ed('0x9d'),'rtpaudioqosrttbridged',_0xa0ed('0x9e'),_0xa0ed('0x9f'),_0xa0ed('0xa0'),'bridgepvtcallid',_0xa0ed('0xa1'),_0xa0ed('0xa2'),_0xa0ed('0xa3'),'memberlastcall','membername',_0xa0ed('0xa4'),_0xa0ed('0xa5')];if(!_['isNil'](_0x2a9058)&&!_[_0xa0ed('0xa6')](_0xc073c9,_0x2a9058)){if(_[_0xa0ed('0x56')](this['variables'][_0x24ff31])){this['variables'][_0x24ff31]={};}this[_0xa0ed('0x38')][_0x24ff31][_0x2a9058]=_0x58baa9;}};VoiceQueueReport['prototype']['syncHangup']=function(_0x2dfa4a){try{if(this[_0xa0ed('0x5a')](_0x2dfa4a)){if(this[_0xa0ed('0xf')][_0x2dfa4a[_0xa0ed('0x61')]]){for(var _0x454a4a=0x0,_0x3fb80e={};_0x454a4a<this[_0xa0ed('0xf')][_0x2dfa4a[_0xa0ed('0x61')]][_0xa0ed('0xa7')];_0x454a4a+=0x1){_0x3fb80e=this[_0xa0ed('0xf')][_0x2dfa4a[_0xa0ed('0x61')]][_0x454a4a];if(this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]]){if(_0x3fb80e[_0xa0ed('0x7a')]){this['voiceQueues'][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0xa8')]+=0x1;}if(_0x3fb80e['queuecallerabandon']){this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0x50')]+=0x1;}this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0xa9')]+=moment(_0x3fb80e[_0xa0ed('0x70')])[_0xa0ed('0xaa')](_0x3fb80e['queuecallerjoinAt'],_0xa0ed('0x84'))||0x0;if(_0x454a4a===this[_0xa0ed('0xf')][_0x2dfa4a['uniqueid']][_0xa0ed('0xa7')]-0x1){this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0x4e')]+=moment()[_0xa0ed('0xab')](0x0)[_0xa0ed('0xaa')](_0x3fb80e['queuecallerjoinAt'],_0xa0ed('0x84'));this['voiceQueues'][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0x4f')]+=0x1;if(_0x3fb80e[_0xa0ed('0x76')]){this[_0xa0ed('0x12')][_0x3fb80e['queue']][_0xa0ed('0x4b')]+=0x1;this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0xac')]+=moment()[_0xa0ed('0xab')](0x0)[_0xa0ed('0xaa')](_0x3fb80e[_0xa0ed('0x70')],_0xa0ed('0x84'));_0x3fb80e['queuecallercompleteAt']=moment()['format'](_0xa0ed('0x64'));_0x3fb80e[_0xa0ed('0x7a')]=![];_0x3fb80e[_0xa0ed('0x7b')]=null;}if(_0x3fb80e['queuecallerexit']){_0x3fb80e[_0xa0ed('0x91')]=_0xa0ed('0xa8');ami[_0xa0ed('0x40')](_0xa0ed('0xad'),_0x3fb80e);}if(_0x3fb80e['queuecallerabandon']){_0x3fb80e[_0xa0ed('0x91')]='abandoned';ami[_0xa0ed('0x40')](_0xa0ed('0xae'),_0x3fb80e);}}else{this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]][_0xa0ed('0x4e')]+=this['voiceQueues'][_0x3fb80e[_0xa0ed('0x5b')]]['sumHoldTime'];}this['channels'][_0x2dfa4a['uniqueid']]=_0x3fb80e;this['emitVoiceQueueChannelRemove'](_0x3fb80e);this[_0xa0ed('0x48')](this[_0xa0ed('0x12')][_0x3fb80e[_0xa0ed('0x5b')]]);}}ami['emit']('custom:voiceQueueReport',this['queueReports'][_0x2dfa4a['uniqueid']]);delete this['queueReports'][_0x2dfa4a[_0xa0ed('0x61')]];delete this['channels'][_0x2dfa4a[_0xa0ed('0x61')]];}if(this[_0xa0ed('0x38')][_0x2dfa4a[_0xa0ed('0x61')]]){delete this[_0xa0ed('0x38')][_0x2dfa4a[_0xa0ed('0x61')]];}}}catch(_0x3c1668){logger[_0xa0ed('0x35')]('[syncHangup][VoiceQueueReport]',util[_0xa0ed('0x3f')](_0x3c1668,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x23')]=function(_0x225094){try{if(this[_0xa0ed('0x5a')](_0x225094)){var _0x2075e9;if(this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xaf')]]){_0x2075e9=_[_0xa0ed('0x75')](this['queueReports'][_0x225094[_0xa0ed('0xaf')]]);_0x2075e9['transferexten']=_0x225094[_0xa0ed('0xb0')];_0x2075e9[_0xa0ed('0xb1')]=_0x225094[_0xa0ed('0xb2')];_0x2075e9[_0xa0ed('0x7e')]=_0xa0ed('0xb3');_0x2075e9['transfer']=!![];_0x2075e9[_0xa0ed('0x86')]='ATTENDED';if(this['queueReports'][_0x225094[_0xa0ed('0xb2')]]){var _0x5c9966=this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb2')]];this[_0xa0ed('0xf')][_0x225094['secondtransfereruniqueid']]=this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xaf')]];this['queueReports'][_0x225094[_0xa0ed('0xaf')]]=_0x5c9966;var _0x1d8ca2=_['last'](this['queueReports'][_0x225094[_0xa0ed('0xaf')]]);_0x1d8ca2[_0xa0ed('0x2f')]=!![];}}else if(this['queueReports'][_0x225094[_0xa0ed('0xb4')]]){_0x2075e9=_[_0xa0ed('0x75')](this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb4')]]);_0x2075e9[_0xa0ed('0x88')]=_0x225094[_0xa0ed('0xb5')];_0x2075e9[_0xa0ed('0xb1')]=_0x225094[_0xa0ed('0xb6')];_0x2075e9[_0xa0ed('0x7e')]=_0xa0ed('0xb3');_0x2075e9[_0xa0ed('0x7c')]=!![];_0x2075e9[_0xa0ed('0x86')]=_0xa0ed('0xb7');if(this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb6')]]){var _0x5c9966=this[_0xa0ed('0xf')][_0x225094['origtransfereruniqueid']];this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb6')]]=this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb4')]];this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb4')]]=_0x5c9966;var _0x1d8ca2=_['last'](this[_0xa0ed('0xf')][_0x225094[_0xa0ed('0xb4')]]);_0x1d8ca2[_0xa0ed('0x2f')]=!![];}}}}catch(_0x5c3832){logger[_0xa0ed('0x35')](_0xa0ed('0xb8'),util[_0xa0ed('0x3f')](_0x5c3832,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0x25')]=function(_0xb186aa){try{if(this[_0xa0ed('0x5a')](_0xb186aa)){if(this[_0xa0ed('0xf')][_0xb186aa[_0xa0ed('0xaf')]]){var _0x272eb9=_['last'](this[_0xa0ed('0xf')][_0xb186aa[_0xa0ed('0xaf')]]);_0x272eb9[_0xa0ed('0x7e')]=_0xa0ed('0xb9');_0x272eb9[_0xa0ed('0x7c')]=!![];_0x272eb9[_0xa0ed('0x86')]=_0xa0ed('0xba');_0x272eb9[_0xa0ed('0x88')]=_0xb186aa[_0xa0ed('0xbb')];_0x272eb9[_0xa0ed('0xb1')]=_0xb186aa['transfereeuniqueid'];this[_0xa0ed('0xbc')]({'event':_0xa0ed('0xbd'),'uniqueid':_0xb186aa[_0xa0ed('0xaf')],'context':_0xb186aa['context'],'channel':_0xb186aa[_0xa0ed('0xbe')]});}}}catch(_0x295a86){logger[_0xa0ed('0x35')](_0xa0ed('0xbf'),util[_0xa0ed('0x3f')](_0x295a86,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0xc0')]=function(_0x1a7c83){try{if(this[_0xa0ed('0x5a')](_0x1a7c83)){if(this['queueReports'][_0x1a7c83[_0xa0ed('0x61')]]){var _0x420c41=_['last'](this[_0xa0ed('0xf')][_0x1a7c83[_0xa0ed('0x61')]]);if(!_[_0xa0ed('0xc1')](_0x420c41[_0xa0ed('0x70')])){_0x420c41[_0xa0ed('0xc2')]=moment()['format'](_0xa0ed('0x64'));}}}}catch(_0x12a9fe){logger[_0xa0ed('0x35')]('[syncMusicOnHoldStart][VoiceQueueReport]',util[_0xa0ed('0x3f')](_0x12a9fe,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xa0ed('0xa')][_0xa0ed('0xc3')]=function(_0x34aa30){try{if(this[_0xa0ed('0x5a')](_0x34aa30)){if(this[_0xa0ed('0xf')][_0x34aa30[_0xa0ed('0x61')]]){var _0x273230=_[_0xa0ed('0x75')](this[_0xa0ed('0xf')][_0x34aa30['uniqueid']]);if(!_[_0xa0ed('0xc1')](_0x273230[_0xa0ed('0xc2')])){_0x273230['mohtime']+=moment()[_0xa0ed('0xab')](0x0)['diff'](_0x273230[_0xa0ed('0xc2')],_0xa0ed('0x84'));delete _0x273230[_0xa0ed('0xc2')];}}}}catch(_0x3d8946){logger[_0xa0ed('0x35')](_0xa0ed('0xc4'),util[_0xa0ed('0x3f')](_0x3d8946,{'showHidden':![],'depth':null}));}};module[_0xa0ed('0xc5')]=VoiceQueueReport;