96a5ab2c687208c286890fbf01b9be0dfad2861d
[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 _0x4187=['rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','sipcallid','sipuri','bridgepeer','memberdynamic','memberpenalty','includes','syncHangup','[%s][voiceAgentReport][hangup]\x20event:','[%s][voiceAgentReport][hangup]\x20destuniqueid:%s','values','[%s][voiceAgentReport][hangup]','[%s][voiceAgentReport][attendedtransfer]\x20event:','transfereeuniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','diff','seconds','secondtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]','[%s][voiceAgentReport][blindtransfer]\x20event:','transfereruniqueid','[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','[%s][voiceAgentReport][blindtransfer]','[%s][voiceAgentReport][musiconholdstart]\x20event:','channel','substring','lastIndexOf','[%s][voiceAgentReport][musiconholdstart]\x20interface:%s','onhold','[%s][voiceAgentReport][musiconholdstart]','[%s][voiceAgentReport][musiconholdstop]\x20event:','[%s][voiceAgentReport][musiconholdstop]\x20interface:%s','[%s][voiceAgentReport][musiconholdstop]','exports','lodash','moment','util','../../../config/logger','ami','redis','defaults','localhost','socket.io-emitter','channels','voiceQueues','agents','variables','agentcalled','syncAgentCalled','bind','agentconnect','syncAgentConnect','agentringnoanswer','syncAgentRingNoAnswer','queuecallerabandon','syncQueueCallerAbandon','syncAgentComplete','hangup','musiconholdstart','syncMusicOnHoldStart','syncMusicOnHoldStop','attendedtransfer','syncAttendedTransfer','blindtransfer','syncBlindTransfer','emit','prototype','isNotNull','isUndefined','info','[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','uniqueid','membername','destuniqueid','[%s][voiceAgentReport][agentcalled]\x20event:','format','YYYY-MM-DD\x20HH:mm:ss','called','mandatoryDisposition','queue','inbound','merge','omit','event','privilege','debug','inspect','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:','user:%s','user:called','error','[%s][voiceAgentReport][agentcalled]','[%s][voiceAgentReport][agentconnect]\x20event:','hasOwnProperty','agentconnectAt','connectedlinename','connectedlinenum','destchannelstate','destchannelstatedesc','holdtime','lastevent','connect','interface','pick','destconnectedlinenum','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentconnect\x20event:','user:agentconnect','answeredelsewheredestinationuniqueid','answeredelsewheremembername','answered_elsewhere','reason','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:','custom:agentansweredelsewhere','[%s][voiceAgentReport][agentconnect]','[%s][voiceAgentReport][agentringnoanswer]\x20event:','agentringnoanswerAt','rejected','[%s][voiceAgentReport][agentringnoanswer]','agentcomplete','abandoned','[%s][voiceAgentReport][queuecallerabandon]\x20sending\x20agentqueuecallerabandon\x20event:','custom:agentqueuecallerabandon','[%s][voiceAgentReport][queuecallerabandon]','[%s][voiceAgentReport][agentcomplete]\x20event:','[%s][voiceAgentReport][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','complete','transfer','talktime','acw','acwtime','acwTimeout','[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:','custom:agentcomplete','[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:','[%s][voiceAgentReport][agentcomplete]','syncVarSet','[%s][voiceAgentReport][varset]\x20event:','keys','variable','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','value','[%s][voiceAgentReport][varset]'];(function(_0x548a22,_0x266250){var _0x4644b0=function(_0x1a34cb){while(--_0x1a34cb){_0x548a22['push'](_0x548a22['shift']());}};_0x4644b0(++_0x266250);}(_0x4187,0xbf));var _0x7418=function(_0x163489,_0x5bfed0){_0x163489=_0x163489-0x0;var _0xef3ef6=_0x4187[_0x163489];return _0xef3ef6;};'use strict';var _=require(_0x7418('0x0'));var moment=require(_0x7418('0x1'));var util=require(_0x7418('0x2'));var Redis=require('ioredis');var config=require('../../../config/environment');var logger=require(_0x7418('0x3'))(_0x7418('0x4'));var ami=require('../ami');config[_0x7418('0x5')]=_[_0x7418('0x6')](config['redis'],{'host':_0x7418('0x7'),'port':0x18eb});var io=require(_0x7418('0x8'))(new Redis(config[_0x7418('0x5')]));function VoiceAgentReport(_0x417823){this[_0x7418('0x9')]={};this[_0x7418('0xa')]=_0x417823['voiceQueues'];this[_0x7418('0xb')]=_0x417823['agents'];this[_0x7418('0xc')]={};ami['on'](_0x7418('0xd'),this[_0x7418('0xe')][_0x7418('0xf')](this));ami['on'](_0x7418('0x10'),this[_0x7418('0x11')][_0x7418('0xf')](this));ami['on'](_0x7418('0x12'),this[_0x7418('0x13')][_0x7418('0xf')](this));ami['on'](_0x7418('0x14'),this[_0x7418('0x15')][_0x7418('0xf')](this));ami['on']('agentcomplete',this[_0x7418('0x16')][_0x7418('0xf')](this));ami['on']('varset',this['syncVarSet'][_0x7418('0xf')](this));ami['on'](_0x7418('0x17'),this['syncHangup'][_0x7418('0xf')](this));ami['on'](_0x7418('0x18'),this[_0x7418('0x19')][_0x7418('0xf')](this));ami['on']('musiconholdstop',this[_0x7418('0x1a')][_0x7418('0xf')](this));ami['on'](_0x7418('0x1b'),this[_0x7418('0x1c')][_0x7418('0xf')](this));ami['on'](_0x7418('0x1d'),this[_0x7418('0x1e')]['bind'](this));}VoiceAgentReport['prototype'][_0x7418('0x1f')]=function(_0x244ab2,_0x4d4467,_0x56235b){io['to'](_0x244ab2)[_0x7418('0x1f')](_0x4d4467,_0x56235b);};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x21')]=function(_0xf8deb7){return _0xf8deb7!==null&&!_[_0x7418('0x22')](_0xf8deb7);};VoiceAgentReport[_0x7418('0x20')]['syncAgentCalled']=function(_0xc7159c){try{if(this['isNotNull'](_0xc7159c)){logger[_0x7418('0x23')](_0x7418('0x24'),_0xc7159c[_0x7418('0x25')],_0xc7159c[_0x7418('0x26')],_0xc7159c[_0x7418('0x27')]);logger['debug'](_0x7418('0x28'),_0xc7159c['uniqueid'],util['inspect'](_0xc7159c,{'showHidden':![],'depth':null}));if(_[_0x7418('0x22')](this['channels'][_0xc7159c[_0x7418('0x25')]])){this[_0x7418('0x9')][_0xc7159c[_0x7418('0x25')]]={};}if(_[_0x7418('0x22')](this[_0x7418('0x9')][_0xc7159c['uniqueid']][_0xc7159c[_0x7418('0x27')]])){this[_0x7418('0x9')][_0xc7159c[_0x7418('0x25')]][_0xc7159c[_0x7418('0x27')]]={'agentcalledAt':moment()[_0x7418('0x29')](_0x7418('0x2a')),'lastevent':_0x7418('0x2b'),'mandatoryDisposition':this[_0x7418('0xa')][_0xc7159c['queue']]?this[_0x7418('0xa')][_0xc7159c['queue']][_0x7418('0x2c')]||![]:![],'type':this[_0x7418('0xa')][_0xc7159c['queue']]?this[_0x7418('0xa')][_0xc7159c[_0x7418('0x2d')]]['type']||_0x7418('0x2e'):_0x7418('0x2e'),'variables':this['variables'][_0xc7159c[_0x7418('0x25')]]};}_[_0x7418('0x2f')](this[_0x7418('0x9')][_0xc7159c[_0x7418('0x25')]][_0xc7159c['destuniqueid']],_[_0x7418('0x30')](_0xc7159c,[_0x7418('0x31'),_0x7418('0x32')]));logger[_0x7418('0x33')]('[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:',_0xc7159c[_0x7418('0x25')],util[_0x7418('0x34')](this[_0x7418('0x9')][_0xc7159c[_0x7418('0x25')]][_0xc7159c[_0x7418('0x27')]],{'showHidden':![],'depth':null}));ami[_0x7418('0x1f')]('custom:agentcalled',this[_0x7418('0x9')][_0xc7159c[_0x7418('0x25')]][_0xc7159c[_0x7418('0x27')]]);logger[_0x7418('0x33')](_0x7418('0x35'),_0xc7159c[_0x7418('0x25')],util[_0x7418('0x34')](this[_0x7418('0x9')][_0xc7159c['uniqueid']][_0xc7159c[_0x7418('0x27')]],{'showHidden':![],'depth':null}));this['emit'](util[_0x7418('0x29')](_0x7418('0x36'),_0xc7159c['membername']),_0x7418('0x37'),this[_0x7418('0x9')][_0xc7159c[_0x7418('0x25')]][_0xc7159c[_0x7418('0x27')]]);}}catch(_0x2d6754){logger[_0x7418('0x38')](_0x7418('0x39'),_0xc7159c['uniqueid'],util[_0x7418('0x34')](_0x2d6754,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x11')]=function(_0xcfe3fc){try{if(this['isNotNull'](_0xcfe3fc)){if(this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]]){logger['debug'](_0x7418('0x3a'),_0xcfe3fc[_0x7418('0x25')],util[_0x7418('0x34')](_0xcfe3fc,{'showHidden':![],'depth':null}));for(var _0x5a3ec8 in this['channels'][_0xcfe3fc['uniqueid']]){if(this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x7418('0x3b')](_0x5a3ec8)){if(_0xcfe3fc['destuniqueid']===_0x5a3ec8){logger[_0x7418('0x23')]('[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect',_0xcfe3fc['uniqueid'],_0xcfe3fc[_0x7418('0x26')],_0xcfe3fc[_0x7418('0x27')]);this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x3c')]=moment()[_0x7418('0x29')](_0x7418('0x2a'));this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x3d')]=_0xcfe3fc['connectedlinename'];this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x3e')]=_0xcfe3fc[_0x7418('0x3e')];this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x3f')]=_0xcfe3fc[_0x7418('0x3f')];this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x40')]=_0xcfe3fc[_0x7418('0x40')];this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x41')]=_0xcfe3fc['holdtime'];this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x42')]=_0x7418('0x43');_['merge'](this[_0x7418('0xb')][_0xcfe3fc[_0x7418('0x44')]],_[_0x7418('0x45')](_0xcfe3fc,[_0x7418('0x2d'),_0x7418('0x46')]));logger['debug'](_0x7418('0x47'),_0xcfe3fc[_0x7418('0x25')],util[_0x7418('0x34')](this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0xcfe3fc[_0x7418('0x27')]],{'showHidden':![],'depth':null}));ami['emit']('custom:agentconnect',this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0xcfe3fc[_0x7418('0x27')]]);logger[_0x7418('0x33')]('[%s][voiceAgentReport][agentcalled]\x20sending\x20user:agentconnect\x20event:',_0xcfe3fc[_0x7418('0x25')],util[_0x7418('0x34')](this[_0x7418('0x9')][_0xcfe3fc['uniqueid']][_0xcfe3fc[_0x7418('0x27')]],{'showHidden':![],'depth':null}));this['emit'](util['format']('user:%s',_0xcfe3fc[_0x7418('0x26')]),_0x7418('0x48'),this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0xcfe3fc[_0x7418('0x27')]]);}else if(!this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x12')]&&!this['channels'][_0xcfe3fc['uniqueid']][_0x5a3ec8]['agentcomplete']){logger[_0x7418('0x23')]('[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere',_0xcfe3fc['uniqueid'],this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x26')],_0x5a3ec8);this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x12')]=!![];this[_0x7418('0x9')][_0xcfe3fc['uniqueid']][_0x5a3ec8]['agentringnoanswerAt']=moment()[_0x7418('0x29')]('YYYY-MM-DD\x20HH:mm:ss');this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x49')]=_0xcfe3fc[_0x7418('0x27')];this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x4a')]=_0xcfe3fc[_0x7418('0x26')];this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x42')]=_0x7418('0x4b');this[_0x7418('0x9')][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8][_0x7418('0x4c')]=_0x7418('0x4b');logger[_0x7418('0x33')](_0x7418('0x4d'),_0xcfe3fc[_0x7418('0x25')],util[_0x7418('0x34')](this['channels'][_0xcfe3fc[_0x7418('0x25')]][_0x5a3ec8],{'showHidden':![],'depth':null}));ami[_0x7418('0x1f')](_0x7418('0x4e'),this[_0x7418('0x9')][_0xcfe3fc['uniqueid']][_0x5a3ec8]);}}}}}}catch(_0x4759c8){logger['error'](_0x7418('0x4f'),_0xcfe3fc[_0x7418('0x25')],util[_0x7418('0x34')](_0x4759c8,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x13')]=function(_0x53a9d5){try{if(this[_0x7418('0x21')](_0x53a9d5)){logger[_0x7418('0x33')](_0x7418('0x50'),_0x53a9d5[_0x7418('0x25')],util[_0x7418('0x34')](_0x53a9d5,{'showHidden':![],'depth':null}));if(this[_0x7418('0x9')][_0x53a9d5[_0x7418('0x25')]]&&this[_0x7418('0x9')][_0x53a9d5[_0x7418('0x25')]][_0x53a9d5[_0x7418('0x27')]]){logger['info']('[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected',_0x53a9d5[_0x7418('0x25')],_0x53a9d5[_0x7418('0x26')],_0x53a9d5[_0x7418('0x27')]);this[_0x7418('0x9')][_0x53a9d5['uniqueid']][_0x53a9d5[_0x7418('0x27')]][_0x7418('0x12')]=!![];this['channels'][_0x53a9d5['uniqueid']][_0x53a9d5[_0x7418('0x27')]][_0x7418('0x51')]=moment()['format'](_0x7418('0x2a'));this['channels'][_0x53a9d5[_0x7418('0x25')]][_0x53a9d5['destuniqueid']][_0x7418('0x42')]=_0x7418('0x52');this['channels'][_0x53a9d5[_0x7418('0x25')]][_0x53a9d5['destuniqueid']][_0x7418('0x4c')]=_0x7418('0x52');logger['debug']('[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:',_0x53a9d5['uniqueid'],util[_0x7418('0x34')](this['channels'][_0x53a9d5[_0x7418('0x25')]][_0x53a9d5[_0x7418('0x27')]],{'showHidden':![],'depth':null}));ami['emit']('custom:agentringnoanswer',this[_0x7418('0x9')][_0x53a9d5['uniqueid']][_0x53a9d5[_0x7418('0x27')]]);}}}catch(_0x10592f){logger[_0x7418('0x38')](_0x7418('0x53'),_0x53a9d5['uniqueid'],util['inspect'](_0x10592f,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')]['syncQueueCallerAbandon']=function(_0x7e3ac0){try{if(this[_0x7418('0x21')](_0x7e3ac0)){logger[_0x7418('0x33')]('[%s][voiceAgentReport][queuecallerabandon]\x20event:',_0x7e3ac0['uniqueid'],util[_0x7418('0x34')](_0x7e3ac0,{'showHidden':![],'depth':null}));if(this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]]){for(var _0x30038a in this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]]){if(this['channels'][_0x7e3ac0['uniqueid']][_0x7418('0x3b')](_0x30038a)&&!this[_0x7418('0x9')][_0x7e3ac0['uniqueid']][_0x30038a][_0x7418('0x12')]&&!this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a][_0x7418('0x54')]){logger['info']('[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x7e3ac0[_0x7418('0x25')],this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a][_0x7418('0x26')],_0x30038a);this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a]['agentringnoanswer']=!![];this['channels'][_0x7e3ac0[_0x7418('0x25')]][_0x30038a][_0x7418('0x51')]=moment()[_0x7418('0x29')](_0x7418('0x2a'));this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a][_0x7418('0x42')]='abandoned';this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a][_0x7418('0x4c')]=_0x7418('0x55');logger[_0x7418('0x33')](_0x7418('0x56'),_0x7e3ac0['uniqueid'],util[_0x7418('0x34')](this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a],{'showHidden':![],'depth':null}));ami[_0x7418('0x1f')](_0x7418('0x57'),this[_0x7418('0x9')][_0x7e3ac0[_0x7418('0x25')]][_0x30038a]);}}}}}catch(_0x144090){logger[_0x7418('0x38')](_0x7418('0x58'),_0x7e3ac0[_0x7418('0x25')],util[_0x7418('0x34')](_0x144090,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x16')]=function(_0x40bfd5){try{if(this['isNotNull'](_0x40bfd5)){logger[_0x7418('0x33')](_0x7418('0x59'),_0x40bfd5['uniqueid'],util[_0x7418('0x34')](_0x40bfd5,{'showHidden':![],'depth':null}));if(this[_0x7418('0x9')][_0x40bfd5['uniqueid']]){for(var _0xbf2fab in this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]]){if(this[_0x7418('0x9')][_0x40bfd5['uniqueid']][_0x7418('0x3b')](_0xbf2fab)){if(this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab][_0x7418('0x3c')]&&!this['channels'][_0x40bfd5['uniqueid']][_0xbf2fab][_0x7418('0x54')]){logger[_0x7418('0x23')](_0x7418('0x5a'),_0x40bfd5[_0x7418('0x25')],this['channels'][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab]['membername'],_0xbf2fab);this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab][_0x7418('0x54')]=!![];this['channels'][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab][_0x7418('0x5b')]=moment()[_0x7418('0x29')](_0x7418('0x2a'));this[_0x7418('0x9')][_0x40bfd5['uniqueid']][_0xbf2fab][_0x7418('0x42')]=_0x7418('0x5c');this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab][_0x7418('0x4c')]=_0x40bfd5[_0x7418('0x4c')]==_0x7418('0x5d')?'agent':_0x40bfd5['reason'];this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab][_0x7418('0x5e')]=_0x40bfd5[_0x7418('0x5e')];if(this['voiceQueues'][_0x40bfd5[_0x7418('0x2d')]]&&this[_0x7418('0xa')][_0x40bfd5[_0x7418('0x2d')]][_0x7418('0x5f')]){this[_0x7418('0x9')][_0x40bfd5['uniqueid']][_0xbf2fab][_0x7418('0x60')]=this[_0x7418('0xa')][_0x40bfd5[_0x7418('0x2d')]][_0x7418('0x61')];this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab]['agentacw']=!![];}this[_0x7418('0xb')][_0x40bfd5[_0x7418('0x44')]]=_['omit'](this[_0x7418('0xb')][_0x40bfd5['interface']],[_0x7418('0x2d'),_0x7418('0x46')]);logger[_0x7418('0x33')](_0x7418('0x62'),_0x40bfd5[_0x7418('0x25')],util[_0x7418('0x34')](this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab],{'showHidden':![],'depth':null}));ami['emit'](_0x7418('0x63'),this['channels'][_0x40bfd5['uniqueid']][_0xbf2fab]);logger[_0x7418('0x33')](_0x7418('0x64'),_0x40bfd5[_0x7418('0x25')],util[_0x7418('0x34')](this[_0x7418('0x9')][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab],{'showHidden':![],'depth':null}));this[_0x7418('0x1f')](util['format'](_0x7418('0x36'),_0x40bfd5['membername']),'user:agentcomplete',this['channels'][_0x40bfd5[_0x7418('0x25')]][_0xbf2fab]);}}}}}}catch(_0x32db0c){logger[_0x7418('0x38')](_0x7418('0x65'),_0x40bfd5[_0x7418('0x25')],util['inspect'](_0x32db0c,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x66')]=function(_0x27553f){try{if(this[_0x7418('0x21')](_0x27553f)){logger[_0x7418('0x33')](_0x7418('0x67'),_0x27553f['uniqueid'],util[_0x7418('0x34')](_0x27553f,{'showHidden':![],'depth':null}));this['addVariable'](_0x27553f['uniqueid'],_[_0x7418('0x68')](_0x27553f[_0x7418('0x69')])[0x0],_0x27553f['value']);if(this[_0x7418('0x9')][_0x27553f[_0x7418('0x25')]]){for(var _0x1fbe66 in this[_0x7418('0x9')][_0x27553f[_0x7418('0x25')]]){if(this[_0x7418('0x9')][_0x27553f[_0x7418('0x25')]][_0x7418('0x3b')](_0x1fbe66)){logger['info'](_0x7418('0x6a'),_0x27553f['uniqueid'],_0x1fbe66,_[_0x7418('0x68')](_0x27553f[_0x7418('0x69')])[0x0],_0x27553f[_0x7418('0x6b')]);if(_[_0x7418('0x22')](this[_0x7418('0x9')][_0x27553f[_0x7418('0x25')]][_0x1fbe66][_0x7418('0xc')])){this[_0x7418('0x9')][_0x27553f[_0x7418('0x25')]][_0x1fbe66]['variables']={};}this[_0x7418('0x9')][_0x27553f[_0x7418('0x25')]][_0x1fbe66]['variables']=this[_0x7418('0xc')][_0x27553f[_0x7418('0x25')]];}}}}}catch(_0x373f0b){logger[_0x7418('0x38')](_0x7418('0x6c'),_0x27553f['uniqueid'],util[_0x7418('0x34')](_0x373f0b,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')]['addVariable']=function(_0x24eb4c,_0x5d96c8,_0x1ae071){var _0x5a2376=[_0x7418('0x6d'),_0x7418('0x6e'),_0x7418('0x6f'),_0x7418('0x70'),_0x7418('0x71'),_0x7418('0x72'),_0x7418('0x73'),_0x7418('0x74'),_0x7418('0x75'),_0x7418('0x76'),_0x7418('0x77'),'bridgepvtcallid','membercalls',_0x7418('0x78'),'memberinterface','memberlastcall',_0x7418('0x26'),_0x7418('0x79'),'memberrealtime'];if(!_['isNil'](_0x5d96c8)&&!_[_0x7418('0x7a')](_0x5a2376,_0x5d96c8)){if(_[_0x7418('0x22')](this[_0x7418('0xc')][_0x24eb4c])){this['variables'][_0x24eb4c]={};}this['variables'][_0x24eb4c][_0x5d96c8]=_0x1ae071;}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x7b')]=function(_0xbca716){try{if(this[_0x7418('0x21')](_0xbca716)){logger[_0x7418('0x33')](_0x7418('0x7c'),_0xbca716[_0x7418('0x25')],util[_0x7418('0x34')](_0xbca716,{'showHidden':![],'depth':null}));if(this['channels'][_0xbca716['uniqueid']]){for(var _0x205c8a in this[_0x7418('0x9')][_0xbca716[_0x7418('0x25')]]){if(this[_0x7418('0x9')][_0xbca716[_0x7418('0x25')]][_0x7418('0x3b')](_0x205c8a)){if(this[_0x7418('0x9')][_0xbca716[_0x7418('0x25')]][_0x205c8a][_0x7418('0x4c')]=='transfer'&&this['channels'][_0xbca716[_0x7418('0x25')]][_0x205c8a][_0x7418('0x54')]){logger[_0x7418('0x23')](_0x7418('0x7d'),_0xbca716[_0x7418('0x25')],_0x205c8a);this[_0x7418('0x9')][_0xbca716['uniqueid']][_0x205c8a]['agentcompleteAt']=moment()[_0x7418('0x29')](_0x7418('0x2a'));}}}logger[_0x7418('0x33')]('[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:',_0xbca716[_0x7418('0x25')],util[_0x7418('0x34')](_['values'](this['channels'][_0xbca716[_0x7418('0x25')]]),{'showHidden':![],'depth':null}));ami[_0x7418('0x1f')]('custom:voiceAgentReport',_[_0x7418('0x7e')](this[_0x7418('0x9')][_0xbca716['uniqueid']]));delete this['channels'][_0xbca716[_0x7418('0x25')]];}if(this[_0x7418('0xc')][_0xbca716[_0x7418('0x25')]]){delete this[_0x7418('0xc')][_0xbca716[_0x7418('0x25')]];}}}catch(_0x1ce71c){logger[_0x7418('0x38')](_0x7418('0x7f'),_0xbca716[_0x7418('0x25')],util[_0x7418('0x34')](_0x1ce71c,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x1c')]=function(_0x1ad745){try{if(this[_0x7418('0x21')](_0x1ad745)){logger[_0x7418('0x33')](_0x7418('0x80'),_0x1ad745[_0x7418('0x25')],util[_0x7418('0x34')](_0x1ad745,{'showHidden':![],'depth':null}));if(this[_0x7418('0x9')][_0x1ad745[_0x7418('0x81')]]){for(var _0x5068ab in this['channels'][_0x1ad745['transfereeuniqueid']]){if(this[_0x7418('0x9')][_0x1ad745['transfereeuniqueid']]['hasOwnProperty'](_0x5068ab)){if(_0x1ad745['origtransfereruniqueid']===_0x5068ab){logger[_0x7418('0x23')](_0x7418('0x82'),_0x1ad745[_0x7418('0x25')],this[_0x7418('0x9')][_0x1ad745[_0x7418('0x81')]][_0x5068ab][_0x7418('0x26')],_0x5068ab);var _0x3a1c2d=moment();this['channels'][_0x1ad745[_0x7418('0x81')]][_0x5068ab][_0x7418('0x54')]=!![];this[_0x7418('0x9')][_0x1ad745['transfereeuniqueid']][_0x5068ab][_0x7418('0x5b')]=moment()[_0x7418('0x29')]('YYYY-MM-DD\x20HH:mm:ss');this[_0x7418('0x9')][_0x1ad745['transfereeuniqueid']][_0x5068ab]['lastevent']='complete';this['channels'][_0x1ad745[_0x7418('0x81')]][_0x5068ab]['reason']=_0x7418('0x5d');this[_0x7418('0x9')][_0x1ad745[_0x7418('0x81')]][_0x5068ab][_0x7418('0x5e')]=_0x3a1c2d[_0x7418('0x83')](this[_0x7418('0x9')][_0x1ad745[_0x7418('0x81')]][_0x5068ab][_0x7418('0x3c')],_0x7418('0x84'));}}}}if(this['channels'][_0x1ad745['secondtransfereruniqueid']]){var _0x4fcfef=this[_0x7418('0x9')][_0x1ad745[_0x7418('0x85')]];this[_0x7418('0x9')][_0x1ad745[_0x7418('0x85')]]=this[_0x7418('0x9')][_0x1ad745[_0x7418('0x81')]];this[_0x7418('0x9')][_0x1ad745['transfereeuniqueid']]=_0x4fcfef;}}}catch(_0x1a1e24){logger[_0x7418('0x38')](_0x7418('0x86'),_0x1ad745['uniqueid'],util[_0x7418('0x34')](_0x1a1e24,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x1e')]=function(_0x4ea282){try{if(this[_0x7418('0x21')](_0x4ea282)){logger[_0x7418('0x33')](_0x7418('0x87'),_0x4ea282['uniqueid'],util[_0x7418('0x34')](_0x4ea282,{'showHidden':![],'depth':null}));if(this['channels'][_0x4ea282[_0x7418('0x81')]]){for(var _0x49d2c4 in this['channels'][_0x4ea282[_0x7418('0x81')]]){if(this[_0x7418('0x9')][_0x4ea282[_0x7418('0x81')]][_0x7418('0x3b')](_0x49d2c4)){if(_0x4ea282[_0x7418('0x88')]===_0x49d2c4){logger[_0x7418('0x23')](_0x7418('0x89'),_0x4ea282['uniqueid'],this[_0x7418('0x9')][_0x4ea282['transfereeuniqueid']][_0x49d2c4][_0x7418('0x26')],_0x49d2c4);var _0x5e27b4=moment();this[_0x7418('0x9')][_0x4ea282[_0x7418('0x81')]][_0x49d2c4][_0x7418('0x54')]=!![];this[_0x7418('0x9')][_0x4ea282['transfereeuniqueid']][_0x49d2c4]['agentcompleteAt']=_0x5e27b4;this[_0x7418('0x9')][_0x4ea282[_0x7418('0x81')]][_0x49d2c4][_0x7418('0x42')]=_0x7418('0x5c');this[_0x7418('0x9')][_0x4ea282[_0x7418('0x81')]][_0x49d2c4][_0x7418('0x4c')]=_0x7418('0x5d');this['channels'][_0x4ea282['transfereeuniqueid']][_0x49d2c4][_0x7418('0x5e')]=_0x5e27b4[_0x7418('0x83')](this[_0x7418('0x9')][_0x4ea282['transfereeuniqueid']][_0x49d2c4][_0x7418('0x3c')],_0x7418('0x84'));}}}}}}catch(_0x15a3cc){logger['error'](_0x7418('0x8a'),_0x4ea282['uniqueid'],util['inspect'](_0x15a3cc,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')]['syncMusicOnHoldStart']=function(_0x833d86){var _0x124313='';try{if(this[_0x7418('0x21')](_0x833d86)){logger['debug'](_0x7418('0x8b'),_0x833d86[_0x7418('0x25')],util[_0x7418('0x34')](_0x833d86,{'showHidden':![],'depth':null}));if(_0x833d86['channel']){_0x124313=_0x833d86[_0x7418('0x8c')][_0x7418('0x8d')](0x0,_0x833d86['channel'][_0x7418('0x8e')]('-'));if(this['agents'][_0x124313]){logger[_0x7418('0x23')](_0x7418('0x8f'),_0x833d86['uniqueid'],_0x124313);this[_0x7418('0xb')][_0x124313][_0x7418('0x90')]=!![];}}}}catch(_0x37db2e){logger[_0x7418('0x38')](_0x7418('0x91'),_0x833d86[_0x7418('0x25')],util[_0x7418('0x34')](_0x37db2e,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x7418('0x20')][_0x7418('0x1a')]=function(_0x5df702){var _0x307553='';try{if(this[_0x7418('0x21')](_0x5df702)){logger['debug'](_0x7418('0x92'),_0x5df702['uniqueid'],util['inspect'](_0x5df702,{'showHidden':![],'depth':null}));if(_0x5df702[_0x7418('0x8c')]){_0x307553=_0x5df702[_0x7418('0x8c')]['substring'](0x0,_0x5df702[_0x7418('0x8c')][_0x7418('0x8e')]('-'));if(this[_0x7418('0xb')][_0x307553]){logger[_0x7418('0x23')](_0x7418('0x93'),_0x5df702['uniqueid'],_0x307553);this[_0x7418('0xb')][_0x307553][_0x7418('0x90')]=![];}}}}catch(_0x3ceb81){logger[_0x7418('0x38')](_0x7418('0x94'),_0x5df702['uniqueid'],util['inspect'](_0x3ceb81,{'showHidden':![],'depth':null}));}};module[_0x7418('0x95')]=VoiceAgentReport;