Built motion from commit b5413ace.|2.6.9
[motion2.git] / server / services / ami / report / voiceAgentReport.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 _0x3c7a=['[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','membername','destuniqueid','debug','[%s][voiceAgentReport][agentcalled]\x20event:','uniqueid','inspect','isUndefined','format','called','queue','mandatoryDisposition','inbound','voice','merge','omit','event','privilege','[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:','custom:agentcalled','interface','calleridnum','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:','user:called','error','[%s][voiceAgentReport][agentcalled]','hasOwnProperty','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect','agentconnectAt','YYYY-MM-DD\x20HH:mm:ss','connectedlinename','connectedlinenum','destchannelstate','destchannelstatedesc','holdtime','lastevent','connect','routealias','destconnectedlinenum','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentconnect\x20event:','custom:agentconnect','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:agentconnect\x20event:','agentringnoanswer','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere','agentringnoanswerAt','answeredelsewheremembername','answered_elsewhere','custom:agentansweredelsewhere','[%s][voiceAgentReport][agentconnect]','[%s][voiceAgentReport][agentringnoanswer]\x20event:','[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected','rejected','reason','custom:agentringnoanswer','syncQueueCallerAbandon','abandoned','custom:agentqueuecallerabandon','[%s][voiceAgentReport][queuecallerabandon]','[%s][voiceAgentReport][agentcomplete]\x20event:','[%s][voiceAgentReport][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agent','acw','acwtime','acwTimeout','custom:agentcomplete','destaccountcode','user:%s','[%s][voiceAgentReport][varset]\x20event:','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','keys','variable','value','[%s][voiceAgentReport][varset]','addVariable','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqosrtt','rtpaudioqosrttbridged','sipcallid','sipuri','membercalls','memberdynamic','memberinterface','memberlastcall','memberpenalty','isNil','includes','transfer','[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:','values','custom:voiceAgentReport','[%s][voiceAgentReport][attendedtransfer]\x20event:','transfereeuniqueid','origtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','secondtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]','[%s][voiceAgentReport][blindtransfer]\x20event:','transfereruniqueid','complete','talktime','seconds','[%s][voiceAgentReport][blindtransfer]','[%s][voiceAgentReport][musiconholdstart]\x20event:','channel','substring','lastIndexOf','[%s][voiceAgentReport][musiconholdstart]\x20interface:%s','onhold','[%s][voiceAgentReport][musiconholdstart]','syncMusicOnHoldStop','[%s][voiceAgentReport][musiconholdstop]\x20event:','[%s][voiceAgentReport][musiconholdstop]\x20interface:%s','[%s][voiceAgentReport][musiconholdstop]','exports','lodash','moment','ioredis','../../../config/environment','../../../config/logger','ami','../ami','defaults','redis','socket.io-emitter','channels','voiceChannels','voiceQueues','agents','variables','agentcalled','bind','syncAgentConnect','syncAgentRingNoAnswer','queuecallerabandon','agentcomplete','syncAgentComplete','syncVarSet','hangup','syncHangup','musiconholdstart','syncMusicOnHoldStart','musiconholdstop','syncAttendedTransfer','blindtransfer','syncBlindTransfer','prototype','emit','isNotNull','syncAgentCalled','info'];(function(_0x42cae2,_0x284ef8){var _0x5f256f=function(_0x41abc8){while(--_0x41abc8){_0x42cae2['push'](_0x42cae2['shift']());}};_0x5f256f(++_0x284ef8);}(_0x3c7a,0x1a7));var _0xa3c7=function(_0x509fb2,_0x541f31){_0x509fb2=_0x509fb2-0x0;var _0x1b1072=_0x3c7a[_0x509fb2];return _0x1b1072;};'use strict';var _=require(_0xa3c7('0x0'));var moment=require(_0xa3c7('0x1'));var util=require('util');var Redis=require(_0xa3c7('0x2'));var config=require(_0xa3c7('0x3'));var logger=require(_0xa3c7('0x4'))(_0xa3c7('0x5'));var ami=require(_0xa3c7('0x6'));config['redis']=_[_0xa3c7('0x7')](config[_0xa3c7('0x8')],{'host':'localhost','port':0x18eb});var io=require(_0xa3c7('0x9'))(new Redis(config[_0xa3c7('0x8')]));function VoiceAgentReport(_0x279fdc){this[_0xa3c7('0xa')]={};this[_0xa3c7('0xb')]=_0x279fdc[_0xa3c7('0xa')];this['voiceQueues']=_0x279fdc[_0xa3c7('0xc')];this[_0xa3c7('0xd')]=_0x279fdc[_0xa3c7('0xd')];this[_0xa3c7('0xe')]={};ami['on'](_0xa3c7('0xf'),this['syncAgentCalled'][_0xa3c7('0x10')](this));ami['on']('agentconnect',this[_0xa3c7('0x11')][_0xa3c7('0x10')](this));ami['on']('agentringnoanswer',this[_0xa3c7('0x12')][_0xa3c7('0x10')](this));ami['on'](_0xa3c7('0x13'),this['syncQueueCallerAbandon'][_0xa3c7('0x10')](this));ami['on'](_0xa3c7('0x14'),this[_0xa3c7('0x15')][_0xa3c7('0x10')](this));ami['on']('varset',this[_0xa3c7('0x16')][_0xa3c7('0x10')](this));ami['on'](_0xa3c7('0x17'),this[_0xa3c7('0x18')][_0xa3c7('0x10')](this));ami['on'](_0xa3c7('0x19'),this[_0xa3c7('0x1a')]['bind'](this));ami['on'](_0xa3c7('0x1b'),this['syncMusicOnHoldStop'][_0xa3c7('0x10')](this));ami['on']('attendedtransfer',this[_0xa3c7('0x1c')][_0xa3c7('0x10')](this));ami['on'](_0xa3c7('0x1d'),this[_0xa3c7('0x1e')][_0xa3c7('0x10')](this));}VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x20')]=function(_0x3148a0,_0x2f075a,_0xf02dbd){io['to'](_0x3148a0)['emit'](_0x2f075a,_0xf02dbd);};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x21')]=function(_0x3b70cd){return _0x3b70cd!==null&&!_['isUndefined'](_0x3b70cd);};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x22')]=function(_0x4d143e){try{if(this[_0xa3c7('0x21')](_0x4d143e)){logger[_0xa3c7('0x23')](_0xa3c7('0x24'),_0x4d143e['uniqueid'],_0x4d143e[_0xa3c7('0x25')],_0x4d143e[_0xa3c7('0x26')]);logger[_0xa3c7('0x27')](_0xa3c7('0x28'),_0x4d143e[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x4d143e,{'showHidden':![],'depth':null}));if(_['isUndefined'](this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]])){this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]]={};}if(_[_0xa3c7('0x2b')](this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]][_0x4d143e[_0xa3c7('0x26')]])){this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]][_0x4d143e[_0xa3c7('0x26')]]={'agentcalledAt':moment()[_0xa3c7('0x2c')]('YYYY-MM-DD\x20HH:mm:ss'),'lastevent':_0xa3c7('0x2d'),'mandatoryDisposition':this[_0xa3c7('0xc')][_0x4d143e[_0xa3c7('0x2e')]]?this[_0xa3c7('0xc')][_0x4d143e[_0xa3c7('0x2e')]][_0xa3c7('0x2f')]||![]:![],'type':this[_0xa3c7('0xc')][_0x4d143e[_0xa3c7('0x2e')]]?this[_0xa3c7('0xc')][_0x4d143e[_0xa3c7('0x2e')]]['type']||_0xa3c7('0x30'):'inbound','variables':this[_0xa3c7('0xe')][_0x4d143e[_0xa3c7('0x29')]],'motionChannel':_0xa3c7('0x31')};}_[_0xa3c7('0x32')](this['channels'][_0x4d143e['uniqueid']][_0x4d143e[_0xa3c7('0x26')]],_[_0xa3c7('0x33')](_0x4d143e,[_0xa3c7('0x34'),_0xa3c7('0x35')]));logger[_0xa3c7('0x27')](_0xa3c7('0x36'),_0x4d143e['uniqueid'],util[_0xa3c7('0x2a')](this['channels'][_0x4d143e[_0xa3c7('0x29')]][_0x4d143e[_0xa3c7('0x26')]],{'showHidden':![],'depth':null}));ami[_0xa3c7('0x20')](_0xa3c7('0x37'),this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]][_0x4d143e[_0xa3c7('0x26')]]);var _0x30657b={'id':this['agents'][_0x4d143e[_0xa3c7('0x38')]]['id'],'calleridnum':this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]][_0x4d143e[_0xa3c7('0x26')]][_0xa3c7('0x39')],'queue':this[_0xa3c7('0xa')][_0x4d143e[_0xa3c7('0x29')]][_0x4d143e[_0xa3c7('0x26')]][_0xa3c7('0x2e')],'variables':this['channels'][_0x4d143e['uniqueid']][_0x4d143e[_0xa3c7('0x26')]][_0xa3c7('0xe')]};logger['debug'](_0xa3c7('0x3a'),_0x4d143e[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x30657b,{'showHidden':![],'depth':null}));this[_0xa3c7('0x20')](util[_0xa3c7('0x2c')]('user:%s',_0x4d143e[_0xa3c7('0x25')]),_0xa3c7('0x3b'),_0x30657b);}}catch(_0x1eefa4){logger[_0xa3c7('0x3c')](_0xa3c7('0x3d'),_0x4d143e[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x1eefa4,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x11')]=function(_0x12aa09){try{if(this[_0xa3c7('0x21')](_0x12aa09)){if(this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]]){logger['debug']('[%s][voiceAgentReport][agentconnect]\x20event:',_0x12aa09['uniqueid'],util[_0xa3c7('0x2a')](_0x12aa09,{'showHidden':![],'depth':null}));for(var _0x3f9fbd in this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]]){if(this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0xa3c7('0x3e')](_0x3f9fbd)){if(_0x12aa09['destuniqueid']===_0x3f9fbd){logger[_0xa3c7('0x23')](_0xa3c7('0x3f'),_0x12aa09['uniqueid'],_0x12aa09[_0xa3c7('0x25')],_0x12aa09[_0xa3c7('0x26')]);this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x40')]=moment()[_0xa3c7('0x2c')](_0xa3c7('0x41'));this['channels'][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x42')]=_0x12aa09[_0xa3c7('0x42')];this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x43')]=_0x12aa09[_0xa3c7('0x43')];this[_0xa3c7('0xa')][_0x12aa09['uniqueid']][_0x3f9fbd][_0xa3c7('0x44')]=_0x12aa09[_0xa3c7('0x44')];this['channels'][_0x12aa09['uniqueid']][_0x3f9fbd][_0xa3c7('0x45')]=_0x12aa09[_0xa3c7('0x45')];this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x46')]=_0x12aa09[_0xa3c7('0x46')];this[_0xa3c7('0xa')][_0x12aa09['uniqueid']][_0x3f9fbd][_0xa3c7('0x47')]=_0xa3c7('0x48');if(this[_0xa3c7('0xb')][this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x29')]]){var _0x3809a0=this[_0xa3c7('0xb')][this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x29')]][_0xa3c7('0x49')];this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x49')]=_0x3809a0;_0x12aa09[_0xa3c7('0x49')]=_0x3809a0;}_['merge'](this[_0xa3c7('0xd')][_0x12aa09[_0xa3c7('0x38')]],_['pick'](_0x12aa09,['queue',_0xa3c7('0x4a'),'routealias']));logger['debug'](_0xa3c7('0x4b'),_0x12aa09['uniqueid'],util[_0xa3c7('0x2a')](this['channels'][_0x12aa09['uniqueid']][_0x12aa09[_0xa3c7('0x26')]],{'showHidden':![],'depth':null}));ami[_0xa3c7('0x20')](_0xa3c7('0x4c'),this[_0xa3c7('0xa')][_0x12aa09['uniqueid']][_0x12aa09[_0xa3c7('0x26')]]);logger[_0xa3c7('0x27')](_0xa3c7('0x4d'),_0x12aa09['uniqueid'],util[_0xa3c7('0x2a')](this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x12aa09[_0xa3c7('0x26')]],{'showHidden':![],'depth':null}));this[_0xa3c7('0x20')](util[_0xa3c7('0x2c')]('user:%s',_0x12aa09[_0xa3c7('0x25')]),'user:agentconnect',this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x12aa09[_0xa3c7('0x26')]]);}else if(!this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x4e')]&&!this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x14')]){logger[_0xa3c7('0x23')](_0xa3c7('0x4f'),_0x12aa09[_0xa3c7('0x29')],this['channels'][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x25')],_0x3f9fbd);this['channels'][_0x12aa09['uniqueid']][_0x3f9fbd][_0xa3c7('0x4e')]=!![];this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x50')]=moment()[_0xa3c7('0x2c')](_0xa3c7('0x41'));this['channels'][_0x12aa09['uniqueid']][_0x3f9fbd]['answeredelsewheredestinationuniqueid']=_0x12aa09[_0xa3c7('0x26')];this[_0xa3c7('0xa')][_0x12aa09['uniqueid']][_0x3f9fbd][_0xa3c7('0x51')]=_0x12aa09[_0xa3c7('0x25')];this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd][_0xa3c7('0x47')]=_0xa3c7('0x52');this['channels'][_0x12aa09['uniqueid']][_0x3f9fbd]['reason']=_0xa3c7('0x52');logger[_0xa3c7('0x27')]('[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:',_0x12aa09['uniqueid'],util[_0xa3c7('0x2a')](this[_0xa3c7('0xa')][_0x12aa09['uniqueid']][_0x3f9fbd],{'showHidden':![],'depth':null}));ami[_0xa3c7('0x20')](_0xa3c7('0x53'),this[_0xa3c7('0xa')][_0x12aa09[_0xa3c7('0x29')]][_0x3f9fbd]);}}}}}}catch(_0x5102ac){logger[_0xa3c7('0x3c')](_0xa3c7('0x54'),_0x12aa09[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x5102ac,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x12')]=function(_0x269300){try{if(this[_0xa3c7('0x21')](_0x269300)){logger['debug'](_0xa3c7('0x55'),_0x269300[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x269300,{'showHidden':![],'depth':null}));if(this[_0xa3c7('0xa')][_0x269300['uniqueid']]&&this[_0xa3c7('0xa')][_0x269300[_0xa3c7('0x29')]][_0x269300[_0xa3c7('0x26')]]){logger[_0xa3c7('0x23')](_0xa3c7('0x56'),_0x269300[_0xa3c7('0x29')],_0x269300['membername'],_0x269300[_0xa3c7('0x26')]);this['channels'][_0x269300[_0xa3c7('0x29')]][_0x269300['destuniqueid']][_0xa3c7('0x4e')]=!![];this[_0xa3c7('0xa')][_0x269300['uniqueid']][_0x269300[_0xa3c7('0x26')]]['agentringnoanswerAt']=moment()[_0xa3c7('0x2c')](_0xa3c7('0x41'));this[_0xa3c7('0xa')][_0x269300['uniqueid']][_0x269300['destuniqueid']][_0xa3c7('0x47')]=_0xa3c7('0x57');this[_0xa3c7('0xa')][_0x269300['uniqueid']][_0x269300[_0xa3c7('0x26')]][_0xa3c7('0x58')]=_0xa3c7('0x57');logger[_0xa3c7('0x27')]('[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:',_0x269300[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](this['channels'][_0x269300[_0xa3c7('0x29')]][_0x269300[_0xa3c7('0x26')]],{'showHidden':![],'depth':null}));ami[_0xa3c7('0x20')](_0xa3c7('0x59'),this[_0xa3c7('0xa')][_0x269300[_0xa3c7('0x29')]][_0x269300['destuniqueid']]);}}}catch(_0x37898f){logger[_0xa3c7('0x3c')]('[%s][voiceAgentReport][agentringnoanswer]',_0x269300[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x37898f,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x5a')]=function(_0x1e292e){try{if(this['isNotNull'](_0x1e292e)){logger['debug']('[%s][voiceAgentReport][queuecallerabandon]\x20event:',_0x1e292e['uniqueid'],util['inspect'](_0x1e292e,{'showHidden':![],'depth':null}));if(this['channels'][_0x1e292e[_0xa3c7('0x29')]]){for(var _0x80af89 in this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]]){if(this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]]['hasOwnProperty'](_0x80af89)&&!this['channels'][_0x1e292e[_0xa3c7('0x29')]][_0x80af89][_0xa3c7('0x4e')]&&!this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89][_0xa3c7('0x14')]){logger['info']('[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x1e292e['uniqueid'],this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89][_0xa3c7('0x25')],_0x80af89);this[_0xa3c7('0xa')][_0x1e292e['uniqueid']][_0x80af89][_0xa3c7('0x4e')]=!![];this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89][_0xa3c7('0x50')]=moment()[_0xa3c7('0x2c')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89][_0xa3c7('0x47')]='abandoned';this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89][_0xa3c7('0x58')]=_0xa3c7('0x5b');logger[_0xa3c7('0x27')]('[%s][voiceAgentReport][queuecallerabandon]\x20sending\x20agentqueuecallerabandon\x20event:',_0x1e292e['uniqueid'],util['inspect'](this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89],{'showHidden':![],'depth':null}));ami[_0xa3c7('0x20')](_0xa3c7('0x5c'),this[_0xa3c7('0xa')][_0x1e292e[_0xa3c7('0x29')]][_0x80af89]);}}}}}catch(_0x46286e){logger[_0xa3c7('0x3c')](_0xa3c7('0x5d'),_0x1e292e[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x46286e,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')]['syncAgentComplete']=function(_0x185f8f){try{if(this[_0xa3c7('0x21')](_0x185f8f)){logger[_0xa3c7('0x27')](_0xa3c7('0x5e'),_0x185f8f[_0xa3c7('0x29')],util['inspect'](_0x185f8f,{'showHidden':![],'depth':null}));if(this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]]){for(var _0x3dd979 in this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]]){if(this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0xa3c7('0x3e')](_0x3dd979)){if(this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979][_0xa3c7('0x40')]&&!this['channels'][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979]['agentcomplete']){logger[_0xa3c7('0x23')](_0xa3c7('0x5f'),_0x185f8f[_0xa3c7('0x29')],this[_0xa3c7('0xa')][_0x185f8f['uniqueid']][_0x3dd979][_0xa3c7('0x25')],_0x3dd979);this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979][_0xa3c7('0x14')]=!![];this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979]['agentcompleteAt']=moment()[_0xa3c7('0x2c')](_0xa3c7('0x41'));this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979][_0xa3c7('0x47')]='complete';this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979][_0xa3c7('0x58')]=_0x185f8f[_0xa3c7('0x58')]=='transfer'?_0xa3c7('0x60'):_0x185f8f[_0xa3c7('0x58')];this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979]['talktime']=_0x185f8f['talktime'];if(this['voiceQueues'][_0x185f8f['queue']]&&this[_0xa3c7('0xc')][_0x185f8f['queue']][_0xa3c7('0x61')]){this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979][_0xa3c7('0x62')]=this[_0xa3c7('0xc')][_0x185f8f[_0xa3c7('0x2e')]][_0xa3c7('0x63')];this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979]['agentacw']=!![];}this[_0xa3c7('0xd')][_0x185f8f[_0xa3c7('0x38')]]=_[_0xa3c7('0x33')](this[_0xa3c7('0xd')][_0x185f8f[_0xa3c7('0x38')]],[_0xa3c7('0x2e'),_0xa3c7('0x4a')]);logger['debug']('[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:',_0x185f8f[_0xa3c7('0x29')],util['inspect'](this[_0xa3c7('0xa')][_0x185f8f['uniqueid']][_0x3dd979],{'showHidden':![],'depth':null}));ami['emit'](_0xa3c7('0x64'),this[_0xa3c7('0xa')][_0x185f8f[_0xa3c7('0x29')]][_0x3dd979]);logger['debug']('[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:',_0x185f8f[_0xa3c7('0x29')],util[_0xa3c7('0x2a')]({'id':this[_0xa3c7('0xd')][_0x185f8f['interface']]['id'],'destaccountcode':_0x185f8f[_0xa3c7('0x65')]},{'showHidden':![],'depth':null}));this[_0xa3c7('0x20')](util['format'](_0xa3c7('0x66'),_0x185f8f[_0xa3c7('0x25')]),'user:agentcomplete',{'id':this['agents'][_0x185f8f[_0xa3c7('0x38')]]['id'],'destaccountcode':_0x185f8f['destaccountcode']});}}}}}}catch(_0x2b8562){logger[_0xa3c7('0x3c')]('[%s][voiceAgentReport][agentcomplete]',_0x185f8f[_0xa3c7('0x29')],util['inspect'](_0x2b8562,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xa3c7('0x16')]=function(_0x459ed7){try{if(this[_0xa3c7('0x21')](_0x459ed7)){logger[_0xa3c7('0x27')](_0xa3c7('0x67'),_0x459ed7[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x459ed7,{'showHidden':![],'depth':null}));this['addVariable'](_0x459ed7['uniqueid'],_['keys'](_0x459ed7['variable'])[0x0],_0x459ed7['value']);if(this[_0xa3c7('0xa')][_0x459ed7[_0xa3c7('0x29')]]){for(var _0x3d2f3c in this[_0xa3c7('0xa')][_0x459ed7[_0xa3c7('0x29')]]){if(this[_0xa3c7('0xa')][_0x459ed7['uniqueid']][_0xa3c7('0x3e')](_0x3d2f3c)){logger['info'](_0xa3c7('0x68'),_0x459ed7[_0xa3c7('0x29')],_0x3d2f3c,_[_0xa3c7('0x69')](_0x459ed7[_0xa3c7('0x6a')])[0x0],_0x459ed7[_0xa3c7('0x6b')]);if(_['isUndefined'](this['channels'][_0x459ed7[_0xa3c7('0x29')]][_0x3d2f3c][_0xa3c7('0xe')])){this['channels'][_0x459ed7[_0xa3c7('0x29')]][_0x3d2f3c][_0xa3c7('0xe')]={};}this[_0xa3c7('0xa')][_0x459ed7['uniqueid']][_0x3d2f3c][_0xa3c7('0xe')]=this[_0xa3c7('0xe')][_0x459ed7[_0xa3c7('0x29')]];}}}}}catch(_0x9647ab){logger[_0xa3c7('0x3c')](_0xa3c7('0x6c'),_0x459ed7[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x9647ab,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xa3c7('0x6d')]=function(_0x43f4a6,_0xc67f0a,_0x511808){var _0x3207f1=['rtpaudioqos','rtpaudioqosbridged',_0xa3c7('0x6e'),_0xa3c7('0x6f'),_0xa3c7('0x70'),'rtpaudioqoslossbridged',_0xa3c7('0x71'),_0xa3c7('0x72'),_0xa3c7('0x73'),_0xa3c7('0x74'),'bridgepeer','bridgepvtcallid',_0xa3c7('0x75'),_0xa3c7('0x76'),_0xa3c7('0x77'),_0xa3c7('0x78'),_0xa3c7('0x25'),_0xa3c7('0x79'),'memberrealtime'];if(!_[_0xa3c7('0x7a')](_0xc67f0a)&&!_[_0xa3c7('0x7b')](_0x3207f1,_0xc67f0a)){if(_[_0xa3c7('0x2b')](this[_0xa3c7('0xe')][_0x43f4a6])){this[_0xa3c7('0xe')][_0x43f4a6]={};}this[_0xa3c7('0xe')][_0x43f4a6][_0xc67f0a]=_0x511808;}};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x18')]=function(_0x24fa15){try{if(this[_0xa3c7('0x21')](_0x24fa15)){logger[_0xa3c7('0x27')]('[%s][voiceAgentReport][hangup]\x20event:',_0x24fa15[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x24fa15,{'showHidden':![],'depth':null}));if(this[_0xa3c7('0xa')][_0x24fa15[_0xa3c7('0x29')]]){for(var _0xda0150 in this['channels'][_0x24fa15[_0xa3c7('0x29')]]){if(this['channels'][_0x24fa15[_0xa3c7('0x29')]][_0xa3c7('0x3e')](_0xda0150)){if(this[_0xa3c7('0xa')][_0x24fa15[_0xa3c7('0x29')]][_0xda0150]['reason']==_0xa3c7('0x7c')&&this['channels'][_0x24fa15[_0xa3c7('0x29')]][_0xda0150][_0xa3c7('0x14')]){logger[_0xa3c7('0x23')]('[%s][voiceAgentReport][hangup]\x20destuniqueid:%s',_0x24fa15['uniqueid'],_0xda0150);this[_0xa3c7('0xa')][_0x24fa15[_0xa3c7('0x29')]][_0xda0150]['agentcompleteAt']=moment()['format'](_0xa3c7('0x41'));}}}logger[_0xa3c7('0x27')](_0xa3c7('0x7d'),_0x24fa15[_0xa3c7('0x29')],util['inspect'](_[_0xa3c7('0x7e')](this[_0xa3c7('0xa')][_0x24fa15['uniqueid']]),{'showHidden':![],'depth':null}));ami['emit'](_0xa3c7('0x7f'),_[_0xa3c7('0x7e')](this[_0xa3c7('0xa')][_0x24fa15[_0xa3c7('0x29')]]));delete this[_0xa3c7('0xa')][_0x24fa15['uniqueid']];}if(this[_0xa3c7('0xe')][_0x24fa15[_0xa3c7('0x29')]]){delete this['variables'][_0x24fa15['uniqueid']];}}}catch(_0x418d03){logger[_0xa3c7('0x3c')]('[%s][voiceAgentReport][hangup]',_0x24fa15[_0xa3c7('0x29')],util['inspect'](_0x418d03,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')]['syncAttendedTransfer']=function(_0x3425fe){try{if(this['isNotNull'](_0x3425fe)){logger[_0xa3c7('0x27')](_0xa3c7('0x80'),_0x3425fe[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x3425fe,{'showHidden':![],'depth':null}));if(this['channels'][_0x3425fe[_0xa3c7('0x81')]]){for(var _0x393da8 in this[_0xa3c7('0xa')][_0x3425fe['transfereeuniqueid']]){if(this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0xa3c7('0x3e')](_0x393da8)){if(_0x3425fe[_0xa3c7('0x82')]===_0x393da8){logger[_0xa3c7('0x23')](_0xa3c7('0x83'),_0x3425fe['uniqueid'],this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0x393da8]['membername'],_0x393da8);var _0x56f3dc=moment();this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0x393da8][_0xa3c7('0x14')]=!![];this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0x393da8][_0xa3c7('0x84')]=moment()[_0xa3c7('0x2c')](_0xa3c7('0x41'));this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0x393da8][_0xa3c7('0x47')]='complete';this[_0xa3c7('0xa')][_0x3425fe['transfereeuniqueid']][_0x393da8][_0xa3c7('0x58')]='transfer';this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0x393da8]['talktime']=_0x56f3dc['diff'](this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]][_0x393da8][_0xa3c7('0x40')],'seconds');}}}}if(this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x85')]]){var _0x32351e=this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x85')]];this['channels'][_0x3425fe['secondtransfereruniqueid']]=this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]];this[_0xa3c7('0xa')][_0x3425fe[_0xa3c7('0x81')]]=_0x32351e;}}}catch(_0x5cb5d6){logger[_0xa3c7('0x3c')](_0xa3c7('0x86'),_0x3425fe[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x5cb5d6,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xa3c7('0x1e')]=function(_0x173622){try{if(this[_0xa3c7('0x21')](_0x173622)){logger[_0xa3c7('0x27')](_0xa3c7('0x87'),_0x173622[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x173622,{'showHidden':![],'depth':null}));if(this['channels'][_0x173622[_0xa3c7('0x81')]]){for(var _0x5181b3 in this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]]){if(this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]][_0xa3c7('0x3e')](_0x5181b3)){if(_0x173622[_0xa3c7('0x88')]===_0x5181b3){logger[_0xa3c7('0x23')]('[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete',_0x173622[_0xa3c7('0x29')],this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]][_0x5181b3][_0xa3c7('0x25')],_0x5181b3);var _0x5ee95a=moment();this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]][_0x5181b3][_0xa3c7('0x14')]=!![];this[_0xa3c7('0xa')][_0x173622['transfereeuniqueid']][_0x5181b3][_0xa3c7('0x84')]=_0x5ee95a;this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]][_0x5181b3][_0xa3c7('0x47')]=_0xa3c7('0x89');this['channels'][_0x173622[_0xa3c7('0x81')]][_0x5181b3]['reason']=_0xa3c7('0x7c');this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]][_0x5181b3][_0xa3c7('0x8a')]=_0x5ee95a['diff'](this[_0xa3c7('0xa')][_0x173622[_0xa3c7('0x81')]][_0x5181b3][_0xa3c7('0x40')],_0xa3c7('0x8b'));}}}}}}catch(_0x29e71f){logger['error'](_0xa3c7('0x8c'),_0x173622['uniqueid'],util[_0xa3c7('0x2a')](_0x29e71f,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x1a')]=function(_0x5d5622){var _0x185c89='';try{if(this[_0xa3c7('0x21')](_0x5d5622)){logger[_0xa3c7('0x27')](_0xa3c7('0x8d'),_0x5d5622[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x5d5622,{'showHidden':![],'depth':null}));if(_0x5d5622[_0xa3c7('0x8e')]){_0x185c89=_0x5d5622[_0xa3c7('0x8e')][_0xa3c7('0x8f')](0x0,_0x5d5622[_0xa3c7('0x8e')][_0xa3c7('0x90')]('-'));if(this[_0xa3c7('0xd')][_0x185c89]){logger[_0xa3c7('0x23')](_0xa3c7('0x91'),_0x5d5622[_0xa3c7('0x29')],_0x185c89);this[_0xa3c7('0xd')][_0x185c89][_0xa3c7('0x92')]=!![];}}}}catch(_0x561abb){logger[_0xa3c7('0x3c')](_0xa3c7('0x93'),_0x5d5622[_0xa3c7('0x29')],util[_0xa3c7('0x2a')](_0x561abb,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xa3c7('0x1f')][_0xa3c7('0x94')]=function(_0x5d5855){var _0x272e13='';try{if(this[_0xa3c7('0x21')](_0x5d5855)){logger[_0xa3c7('0x27')](_0xa3c7('0x95'),_0x5d5855['uniqueid'],util[_0xa3c7('0x2a')](_0x5d5855,{'showHidden':![],'depth':null}));if(_0x5d5855['channel']){_0x272e13=_0x5d5855[_0xa3c7('0x8e')]['substring'](0x0,_0x5d5855[_0xa3c7('0x8e')][_0xa3c7('0x90')]('-'));if(this[_0xa3c7('0xd')][_0x272e13]){logger[_0xa3c7('0x23')](_0xa3c7('0x96'),_0x5d5855[_0xa3c7('0x29')],_0x272e13);this[_0xa3c7('0xd')][_0x272e13][_0xa3c7('0x92')]=![];}}}}catch(_0x36e513){logger[_0xa3c7('0x3c')](_0xa3c7('0x97'),_0x5d5855[_0xa3c7('0x29')],util['inspect'](_0x36e513,{'showHidden':![],'depth':null}));}};module[_0xa3c7('0x98')]=VoiceAgentReport;