Built motion from commit (unavailable).|2.5.0
[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 _0x983f=['info','[DEBUG]\x20Emit\x20voice_queue_channel:remove\x20event','stringify','emitVoiceQueueSummary','name','answered','available','loggedIn','sumBillable','sumDuration','sumHoldTime','total','type','unmanaged','abandoned','Trunk','callerid','Interval','voice_queue:save','isNotNull','[queues]','flagQueueSummary','[queuesummary]','queue','countBy','callers','toNumber','loggedin','custom:queuesummary','syncNewExten','uniqueid','inbound','queuecallerjoinAt','position','count','push','emitVoiceQueueChannelSave','[syncQueueCallerJoin][VoiceQueueReport]','inspect','last','queuecallercompleteAt','holdtime','originalposition','queuecallerabandonAt','YYYY-MM-DD\x20HH:mm:ss','queuecallerexitreason','ABANDONED','lastAssignedTo','[syncQueueCallerAbandon][VoiceQueueReport]','queuecallerleaveAt','connectedlinenum','connectedlinename','[syncQueueCallerLeave][VoiceQueueReport]','COMPLETEDBYAGENT','[syncAgentConnect][VoiceQueueReport]','assigned','membername','queuecallercomplete','queuecallerexit','queuecallerexitAt','transfer','reason','COMPLETED','startsWith','local/','linkedid','add','seconds','FORWARD','destexten','transferuniqueid','toUpperCase','[syncAgentComplete][VoiceQueueReport]','addVariable','keys','variable','value','queueposition','EXITWITHKEY','[syncVarSet][VoiceQueueReport]','rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','sipcallid','sipuri','bridgepeer','membercalls','memberdynamic','memberrealtime','includes','length','diff','milliseconds','lastevent','custom:queuecallerunmanaged','custom:queuecallerabandon','custom:voiceQueueReport','transfereeuniqueid','transferexten','secondtransfererexten','secondtransfereruniqueid','ATTENDEDTRANSFER','transfertype','ATTENDED','transfertargetuniqueid','origtransfereruniqueid','[syncAttendedTransfer][VoiceQueueReport]','extension','BlindTransfer','context','transfererchannel','[syncBlindTransfer][VoiceQueueReport]','syncMusicOnHoldStart','mohstarttime','[syncMusicOnHoldStart][VoiceQueueReport]','[syncMusicOnHoldStop][VoiceQueueReport]','exports','lodash','moment','bluebird','util','md5','ioredis','../../../config/environment','../../../config/logger','redis','defaults','localhost','socket.io-emitter','enqueue','tail','finally','sequence','queueReports','agents','channels','queueChannels','voiceQueues','campaigns','syncQueueSummary','bind','syncQueueSummaryComplete','syncQueueCallerJoin','queuecallerabandon','syncQueueCallerAbandon','syncQueueCallerLeave','syncAgentComplete','syncAgentConnect','varset','syncVarSet','hangup','syncHangup','fullybooted','syncFullyBooted','attendedtransfer','syncAttendedTransfer','blindtransfer','syncBlindTransfer','loopQueueSummary','loopQueueShow','isUndefined','isEmpty','hasOwnProperty','originated','talking','pTalking','waiting','queueStatusComplete','unlockRR','clearZombieChannels','switch','isNil','Action','channel','catch','message','No\x20such\x20channel','error','[voiceQueueReport][checkChannel]','variables','prototype','[FullyBooted]\x20clear\x20realtime','clearQueueReport','emitVoiceQueueChannelRemove','emit','format','voice:queue:%s','voice_queue_channel:save'];(function(_0x2ce6d5,_0x333e0c){var _0x32d272=function(_0x399f0b){while(--_0x399f0b){_0x2ce6d5['push'](_0x2ce6d5['shift']());}};_0x32d272(++_0x333e0c);}(_0x983f,0x137));var _0xf983=function(_0x17ec0a,_0x363e0b){_0x17ec0a=_0x17ec0a-0x0;var _0x3edff2=_0x983f[_0x17ec0a];return _0x3edff2;};'use strict';var _=require(_0xf983('0x0'));var moment=require(_0xf983('0x1'));var BPromise=require(_0xf983('0x2'));var util=require(_0xf983('0x3'));var md5=require(_0xf983('0x4'));var Redis=require(_0xf983('0x5'));var config=require(_0xf983('0x6'));var logger=require(_0xf983('0x7'))('ami');var ami=require('../ami');var QueueReport=require('../model/queueReport');config[_0xf983('0x8')]=_[_0xf983('0x9')](config[_0xf983('0x8')],{'host':_0xf983('0xa'),'port':0x18eb});var io=require(_0xf983('0xb'))(new Redis(config[_0xf983('0x8')]));var Sequence=function(){};Sequence['prototype'][_0xf983('0xc')]=function(_0x3dcc44){this['tail']=this[_0xf983('0xd')]?this[_0xf983('0xd')][_0xf983('0xe')](_0x3dcc44):_0x3dcc44();};function VoiceQueueReport(_0x425905){this[_0xf983('0xf')]=new Sequence();this[_0xf983('0x10')]={};this['agents']=_0x425905[_0xf983('0x11')];this[_0xf983('0x12')]=_0x425905[_0xf983('0x13')];this[_0xf983('0x14')]=_0x425905['voiceQueues'];this['flagQueueSummary']=!![];this[_0xf983('0x15')]=_0x425905[_0xf983('0x15')];this['variables']={};ami['on']('queuesummary',this[_0xf983('0x16')][_0xf983('0x17')](this));ami['on']('queuesummarycomplete',this[_0xf983('0x18')][_0xf983('0x17')](this));ami['on']('queuecallerjoin',this[_0xf983('0x19')][_0xf983('0x17')](this));ami['on'](_0xf983('0x1a'),this[_0xf983('0x1b')][_0xf983('0x17')](this));ami['on']('queuecallerleave',this[_0xf983('0x1c')]['bind'](this));ami['on']('agentcomplete',this[_0xf983('0x1d')][_0xf983('0x17')](this));ami['on']('agentconnect',this[_0xf983('0x1e')][_0xf983('0x17')](this));ami['on'](_0xf983('0x1f'),this[_0xf983('0x20')][_0xf983('0x17')](this));ami['on'](_0xf983('0x21'),this[_0xf983('0x22')][_0xf983('0x17')](this));ami['on'](_0xf983('0x23'),this[_0xf983('0x24')][_0xf983('0x17')](this));ami['on']('musiconholdstart',this['syncMusicOnHoldStart']['bind'](this));ami['on']('musiconholdstop',this['syncMusicOnHoldStop'][_0xf983('0x17')](this));ami['on'](_0xf983('0x25'),this[_0xf983('0x26')][_0xf983('0x17')](this));ami['on'](_0xf983('0x27'),this[_0xf983('0x28')][_0xf983('0x17')](this));this[_0xf983('0x29')]();this[_0xf983('0x2a')]();}function isNotNull(_0x3c1b5c){return _0x3c1b5c!==null&&!_[_0xf983('0x2b')](_0x3c1b5c);}function clearChannels(_0x2bf00b){if(!_[_0xf983('0x2c')](_0x2bf00b)){for(var _0x24ef36 in _0x2bf00b){if(_0x2bf00b[_0xf983('0x2d')](_0x24ef36)){delete _0x2bf00b[_0x24ef36];}}}}function clearCampaigns(_0x500f3f){if(!_['isEmpty'](_0x500f3f)){for(var _0x1621b1 in _0x500f3f){if(_0x500f3f[_0xf983('0x2d')](_0x1621b1)){_0x500f3f[_0x1621b1][_0xf983('0x2e')]=0x0;}}}}function clearVoiceQueues(_0x217706){if(!_['isEmpty'](_0x217706)){for(var _0x210462 in _0x217706){if(_0x217706['hasOwnProperty'](_0x210462)){_0x217706[_0x210462][_0xf983('0x2e')]=0x0;_0x217706[_0x210462][_0xf983('0x2f')]=0x0;_0x217706[_0x210462][_0xf983('0x30')]=0x0;_0x217706[_0x210462][_0xf983('0x31')]=0x0;_0x217706[_0x210462][_0xf983('0x32')]=!![];}}}}function clearAgentBooked(_0x8c92d){if(!_[_0xf983('0x2c')](_0x8c92d)){for(var _0x1bb7a9 in _0x8c92d){if(_0x8c92d[_0xf983('0x2d')](_0x1bb7a9)){_0x8c92d[_0x1bb7a9][_0xf983('0x33')]=!![];}}}}VoiceQueueReport['prototype'][_0xf983('0x34')]=function(){var _0x4f08a0=this;for(var _0x3f4437 in this[_0xf983('0x12')]){if(this['channels'][_0xf983('0x2d')](_0x3f4437)&&!this[_0xf983('0x12')][_0x3f4437][_0xf983('0x35')]){this['sequence']['enqueue'](function(){if(!_[_0xf983('0x36')](_0x4f08a0[_0xf983('0x12')][_0x3f4437])){return ami[_0xf983('0x37')]({'action':'status','channel':_0x4f08a0[_0xf983('0x12')][_0x3f4437][_0xf983('0x38')]})[_0xf983('0x39')](function(_0x37b9c1){if(_0x37b9c1[_0xf983('0x3a')]===_0xf983('0x3b')){setTimeout(function(){if(_0x4f08a0[_0xf983('0x12')][_0x3f4437]){delete _0x4f08a0['channels'][_0x3f4437];logger[_0xf983('0x3c')](_0xf983('0x3d'),_0x3f4437);}if(_0x4f08a0[_0xf983('0x10')][_0x3f4437]){delete _0x4f08a0[_0xf983('0x10')][_0x3f4437];logger[_0xf983('0x3c')]('[voiceQueueReport][checkQueueReport]',_0x3f4437);}if(_0x4f08a0[_0xf983('0x3e')][_0x3f4437]){delete _0x4f08a0['variables'][_0x3f4437];logger[_0xf983('0x3c')]('[voiceQueueReport][checkVariables]',_0x3f4437);}},0x1f40);}});}});}}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x24')]=function(){logger[_0xf983('0x3c')](_0xf983('0x40'));clearChannels(this[_0xf983('0x12')]);this[_0xf983('0x41')](this[_0xf983('0x10')]);clearAgentBooked(this['agents']);clearVoiceQueues(this[_0xf983('0x14')]);clearCampaigns(this[_0xf983('0x15')]);};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x41')]=function(_0x6f05ea){var _0x24067d=this;if(!_[_0xf983('0x2c')](_0x6f05ea)){for(var _0x44522b in _0x6f05ea){if(_0x6f05ea[_0xf983('0x2d')](_0x44522b)){_0x24067d[_0xf983('0x42')](_0x6f05ea[_0x44522b]);delete _0x6f05ea[_0x44522b];}}}};function loggerCatch(_0x155445){return function(_0x551135){logger['error'](_0x155445,util['inspect'](_0x551135,{'showHidden':![],'depth':null}));};}VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x43')]=function(_0x4e06ce,_0x26cf4d,_0x3960a1){io['to'](_0x4e06ce)[_0xf983('0x43')](_0x26cf4d,_0x3960a1);};VoiceQueueReport['prototype']['emitVoiceQueueChannelSave']=function(_0xeaa01){this[_0xf983('0x43')](util[_0xf983('0x44')](_0xf983('0x45'),_0xeaa01['name']),_0xf983('0x46'),_0xeaa01);};VoiceQueueReport['prototype'][_0xf983('0x42')]=function(_0x11a406){logger[_0xf983('0x47')](_0xf983('0x48'),JSON[_0xf983('0x49')](_0x11a406));this[_0xf983('0x43')](util[_0xf983('0x44')](_0xf983('0x45'),_0x11a406['name']),'voice_queue_channel:remove',_0x11a406);};VoiceQueueReport['prototype'][_0xf983('0x4a')]=function(_0x4bcf72){if(_0x4bcf72['type']==='inbound'){var _0xdde4a2={'id':_0x4bcf72['id'],'name':_0x4bcf72[_0xf983('0x4b')],'strategy':_0x4bcf72['strategy'],'answered':_0x4bcf72[_0xf983('0x4c')],'available':_0x4bcf72[_0xf983('0x4d')],'loggedIn':_0x4bcf72[_0xf983('0x4e')],'pTalking':_0x4bcf72[_0xf983('0x30')],'sumBillable':_0x4bcf72[_0xf983('0x4f')],'sumDuration':_0x4bcf72[_0xf983('0x50')],'sumHoldTime':_0x4bcf72[_0xf983('0x51')]||0x0,'talking':_0x4bcf72[_0xf983('0x2f')],'total':_0x4bcf72[_0xf983('0x52')],'type':_0x4bcf72[_0xf983('0x53')],'unmanaged':_0x4bcf72[_0xf983('0x54')],'abandoned':_0x4bcf72[_0xf983('0x55')],'waiting':_0x4bcf72[_0xf983('0x31')]};if(_0x4bcf72[_0xf983('0x56')]){_0xdde4a2['Trunk']={'id':_0x4bcf72['Trunk']['id'],'name':_0x4bcf72['Trunk'][_0xf983('0x4b')],'active':_0x4bcf72['Trunk']['active'],'callerid':_0x4bcf72[_0xf983('0x56')][_0xf983('0x57')]};}if(_0x4bcf72[_0xf983('0x58')]){_0xdde4a2['Interval']={'id':_0x4bcf72['Interval']['id'],'name':_0x4bcf72['Interval'][_0xf983('0x4b')]};}var _0x2f52ca=md5(JSON[_0xf983('0x49')](_0xdde4a2));if(_0x4bcf72[_0xf983('0x4')]!==_0x2f52ca){_0x4bcf72[_0xf983('0x4')]=_0x2f52ca;this['emit'](util[_0xf983('0x44')]('voice:queue:%s',_0xdde4a2[_0xf983('0x4b')]),_0xf983('0x59'),_0xdde4a2);}}};VoiceQueueReport['prototype'][_0xf983('0x5a')]=function(_0x1a5848){return _0x1a5848!==null&&!_[_0xf983('0x2b')](_0x1a5848);};VoiceQueueReport['prototype'][_0xf983('0x2a')]=function(){var _0x51d903=this;setInterval(function(){_0x51d903[_0xf983('0x34')]();ami[_0xf983('0x37')]({'action':'queues'})[_0xf983('0x39')](loggerCatch(_0xf983('0x5b')));},0x2710);};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x29')]=function(){var _0x17e427=this;setInterval(function(){if(_0x17e427[_0xf983('0x5c')]){return ami['Action']({'action':'queuesummary'})['then'](function(_0x453b0c){_0x17e427[_0xf983('0x5c')]=![];})['catch'](loggerCatch(_0xf983('0x5d')));}},0x3e8);};VoiceQueueReport[_0xf983('0x3f')]['syncQueueSummary']=function(_0x35e633){try{if(this[_0xf983('0x5a')](_0x35e633)&&this[_0xf983('0x5a')](_0x35e633['queue'])){if(this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]]){var _0x1e99fa=_[_0xf983('0x5f')](this[_0xf983('0x12')],_0xf983('0x5e'))[_0x35e633[_0xf983('0x5e')]]||0x0;var _0x22538f=_0x1e99fa-_0x35e633[_0xf983('0x60')];if(this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]]['waiting']!==_[_0xf983('0x61')](_0x35e633[_0xf983('0x60')])||this[_0xf983('0x14')][_0x35e633['queue']][_0xf983('0x4e')]!==_[_0xf983('0x61')](_0x35e633[_0xf983('0x62')])||this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]]['available']!==_[_0xf983('0x61')](_0x35e633['available'])||this[_0xf983('0x14')][_0x35e633['queue']][_0xf983('0x2f')]!==_0x22538f){this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]]['waiting']=_[_0xf983('0x61')](_0x35e633[_0xf983('0x60')]);this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]][_0xf983('0x4e')]=_[_0xf983('0x61')](_0x35e633[_0xf983('0x62')]);this[_0xf983('0x14')][_0x35e633['queue']][_0xf983('0x4d')]=_['toNumber'](_0x35e633[_0xf983('0x4d')]);this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]]['talking']=_0x22538f>0x0?_0x22538f:0x0;this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]][_0xf983('0x2f')]=this[_0xf983('0x14')][_0x35e633[_0xf983('0x5e')]][_0xf983('0x2f')]>_[_0xf983('0x61')](_0x35e633[_0xf983('0x62')])?_[_0xf983('0x61')](_0x35e633[_0xf983('0x62')]):this['voiceQueues'][_0x35e633['queue']][_0xf983('0x2f')];this['emitVoiceQueueSummary'](this['voiceQueues'][_0x35e633['queue']]);}ami[_0xf983('0x43')](_0xf983('0x63'),this['voiceQueues'][_0x35e633['queue']]);}}}catch(_0x21aaea){logger[_0xf983('0x3c')]('[syncQueueSummary][VoiceQueueReport]',util['inspect'](_0x21aaea,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x18')]=function(_0x5958cc){this[_0xf983('0x5c')]=!![];};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x64')]=function(_0x23493f){};VoiceQueueReport['prototype'][_0xf983('0x19')]=function(_0x9390bb){try{if(this[_0xf983('0x5a')](_0x9390bb)){if(_[_0xf983('0x2b')](this[_0xf983('0x10')][_0x9390bb[_0xf983('0x65')]])){this['queueReports'][_0x9390bb[_0xf983('0x65')]]=[];this['channels'][_0x9390bb[_0xf983('0x65')]]={};}var _0x2c33e8=new QueueReport();_0x2c33e8['name']=_0x9390bb[_0xf983('0x5e')];_0x2c33e8[_0xf983('0x53')]=this[_0xf983('0x14')][_0x2c33e8['name']]&&this[_0xf983('0x14')][_0x2c33e8[_0xf983('0x4b')]]['type']?this['voiceQueues'][_0x2c33e8['name']]['type']||_0xf983('0x66'):_0xf983('0x66');_0x2c33e8[_0xf983('0x5e')]=_0x9390bb[_0xf983('0x5e')];_0x2c33e8[_0xf983('0x67')]=moment()[_0xf983('0x44')]('YYYY-MM-DD\x20HH:mm:ss');_0x2c33e8[_0xf983('0x68')]=_0x9390bb[_0xf983('0x68')];_0x2c33e8[_0xf983('0x69')]=_0x9390bb[_0xf983('0x69')];_['merge'](_0x2c33e8,_['pick'](_0x9390bb,_['keys'](_0x2c33e8)));this[_0xf983('0x10')][_0x9390bb[_0xf983('0x65')]][_0xf983('0x6a')](_0x2c33e8);this['channels'][_0x9390bb[_0xf983('0x65')]]=_0x2c33e8;this[_0xf983('0x6b')](_0x2c33e8);}}catch(_0xaa1d04){logger[_0xf983('0x3c')](_0xf983('0x6c'),util[_0xf983('0x6d')](_0xaa1d04,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x1b')]=function(_0x327848){try{if(this[_0xf983('0x5a')](_0x327848)){if(this[_0xf983('0x10')][_0x327848['uniqueid']]){var _0x12564f=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x327848[_0xf983('0x65')]]);_0x12564f['queuecallercomplete']=![];_0x12564f[_0xf983('0x6f')]=null;_0x12564f[_0xf983('0x70')]=_0x327848[_0xf983('0x70')];_0x12564f[_0xf983('0x71')]=_0x327848['originalposition'];_0x12564f[_0xf983('0x1a')]=!![];_0x12564f[_0xf983('0x72')]=moment()[_0xf983('0x44')](_0xf983('0x73'));_0x12564f[_0xf983('0x74')]=_0xf983('0x75');_0x12564f[_0xf983('0x76')]=null;this[_0xf983('0x12')][_0x327848[_0xf983('0x65')]]=_0x12564f;this[_0xf983('0x42')](_0x12564f);}}}catch(_0x3d93c7){logger['error'](_0xf983('0x77'),util[_0xf983('0x6d')](_0x3d93c7,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x1c')]=function(_0x462408){try{if(this[_0xf983('0x5a')](_0x462408)){if(this['queueReports'][_0x462408[_0xf983('0x65')]]){var _0x7ee92e=_['last'](this[_0xf983('0x10')][_0x462408[_0xf983('0x65')]]);_0x7ee92e[_0xf983('0x78')]=moment()[_0xf983('0x44')](_0xf983('0x73'));_0x7ee92e['connectedlinenum']=_0x462408[_0xf983('0x79')];_0x7ee92e[_0xf983('0x7a')]=_0x462408[_0xf983('0x7a')];this[_0xf983('0x12')][_0x462408[_0xf983('0x65')]]=_0x7ee92e;this[_0xf983('0x6b')](_0x7ee92e);}}}catch(_0x3ce511){logger[_0xf983('0x3c')](_0xf983('0x7b'),util[_0xf983('0x6d')](_0x3ce511,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x1e')]=function(_0x20c67d){try{if(this[_0xf983('0x5a')](_0x20c67d)){if(this[_0xf983('0x10')][_0x20c67d['uniqueid']]){var _0x327a9a=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x20c67d[_0xf983('0x65')]]);_0x327a9a['queuecallercomplete']=!![];_0x327a9a[_0xf983('0x74')]=_0xf983('0x7c');}}}catch(_0x34c32a){logger[_0xf983('0x3c')](_0xf983('0x7d'),util[_0xf983('0x6d')](_0x34c32a,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x1d')]=function(_0x2bf5b1){try{if(this[_0xf983('0x5a')](_0x2bf5b1)){if(this[_0xf983('0x10')][_0x2bf5b1[_0xf983('0x65')]]){var _0x1e3353=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x2bf5b1[_0xf983('0x65')]]);_0x1e3353[_0xf983('0x1a')]=![];_0x1e3353['queuecallerabandonAt']=null;_0x1e3353[_0xf983('0x7e')]=!![];_0x1e3353['lastAssignedTo']=_0x2bf5b1[_0xf983('0x7f')];_0x1e3353[_0xf983('0x70')]=_0x2bf5b1['holdtime'];_0x1e3353[_0xf983('0x80')]=!![];_0x1e3353[_0xf983('0x81')]=![];_0x1e3353[_0xf983('0x82')]=null;if(!_0x1e3353[_0xf983('0x83')]){if(_0x2bf5b1[_0xf983('0x84')]==_0xf983('0x83')){_0x1e3353[_0xf983('0x74')]=_0xf983('0x85');}else{if(_[_0xf983('0x86')](_0x2bf5b1[_0xf983('0x38')]['toLowerCase'](),_0xf983('0x87'))){if(this[_0xf983('0x10')][_0x2bf5b1[_0xf983('0x88')]]){var _0x1adae8=_['last'](this['queueReports'][_0x2bf5b1[_0xf983('0x88')]]);_0x1adae8[_0xf983('0x80')]=![];_0x1adae8['queuecallerexit']=!![];_0x1adae8[_0xf983('0x82')]=moment(_0x1e3353[_0xf983('0x67')])[_0xf983('0x89')](_0x2bf5b1[_0xf983('0x70')],_0xf983('0x8a'))['format']('YYYY-MM-DD\x20HH:mm:ss');_0x1adae8['queuecallerexitreason']='FORWARDTRANSFER';_0x1adae8[_0xf983('0x83')]=!![];_0x1adae8['transfertype']=_0xf983('0x8b');_0x1adae8['transferexten']=_0x2bf5b1[_0xf983('0x8c')];_0x1adae8[_0xf983('0x8d')]=_0x2bf5b1[_0xf983('0x65')];var _0xc1ff5f=this['queueReports'][_0x2bf5b1[_0xf983('0x88')]];this[_0xf983('0x10')][_0x2bf5b1[_0xf983('0x88')]]=this[_0xf983('0x10')][_0x2bf5b1[_0xf983('0x65')]];this[_0xf983('0x10')][_0x2bf5b1[_0xf983('0x65')]]=_0xc1ff5f;}}else{_0x1e3353[_0xf983('0x74')]='COMPLETEDBY'+_0x2bf5b1[_0xf983('0x84')][_0xf983('0x8e')]();}}}this[_0xf983('0x12')][_0x2bf5b1[_0xf983('0x65')]]=_0x1e3353;this[_0xf983('0x42')](_0x1e3353);}}}catch(_0x39833c){logger[_0xf983('0x3c')](_0xf983('0x8f'),util[_0xf983('0x6d')](_0x39833c,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x20')]=function(_0x1941c6){try{if(this[_0xf983('0x5a')](_0x1941c6)){this[_0xf983('0x90')](_0x1941c6[_0xf983('0x65')],_[_0xf983('0x91')](_0x1941c6[_0xf983('0x92')])[0x0],_0x1941c6[_0xf983('0x93')]);if(this[_0xf983('0x10')][_0x1941c6[_0xf983('0x65')]]){var _0x5104b=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x1941c6[_0xf983('0x65')]]);if(_0x5104b){if(this[_0xf983('0x5a')](_0x1941c6[_0xf983('0x92')])&&this[_0xf983('0x5a')](_0x1941c6['variable']['queuestatus'])){switch(_0x1941c6[_0xf983('0x93')]){case'CONTINUE':_0x5104b['queuecallerexit']=![];_0x5104b['queuecallerexitAt']=null;break;default:_0x5104b[_0xf983('0x81')]=!![];_0x5104b['queuecallerexitAt']=moment()['format']('YYYY-MM-DD\x20HH:mm:ss');_0x5104b[_0xf983('0x78')]=moment()['format']('YYYY-MM-DD\x20HH:mm:ss');}_0x5104b[_0xf983('0x1a')]=![];_0x5104b[_0xf983('0x72')]=null;_0x5104b['queuecallerexitreason']=_0x1941c6[_0xf983('0x93')];this[_0xf983('0x12')][_0x1941c6[_0xf983('0x65')]]=_0x5104b;this[_0xf983('0x42')](_0x5104b);}else if(this['isNotNull'](_0x1941c6[_0xf983('0x92')])&&this[_0xf983('0x5a')](_0x1941c6[_0xf983('0x92')][_0xf983('0x94')])){if(!_0x5104b['queuecallerabandon']){_0x5104b[_0xf983('0x81')]=!![];_0x5104b[_0xf983('0x82')]=moment()[_0xf983('0x44')](_0xf983('0x73'));_0x5104b[_0xf983('0x74')]=_0xf983('0x95');_0x5104b[_0xf983('0x78')]=moment()['format'](_0xf983('0x73'));this[_0xf983('0x12')][_0x1941c6[_0xf983('0x65')]]=_0x5104b;}}_0x5104b[_0xf983('0x3e')]=this[_0xf983('0x3e')][_0x1941c6[_0xf983('0x65')]];}}}}catch(_0x3d0d46){logger[_0xf983('0x3c')](_0xf983('0x96'),util['inspect'](_0x3d0d46,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')]['addVariable']=function(_0x834d6b,_0x2fe3ca,_0x3a12db){var _0x392a3f=[_0xf983('0x97'),_0xf983('0x98'),_0xf983('0x99'),_0xf983('0x9a'),_0xf983('0x9b'),_0xf983('0x9c'),'rtpaudioqosrtt','rtpaudioqosrttbridged',_0xf983('0x9d'),_0xf983('0x9e'),_0xf983('0x9f'),'bridgepvtcallid',_0xf983('0xa0'),_0xf983('0xa1'),'memberinterface','memberlastcall','membername','memberpenalty',_0xf983('0xa2')];if(!_[_0xf983('0x36')](_0x2fe3ca)&&!_[_0xf983('0xa3')](_0x392a3f,_0x2fe3ca)){if(_[_0xf983('0x2b')](this[_0xf983('0x3e')][_0x834d6b])){this[_0xf983('0x3e')][_0x834d6b]={};}this[_0xf983('0x3e')][_0x834d6b][_0x2fe3ca]=_0x3a12db;}};VoiceQueueReport[_0xf983('0x3f')]['syncHangup']=function(_0x50aadf){try{if(this[_0xf983('0x5a')](_0x50aadf)){if(this['queueReports'][_0x50aadf['uniqueid']]){for(var _0x29964b=0x0,_0x2ec0e2={};_0x29964b<this[_0xf983('0x10')][_0x50aadf[_0xf983('0x65')]][_0xf983('0xa4')];_0x29964b+=0x1){_0x2ec0e2=this[_0xf983('0x10')][_0x50aadf[_0xf983('0x65')]][_0x29964b];if(this[_0xf983('0x14')][_0x2ec0e2['queue']]){if(_0x2ec0e2['queuecallerexit']){this[_0xf983('0x14')][_0x2ec0e2[_0xf983('0x5e')]][_0xf983('0x54')]+=0x1;}if(_0x2ec0e2['queuecallerabandon']){this[_0xf983('0x14')][_0x2ec0e2[_0xf983('0x5e')]]['abandoned']+=0x1;}this[_0xf983('0x14')][_0x2ec0e2['queue']][_0xf983('0x51')]+=moment(_0x2ec0e2[_0xf983('0x78')])[_0xf983('0xa5')](_0x2ec0e2['queuecallerjoinAt'],_0xf983('0x8a'))||0x0;if(_0x29964b===this[_0xf983('0x10')][_0x50aadf[_0xf983('0x65')]][_0xf983('0xa4')]-0x1){this[_0xf983('0x14')][_0x2ec0e2[_0xf983('0x5e')]]['sumDuration']+=moment()[_0xf983('0xa6')](0x0)['diff'](_0x2ec0e2[_0xf983('0x67')],'seconds');this['voiceQueues'][_0x2ec0e2['queue']][_0xf983('0x52')]+=0x1;if(_0x2ec0e2['queuecallercomplete']){this[_0xf983('0x14')][_0x2ec0e2['queue']]['answered']+=0x1;this['voiceQueues'][_0x2ec0e2[_0xf983('0x5e')]][_0xf983('0x4f')]+=moment()[_0xf983('0xa6')](0x0)['diff'](_0x2ec0e2[_0xf983('0x78')],'seconds');_0x2ec0e2[_0xf983('0x6f')]=moment()[_0xf983('0x44')](_0xf983('0x73'));_0x2ec0e2[_0xf983('0x81')]=![];_0x2ec0e2[_0xf983('0x82')]=null;}if(_0x2ec0e2[_0xf983('0x81')]){_0x2ec0e2[_0xf983('0xa7')]='unmanaged';ami['emit'](_0xf983('0xa8'),_0x2ec0e2);}if(_0x2ec0e2[_0xf983('0x1a')]){_0x2ec0e2['lastevent']=_0xf983('0x55');ami[_0xf983('0x43')](_0xf983('0xa9'),_0x2ec0e2);}}else{this[_0xf983('0x14')][_0x2ec0e2[_0xf983('0x5e')]][_0xf983('0x50')]+=this[_0xf983('0x14')][_0x2ec0e2[_0xf983('0x5e')]][_0xf983('0x51')];}this[_0xf983('0x12')][_0x50aadf[_0xf983('0x65')]]=_0x2ec0e2;this['emitVoiceQueueChannelRemove'](_0x2ec0e2);this['emitVoiceQueueSummary'](this['voiceQueues'][_0x2ec0e2['queue']]);}}ami[_0xf983('0x43')](_0xf983('0xaa'),this['queueReports'][_0x50aadf[_0xf983('0x65')]]);delete this['queueReports'][_0x50aadf[_0xf983('0x65')]];delete this[_0xf983('0x12')][_0x50aadf[_0xf983('0x65')]];}if(this[_0xf983('0x3e')][_0x50aadf[_0xf983('0x65')]]){delete this[_0xf983('0x3e')][_0x50aadf[_0xf983('0x65')]];}}}catch(_0x336ece){logger[_0xf983('0x3c')]('[syncHangup][VoiceQueueReport]',util[_0xf983('0x6d')](_0x336ece,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0x26')]=function(_0x5a7e5d){try{if(this['isNotNull'](_0x5a7e5d)){var _0xd6c988;if(this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xab')]]){_0xd6c988=_['last'](this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xab')]]);_0xd6c988[_0xf983('0xac')]=_0x5a7e5d[_0xf983('0xad')];_0xd6c988['transferuniqueid']=_0x5a7e5d[_0xf983('0xae')];_0xd6c988['queuecallerexitreason']=_0xf983('0xaf');_0xd6c988[_0xf983('0x83')]=!![];_0xd6c988[_0xf983('0xb0')]=_0xf983('0xb1');if(this['queueReports'][_0x5a7e5d[_0xf983('0xae')]]){var _0x4c63e4=this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xae')]];this['queueReports'][_0x5a7e5d[_0xf983('0xae')]]=this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xab')]];this['queueReports'][_0x5a7e5d[_0xf983('0xab')]]=_0x4c63e4;var _0x324f71=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xab')]]);_0x324f71['switch']=!![];}}else if(this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xb2')]]){_0xd6c988=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x5a7e5d['transfertargetuniqueid']]);_0xd6c988['transferexten']=_0x5a7e5d['origtransfererexten'];_0xd6c988[_0xf983('0x8d')]=_0x5a7e5d['origtransfereruniqueid'];_0xd6c988['queuecallerexitreason']=_0xf983('0xaf');_0xd6c988[_0xf983('0x83')]=!![];_0xd6c988['transfertype']='ATTENDED';if(this[_0xf983('0x10')][_0x5a7e5d['origtransfereruniqueid']]){var _0x4c63e4=this['queueReports'][_0x5a7e5d['origtransfereruniqueid']];this['queueReports'][_0x5a7e5d[_0xf983('0xb3')]]=this['queueReports'][_0x5a7e5d[_0xf983('0xb2')]];this[_0xf983('0x10')][_0x5a7e5d[_0xf983('0xb2')]]=_0x4c63e4;var _0x324f71=_[_0xf983('0x6e')](this['queueReports'][_0x5a7e5d[_0xf983('0xb2')]]);_0x324f71[_0xf983('0x35')]=!![];}}}}catch(_0x1d5db2){logger[_0xf983('0x3c')](_0xf983('0xb4'),util['inspect'](_0x1d5db2,{'showHidden':![],'depth':null}));}};VoiceQueueReport['prototype']['syncBlindTransfer']=function(_0x2b08e2){try{if(this[_0xf983('0x5a')](_0x2b08e2)){if(this[_0xf983('0x10')][_0x2b08e2['transfereeuniqueid']]){var _0x11309a=_['last'](this['queueReports'][_0x2b08e2[_0xf983('0xab')]]);_0x11309a[_0xf983('0x74')]='BLINDTRANSFER';_0x11309a[_0xf983('0x83')]=!![];_0x11309a['transfertype']='BLIND';_0x11309a[_0xf983('0xac')]=_0x2b08e2[_0xf983('0xb5')];_0x11309a[_0xf983('0x8d')]=_0x2b08e2[_0xf983('0xab')];this[_0xf983('0x22')]({'event':_0xf983('0xb6'),'uniqueid':_0x2b08e2[_0xf983('0xab')],'context':_0x2b08e2[_0xf983('0xb7')],'channel':_0x2b08e2[_0xf983('0xb8')]});}}}catch(_0x523c5c){logger[_0xf983('0x3c')](_0xf983('0xb9'),util[_0xf983('0x6d')](_0x523c5c,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')][_0xf983('0xba')]=function(_0x2c0d78){try{if(this[_0xf983('0x5a')](_0x2c0d78)){if(this[_0xf983('0x10')][_0x2c0d78[_0xf983('0x65')]]){var _0x301fd3=_[_0xf983('0x6e')](this[_0xf983('0x10')][_0x2c0d78[_0xf983('0x65')]]);if(!_['isNil'](_0x301fd3[_0xf983('0x78')])){_0x301fd3[_0xf983('0xbb')]=moment()[_0xf983('0x44')](_0xf983('0x73'));}}}}catch(_0x22dbb8){logger[_0xf983('0x3c')](_0xf983('0xbc'),util[_0xf983('0x6d')](_0x22dbb8,{'showHidden':![],'depth':null}));}};VoiceQueueReport[_0xf983('0x3f')]['syncMusicOnHoldStop']=function(_0x45fe58){try{if(this[_0xf983('0x5a')](_0x45fe58)){if(this[_0xf983('0x10')][_0x45fe58[_0xf983('0x65')]]){var _0x588026=_[_0xf983('0x6e')](this['queueReports'][_0x45fe58[_0xf983('0x65')]]);if(!_[_0xf983('0x36')](_0x588026[_0xf983('0xbb')])){_0x588026['mohtime']+=moment()[_0xf983('0xa6')](0x0)[_0xf983('0xa5')](_0x588026[_0xf983('0xbb')],_0xf983('0x8a'));delete _0x588026[_0xf983('0xbb')];}}}}catch(_0x269f9f){logger[_0xf983('0x3c')](_0xf983('0xbd'),util[_0xf983('0x6d')](_0x269f9f,{'showHidden':![],'depth':null}));}};module[_0xf983('0xbe')]=VoiceQueueReport;