3cf79d4e3e503f25ca4556e8f804681b7d557b0e
[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 _0xc0d2=['rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqoslossbridged','rtpaudioqosrtt','sipcallid','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberlastcall','memberrealtime','isNil','includes','syncHangup','[%s][voiceAgentReport][hangup]\x20event:','[%s][voiceAgentReport][hangup]\x20destuniqueid:%s','[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:','values','custom:voiceAgentReport','[%s][voiceAgentReport][hangup]','transfereeuniqueid','origtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','complete','seconds','secondtransfereruniqueid','[%s][voiceAgentReport][blindtransfer]\x20event:','transfereruniqueid','[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','diff','[%s][voiceAgentReport][musiconholdstart]\x20event:','channel','substring','lastIndexOf','[%s][voiceAgentReport][musiconholdstart]\x20interface:%s','onhold','[%s][voiceAgentReport][musiconholdstart]','[%s][voiceAgentReport][musiconholdstop]\x20interface:%s','exports','moment','util','ioredis','../../../config/logger','ami','redis','defaults','localhost','socket.io-emitter','channels','voiceChannels','voiceQueues','agents','variables','syncAgentCalled','syncAgentConnect','bind','agentringnoanswer','syncAgentRingNoAnswer','queuecallerabandon','syncQueueCallerAbandon','agentcomplete','syncAgentComplete','varset','syncVarSet','musiconholdstart','syncMusicOnHoldStart','musiconholdstop','syncMusicOnHoldStop','syncAttendedTransfer','blindtransfer','syncBlindTransfer','prototype','emit','isNotNull','isUndefined','info','[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','uniqueid','membername','debug','[%s][voiceAgentReport][agentcalled]\x20event:','destuniqueid','queue','format','mandatoryDisposition','type','inbound','omit','event','privilege','[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:','inspect','calleridnum','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:','user:called','error','[%s][voiceAgentReport][agentcalled]','hasOwnProperty','agentconnectAt','YYYY-MM-DD\x20HH:mm:ss','connectedlinename','connectedlinenum','destchannelstate','destchannelstatedesc','holdtime','routealias','merge','pick','destconnectedlinenum','interface','name','accountcode','custom:agentconnect','user:agentconnect','agentringnoanswerAt','answeredelsewheredestinationuniqueid','answeredelsewheremembername','lastevent','answered_elsewhere','reason','[%s][voiceAgentReport][agentconnect]\x20Else\x20path\x20should\x20never\x20be\x20taken','[%s][voiceAgentReport][agentconnect]','[%s][voiceAgentReport][agentringnoanswer]\x20event:','[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected','[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:','user:%s','user:agentringnoanswer','custom:agentringnoanswer','assign','[%s][voiceAgentReport][queuecallerabandon]\x20event:','abandoned','custom:agentqueuecallerabandon','[%s][voiceAgentReport][queuecallerabandon]','[%s][voiceAgentReport][agentcomplete]\x20event:','[%s][voiceAgentReport][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','transfer','agent','talktime','acwtime','acwTimeout','[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:','custom:agentcomplete','[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:','destaccountcode','user:agentcomplete','[%s][voiceAgentReport][agentcomplete]','addVariable','keys','variable','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','value','[%s][voiceAgentReport][varset]','rtpaudioqos','rtpaudioqosbridged'];(function(_0x1ab683,_0x27030b){var _0x357546=function(_0x29a6b0){while(--_0x29a6b0){_0x1ab683['push'](_0x1ab683['shift']());}};_0x357546(++_0x27030b);}(_0xc0d2,0x163));var _0x2c0d=function(_0x2b4411,_0x2625ed){_0x2b4411=_0x2b4411-0x0;var _0x8e41ef=_0xc0d2[_0x2b4411];return _0x8e41ef;};'use strict';var _=require('lodash');var moment=require(_0x2c0d('0x0'));var util=require(_0x2c0d('0x1'));var Redis=require(_0x2c0d('0x2'));var config=require('../../../config/environment');var logger=require(_0x2c0d('0x3'))(_0x2c0d('0x4'));var ami=require('../ami');config[_0x2c0d('0x5')]=_[_0x2c0d('0x6')](config['redis'],{'host':_0x2c0d('0x7'),'port':0x18eb});var io=require(_0x2c0d('0x8'))(new Redis(config[_0x2c0d('0x5')]));function VoiceAgentReport(_0x4d2b05){this[_0x2c0d('0x9')]={};this[_0x2c0d('0xa')]=_0x4d2b05[_0x2c0d('0x9')];this['voiceQueues']=_0x4d2b05[_0x2c0d('0xb')];this[_0x2c0d('0xc')]=_0x4d2b05[_0x2c0d('0xc')];this[_0x2c0d('0xd')]={};ami['on']('agentcalled',this[_0x2c0d('0xe')]['bind'](this));ami['on']('agentconnect',this[_0x2c0d('0xf')][_0x2c0d('0x10')](this));ami['on'](_0x2c0d('0x11'),this[_0x2c0d('0x12')][_0x2c0d('0x10')](this));ami['on'](_0x2c0d('0x13'),this[_0x2c0d('0x14')]['bind'](this));ami['on'](_0x2c0d('0x15'),this[_0x2c0d('0x16')][_0x2c0d('0x10')](this));ami['on'](_0x2c0d('0x17'),this[_0x2c0d('0x18')]['bind'](this));ami['on']('hangup',this['syncHangup'][_0x2c0d('0x10')](this));ami['on'](_0x2c0d('0x19'),this[_0x2c0d('0x1a')][_0x2c0d('0x10')](this));ami['on'](_0x2c0d('0x1b'),this[_0x2c0d('0x1c')]['bind'](this));ami['on']('attendedtransfer',this[_0x2c0d('0x1d')][_0x2c0d('0x10')](this));ami['on'](_0x2c0d('0x1e'),this[_0x2c0d('0x1f')]['bind'](this));}VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0x21')]=function(_0x27d234,_0x5aba55,_0x2636c4){io['to'](_0x27d234)[_0x2c0d('0x21')](_0x5aba55,_0x2636c4);};VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0x22')]=function(_0xa30d5e){return _0xa30d5e!==null&&!_[_0x2c0d('0x23')](_0xa30d5e);};VoiceAgentReport['prototype'][_0x2c0d('0xe')]=function(_0x327954){try{if(this['isNotNull'](_0x327954)){logger[_0x2c0d('0x24')](_0x2c0d('0x25'),_0x327954[_0x2c0d('0x26')],_0x327954[_0x2c0d('0x27')],_0x327954['destuniqueid']);logger[_0x2c0d('0x28')](_0x2c0d('0x29'),_0x327954[_0x2c0d('0x26')],util['inspect'](_0x327954,{'showHidden':![],'depth':null}));if(_[_0x2c0d('0x23')](this[_0x2c0d('0x9')][_0x327954[_0x2c0d('0x26')]])){this[_0x2c0d('0x9')][_0x327954[_0x2c0d('0x26')]]={};}var _0x1aa6cf=this[_0x2c0d('0xc')][_0x327954['interface']];var _0x2f8b47=this[_0x2c0d('0x9')][_0x327954['uniqueid']][_0x327954[_0x2c0d('0x2a')]];var _0x57d9fc=this[_0x2c0d('0xb')][_0x327954[_0x2c0d('0x2b')]];var _0x1b08a1=this[_0x2c0d('0xd')][_0x327954['uniqueid']];if(_[_0x2c0d('0x23')](_0x2f8b47)){_0x2f8b47={'agentcalledAt':moment()[_0x2c0d('0x2c')]('YYYY-MM-DD\x20HH:mm:ss'),'lastevent':'called','mandatoryDisposition':_0x57d9fc&&_0x57d9fc[_0x2c0d('0x2d')]?_0x57d9fc[_0x2c0d('0x2d')]:![],'type':_0x57d9fc&&_0x57d9fc[_0x2c0d('0x2e')]?_0x57d9fc[_0x2c0d('0x2e')]:_0x2c0d('0x2f'),'variables':_0x1b08a1,'motionChannel':'voice'};}Object['assign'](_0x2f8b47,_[_0x2c0d('0x30')](_0x327954,[_0x2c0d('0x31'),_0x2c0d('0x32')]));this[_0x2c0d('0x9')][_0x327954['uniqueid']][_0x327954[_0x2c0d('0x2a')]]=_0x2f8b47;logger[_0x2c0d('0x28')](_0x2c0d('0x33'),_0x327954[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x2f8b47,{'showHidden':![],'depth':null}));ami[_0x2c0d('0x21')]('custom:agentcalled',_0x2f8b47);var _0x287bf5={'id':_0x1aa6cf['id'],'calleridnum':_0x2f8b47[_0x2c0d('0x35')],'queue':_0x2f8b47[_0x2c0d('0x2b')],'variables':_0x2f8b47['variables'],'uniqueid':_0x327954[_0x2c0d('0x26')]};logger[_0x2c0d('0x28')](_0x2c0d('0x36'),_0x327954[_0x2c0d('0x26')],util['inspect'](_0x287bf5,{'showHidden':![],'depth':null}));this['emit'](util['format']('user:%s',_0x327954[_0x2c0d('0x27')]),_0x2c0d('0x37'),_0x287bf5);}}catch(_0x537f0c){logger[_0x2c0d('0x38')](_0x2c0d('0x39'),_0x327954[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x537f0c,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0xf')]=function(_0x221533){try{if(this['isNotNull'](_0x221533)){if(this[_0x2c0d('0x9')][_0x221533['uniqueid']]){for(var _0x269082 in this['channels'][_0x221533[_0x2c0d('0x26')]]){if(this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x2c0d('0x3a')](_0x269082)){if(_0x221533[_0x2c0d('0x2a')]===_0x269082){logger[_0x2c0d('0x24')]('[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect',_0x221533[_0x2c0d('0x26')],_0x221533['membername'],_0x221533[_0x2c0d('0x2a')]);this[_0x2c0d('0x9')][_0x221533['uniqueid']][_0x269082][_0x2c0d('0x3b')]=moment()[_0x2c0d('0x2c')](_0x2c0d('0x3c'));this['channels'][_0x221533[_0x2c0d('0x26')]][_0x269082]['connectedlinename']=_0x221533[_0x2c0d('0x3d')];this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x3e')]=_0x221533[_0x2c0d('0x3e')];this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x3f')]=_0x221533[_0x2c0d('0x3f')];this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082]['destchannelstatedesc']=_0x221533[_0x2c0d('0x40')];this['channels'][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x41')]=_0x221533[_0x2c0d('0x41')];this[_0x2c0d('0x9')][_0x221533['uniqueid']][_0x269082]['lastevent']='connect';if(this[_0x2c0d('0xa')][this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x26')]]){var _0x31e6ca=this[_0x2c0d('0xa')][this['channels'][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x26')]]['routealias'];this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x42')]=_0x31e6ca;_0x221533['routealias']=_0x31e6ca;}_[_0x2c0d('0x43')](this[_0x2c0d('0xc')][_0x221533['interface']],_[_0x2c0d('0x44')](_0x221533,['queue',_0x2c0d('0x45'),_0x2c0d('0x42')]));var _0x2183f0=this[_0x2c0d('0xc')][_0x221533[_0x2c0d('0x46')]];var _0x1bdade={'id':_0x2183f0['id'],'name':_0x2183f0[_0x2c0d('0x47')],'agentconnected':!![],'destaccountcode':_0x2183f0[_0x2c0d('0x48')],'destconnectedlinenum':this['channels'][_0x221533['uniqueid']][_0x221533[_0x2c0d('0x2a')]]['exten'],'queue':this['channels'][_0x221533[_0x2c0d('0x26')]][_0x221533[_0x2c0d('0x2a')]][_0x2c0d('0x2b')],'routealias':this['channels'][_0x221533[_0x2c0d('0x26')]][_0x221533[_0x2c0d('0x2a')]][_0x2c0d('0x42')],'uniqueid':this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x221533['destuniqueid']][_0x2c0d('0x26')]};ami[_0x2c0d('0x21')](_0x2c0d('0x49'),this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x221533[_0x2c0d('0x2a')]]);this[_0x2c0d('0x21')](util[_0x2c0d('0x2c')]('user:%s',_0x221533[_0x2c0d('0x27')]),_0x2c0d('0x4a'),_0x1bdade);}else if(!this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082]['agentringnoanswer']&&!this['channels'][_0x221533[_0x2c0d('0x26')]][_0x269082]['agentcomplete']){logger[_0x2c0d('0x24')]('[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere',_0x221533[_0x2c0d('0x26')],this[_0x2c0d('0x9')][_0x221533['uniqueid']][_0x269082]['membername'],_0x269082);this[_0x2c0d('0x9')][_0x221533['uniqueid']][_0x269082][_0x2c0d('0x11')]=!![];this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x4b')]=moment()[_0x2c0d('0x2c')](_0x2c0d('0x3c'));this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x4c')]=_0x221533['destuniqueid'];this[_0x2c0d('0x9')][_0x221533['uniqueid']][_0x269082][_0x2c0d('0x4d')]=_0x221533[_0x2c0d('0x27')];this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x4e')]=_0x2c0d('0x4f');this['channels'][_0x221533[_0x2c0d('0x26')]][_0x269082][_0x2c0d('0x50')]=_0x2c0d('0x4f');logger['debug']('[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:',_0x221533[_0x2c0d('0x26')],util[_0x2c0d('0x34')](this['channels'][_0x221533[_0x2c0d('0x26')]][_0x269082],{'showHidden':![],'depth':null}));ami['emit']('custom:agentansweredelsewhere',this[_0x2c0d('0x9')][_0x221533[_0x2c0d('0x26')]][_0x269082]);}else{logger[_0x2c0d('0x28')](_0x2c0d('0x51'),_0x221533[_0x2c0d('0x26')]);}}}}}}catch(_0x593598){logger[_0x2c0d('0x38')](_0x2c0d('0x52'),_0x221533[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x593598,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0x12')]=function(_0x2094e9){try{if(this[_0x2c0d('0x22')](_0x2094e9)){logger[_0x2c0d('0x28')](_0x2c0d('0x53'),_0x2094e9[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x2094e9,{'showHidden':![],'depth':null}));if(this[_0x2c0d('0x9')][_0x2094e9[_0x2c0d('0x26')]]&&this[_0x2c0d('0x9')][_0x2094e9[_0x2c0d('0x26')]][_0x2094e9[_0x2c0d('0x2a')]]){logger[_0x2c0d('0x24')](_0x2c0d('0x54'),_0x2094e9['uniqueid'],_0x2094e9[_0x2c0d('0x27')],_0x2094e9[_0x2c0d('0x2a')]);var _0x387639=this[_0x2c0d('0xc')][_0x2094e9[_0x2c0d('0x46')]];var _0x209e70=this[_0x2c0d('0x9')][_0x2094e9[_0x2c0d('0x26')]][_0x2094e9[_0x2c0d('0x2a')]];_0x209e70[_0x2c0d('0x11')]=!![];_0x209e70[_0x2c0d('0x4b')]=moment()['format'](_0x2c0d('0x3c'));_0x209e70['lastevent']='rejected';_0x209e70[_0x2c0d('0x50')]='rejected';var _0x564d3d={'id':_0x387639['id'],'name':_0x387639['name'],'queue':_0x209e70[_0x2c0d('0x2b')],'uniqueid':_0x209e70[_0x2c0d('0x26')]};logger['debug'](_0x2c0d('0x55'),_0x2094e9[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x564d3d,{'showHidden':![],'depth':null}));this['emit'](util[_0x2c0d('0x2c')](_0x2c0d('0x56'),_0x387639[_0x2c0d('0x47')]),_0x2c0d('0x57'),_0x564d3d);ami[_0x2c0d('0x21')](_0x2c0d('0x58'),_0x209e70);this[_0x2c0d('0x9')][_0x2094e9[_0x2c0d('0x26')]][_0x2094e9[_0x2c0d('0x2a')]]=Object[_0x2c0d('0x59')]({},_0x209e70);}}}catch(_0x25507b){logger[_0x2c0d('0x38')]('[%s][voiceAgentReport][agentringnoanswer]',_0x2094e9[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x25507b,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')]['syncQueueCallerAbandon']=function(_0x181c83){try{if(this[_0x2c0d('0x22')](_0x181c83)){logger[_0x2c0d('0x28')](_0x2c0d('0x5a'),_0x181c83['uniqueid'],util['inspect'](_0x181c83,{'showHidden':![],'depth':null}));if(this[_0x2c0d('0x9')][_0x181c83['uniqueid']]){for(var _0x2cb8da in this[_0x2c0d('0x9')][_0x181c83['uniqueid']]){if(this['channels'][_0x181c83[_0x2c0d('0x26')]][_0x2c0d('0x3a')](_0x2cb8da)&&!this[_0x2c0d('0x9')][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da][_0x2c0d('0x11')]&&!this[_0x2c0d('0x9')][_0x181c83['uniqueid']][_0x2cb8da][_0x2c0d('0x15')]){logger['info']('[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x181c83['uniqueid'],this[_0x2c0d('0x9')][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da]['membername'],_0x2cb8da);this[_0x2c0d('0x9')][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da][_0x2c0d('0x11')]=!![];this[_0x2c0d('0x9')][_0x181c83['uniqueid']][_0x2cb8da]['agentringnoanswerAt']=moment()['format'](_0x2c0d('0x3c'));this['channels'][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da]['lastevent']='abandoned';this[_0x2c0d('0x9')][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da][_0x2c0d('0x50')]=_0x2c0d('0x5b');logger[_0x2c0d('0x28')]('[%s][voiceAgentReport][queuecallerabandon]\x20sending\x20agentqueuecallerabandon\x20event:',_0x181c83[_0x2c0d('0x26')],util[_0x2c0d('0x34')](this[_0x2c0d('0x9')][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da],{'showHidden':![],'depth':null}));ami['emit'](_0x2c0d('0x5c'),this[_0x2c0d('0x9')][_0x181c83[_0x2c0d('0x26')]][_0x2cb8da]);}}}}}catch(_0x52c7c7){logger[_0x2c0d('0x38')](_0x2c0d('0x5d'),_0x181c83['uniqueid'],util[_0x2c0d('0x34')](_0x52c7c7,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0x16')]=function(_0x37999f){try{if(this[_0x2c0d('0x22')](_0x37999f)){logger['debug'](_0x2c0d('0x5e'),_0x37999f[_0x2c0d('0x26')],util['inspect'](_0x37999f,{'showHidden':![],'depth':null}));if(this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]]){for(var _0x40e91d in this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]]){if(this[_0x2c0d('0x9')][_0x37999f['uniqueid']][_0x2c0d('0x3a')](_0x40e91d)){if(this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d][_0x2c0d('0x3b')]&&!this['channels'][_0x37999f['uniqueid']][_0x40e91d][_0x2c0d('0x15')]){logger[_0x2c0d('0x24')](_0x2c0d('0x5f'),_0x37999f['uniqueid'],this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d]['membername'],_0x40e91d);this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d]['agentcomplete']=!![];this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d][_0x2c0d('0x60')]=moment()[_0x2c0d('0x2c')](_0x2c0d('0x3c'));this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d][_0x2c0d('0x4e')]='complete';this['channels'][_0x37999f['uniqueid']][_0x40e91d][_0x2c0d('0x50')]=_0x37999f['reason']==_0x2c0d('0x61')?_0x2c0d('0x62'):_0x37999f[_0x2c0d('0x50')];this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d][_0x2c0d('0x63')]=_0x37999f['talktime'];if(this['voiceQueues'][_0x37999f[_0x2c0d('0x2b')]]&&this['voiceQueues'][_0x37999f[_0x2c0d('0x2b')]]['acw']){this[_0x2c0d('0x9')][_0x37999f['uniqueid']][_0x40e91d][_0x2c0d('0x64')]=this[_0x2c0d('0xb')][_0x37999f[_0x2c0d('0x2b')]][_0x2c0d('0x65')];this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d]['agentacw']=!![];}this['agents'][_0x37999f[_0x2c0d('0x46')]]=_['omit'](this[_0x2c0d('0xc')][_0x37999f[_0x2c0d('0x46')]],[_0x2c0d('0x2b'),_0x2c0d('0x45')]);logger[_0x2c0d('0x28')](_0x2c0d('0x66'),_0x37999f[_0x2c0d('0x26')],util['inspect'](this[_0x2c0d('0x9')][_0x37999f[_0x2c0d('0x26')]][_0x40e91d],{'showHidden':![],'depth':null}));ami[_0x2c0d('0x21')](_0x2c0d('0x67'),this['channels'][_0x37999f[_0x2c0d('0x26')]][_0x40e91d]);logger['debug'](_0x2c0d('0x68'),_0x37999f[_0x2c0d('0x26')],util[_0x2c0d('0x34')]({'id':this[_0x2c0d('0xc')][_0x37999f[_0x2c0d('0x46')]]['id'],'destaccountcode':_0x37999f[_0x2c0d('0x69')]},{'showHidden':![],'depth':null}));this[_0x2c0d('0x21')](util[_0x2c0d('0x2c')](_0x2c0d('0x56'),_0x37999f[_0x2c0d('0x27')]),_0x2c0d('0x6a'),{'id':this['agents'][_0x37999f[_0x2c0d('0x46')]]['id'],'destaccountcode':Number(_0x37999f[_0x2c0d('0x69')])});}}}}}}catch(_0x127f1e){logger[_0x2c0d('0x38')](_0x2c0d('0x6b'),_0x37999f[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x127f1e,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0x18')]=function(_0x5bdc95){try{if(this[_0x2c0d('0x22')](_0x5bdc95)){logger[_0x2c0d('0x28')]('[%s][voiceAgentReport][varset]\x20event:',_0x5bdc95[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x5bdc95,{'showHidden':![],'depth':null}));this[_0x2c0d('0x6c')](_0x5bdc95[_0x2c0d('0x26')],_[_0x2c0d('0x6d')](_0x5bdc95[_0x2c0d('0x6e')])[0x0],_0x5bdc95['value']);if(this[_0x2c0d('0x9')][_0x5bdc95['uniqueid']]){for(var _0x27d099 in this['channels'][_0x5bdc95[_0x2c0d('0x26')]]){if(this[_0x2c0d('0x9')][_0x5bdc95[_0x2c0d('0x26')]]['hasOwnProperty'](_0x27d099)){logger[_0x2c0d('0x24')](_0x2c0d('0x6f'),_0x5bdc95[_0x2c0d('0x26')],_0x27d099,_[_0x2c0d('0x6d')](_0x5bdc95['variable'])[0x0],_0x5bdc95[_0x2c0d('0x70')]);if(_[_0x2c0d('0x23')](this['channels'][_0x5bdc95[_0x2c0d('0x26')]][_0x27d099][_0x2c0d('0xd')])){this[_0x2c0d('0x9')][_0x5bdc95[_0x2c0d('0x26')]][_0x27d099][_0x2c0d('0xd')]={};}this[_0x2c0d('0x9')][_0x5bdc95['uniqueid']][_0x27d099][_0x2c0d('0xd')]=this[_0x2c0d('0xd')][_0x5bdc95[_0x2c0d('0x26')]];}}}}}catch(_0x22cf4f){logger[_0x2c0d('0x38')](_0x2c0d('0x71'),_0x5bdc95[_0x2c0d('0x26')],util['inspect'](_0x22cf4f,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x2c0d('0x6c')]=function(_0x20d1d5,_0x45cbee,_0x1a6b12){var _0x254cb4=[_0x2c0d('0x72'),_0x2c0d('0x73'),_0x2c0d('0x74'),_0x2c0d('0x75'),'rtpaudioqosloss',_0x2c0d('0x76'),_0x2c0d('0x77'),'rtpaudioqosrttbridged',_0x2c0d('0x78'),_0x2c0d('0x79'),_0x2c0d('0x7a'),_0x2c0d('0x7b'),_0x2c0d('0x7c'),_0x2c0d('0x7d'),_0x2c0d('0x7e'),_0x2c0d('0x7f'),_0x2c0d('0x27'),'memberpenalty',_0x2c0d('0x80')];if(!_[_0x2c0d('0x81')](_0x45cbee)&&!_[_0x2c0d('0x82')](_0x254cb4,_0x45cbee)){if(_['isUndefined'](this[_0x2c0d('0xd')][_0x20d1d5])){this[_0x2c0d('0xd')][_0x20d1d5]={};}this[_0x2c0d('0xd')][_0x20d1d5][_0x45cbee]=_0x1a6b12;}};VoiceAgentReport['prototype'][_0x2c0d('0x83')]=function(_0x582c92){try{if(this[_0x2c0d('0x22')](_0x582c92)){logger[_0x2c0d('0x28')](_0x2c0d('0x84'),_0x582c92['uniqueid'],util[_0x2c0d('0x34')](_0x582c92,{'showHidden':![],'depth':null}));if(this[_0x2c0d('0x9')][_0x582c92['uniqueid']]){for(var _0x26411a in this[_0x2c0d('0x9')][_0x582c92['uniqueid']]){if(this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]][_0x2c0d('0x3a')](_0x26411a)){if(this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]][_0x26411a]['reason']==_0x2c0d('0x61')&&this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]][_0x26411a][_0x2c0d('0x15')]){logger[_0x2c0d('0x24')](_0x2c0d('0x85'),_0x582c92[_0x2c0d('0x26')],_0x26411a);this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]][_0x26411a][_0x2c0d('0x60')]=moment()['format'](_0x2c0d('0x3c'));}}}logger['debug'](_0x2c0d('0x86'),_0x582c92['uniqueid'],util[_0x2c0d('0x34')](_[_0x2c0d('0x87')](this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]]),{'showHidden':![],'depth':null}));ami[_0x2c0d('0x21')](_0x2c0d('0x88'),_[_0x2c0d('0x87')](this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]]));delete this[_0x2c0d('0x9')][_0x582c92[_0x2c0d('0x26')]];}if(this[_0x2c0d('0xd')][_0x582c92['uniqueid']]){delete this[_0x2c0d('0xd')][_0x582c92[_0x2c0d('0x26')]];}}}catch(_0xb5e935){logger[_0x2c0d('0x38')](_0x2c0d('0x89'),_0x582c92['uniqueid'],util[_0x2c0d('0x34')](_0xb5e935,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x2c0d('0x1d')]=function(_0x20750e){try{if(this[_0x2c0d('0x22')](_0x20750e)){logger['debug']('[%s][voiceAgentReport][attendedtransfer]\x20event:',_0x20750e['uniqueid'],util[_0x2c0d('0x34')](_0x20750e,{'showHidden':![],'depth':null}));if(this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]]){for(var _0x48f788 in this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]]){if(this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]]['hasOwnProperty'](_0x48f788)){if(_0x20750e[_0x2c0d('0x8b')]===_0x48f788){logger[_0x2c0d('0x24')](_0x2c0d('0x8c'),_0x20750e[_0x2c0d('0x26')],this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]][_0x48f788][_0x2c0d('0x27')],_0x48f788);var _0x1bf5f8=moment();this['channels'][_0x20750e['transfereeuniqueid']][_0x48f788][_0x2c0d('0x15')]=!![];this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]][_0x48f788]['agentcompleteAt']=moment()[_0x2c0d('0x2c')](_0x2c0d('0x3c'));this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]][_0x48f788][_0x2c0d('0x4e')]=_0x2c0d('0x8d');this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]][_0x48f788][_0x2c0d('0x50')]=_0x2c0d('0x61');this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]][_0x48f788][_0x2c0d('0x63')]=_0x1bf5f8['diff'](this['channels'][_0x20750e[_0x2c0d('0x8a')]][_0x48f788][_0x2c0d('0x3b')],_0x2c0d('0x8e'));}}}}if(this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8f')]]){var _0x38f699=this[_0x2c0d('0x9')][_0x20750e['secondtransfereruniqueid']];this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8f')]]=this[_0x2c0d('0x9')][_0x20750e[_0x2c0d('0x8a')]];this['channels'][_0x20750e[_0x2c0d('0x8a')]]=_0x38f699;}}}catch(_0x253682){logger['error']('[%s][voiceAgentReport][attendedtransfer]',_0x20750e[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x253682,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')]['syncBlindTransfer']=function(_0x3bec1e){try{if(this[_0x2c0d('0x22')](_0x3bec1e)){logger[_0x2c0d('0x28')](_0x2c0d('0x90'),_0x3bec1e[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x3bec1e,{'showHidden':![],'depth':null}));if(this[_0x2c0d('0x9')][_0x3bec1e[_0x2c0d('0x8a')]]){for(var _0x4bb25e in this['channels'][_0x3bec1e[_0x2c0d('0x8a')]]){if(this['channels'][_0x3bec1e[_0x2c0d('0x8a')]][_0x2c0d('0x3a')](_0x4bb25e)){if(_0x3bec1e[_0x2c0d('0x91')]===_0x4bb25e){logger[_0x2c0d('0x24')](_0x2c0d('0x92'),_0x3bec1e[_0x2c0d('0x26')],this[_0x2c0d('0x9')][_0x3bec1e[_0x2c0d('0x8a')]][_0x4bb25e][_0x2c0d('0x27')],_0x4bb25e);var _0x4cf9fb=moment();this[_0x2c0d('0x9')][_0x3bec1e[_0x2c0d('0x8a')]][_0x4bb25e][_0x2c0d('0x15')]=!![];this[_0x2c0d('0x9')][_0x3bec1e[_0x2c0d('0x8a')]][_0x4bb25e][_0x2c0d('0x60')]=_0x4cf9fb;this['channels'][_0x3bec1e[_0x2c0d('0x8a')]][_0x4bb25e][_0x2c0d('0x4e')]='complete';this[_0x2c0d('0x9')][_0x3bec1e['transfereeuniqueid']][_0x4bb25e]['reason']=_0x2c0d('0x61');this[_0x2c0d('0x9')][_0x3bec1e[_0x2c0d('0x8a')]][_0x4bb25e]['talktime']=_0x4cf9fb[_0x2c0d('0x93')](this[_0x2c0d('0x9')][_0x3bec1e[_0x2c0d('0x8a')]][_0x4bb25e][_0x2c0d('0x3b')],_0x2c0d('0x8e'));}}}}}}catch(_0x2445ba){logger[_0x2c0d('0x38')]('[%s][voiceAgentReport][blindtransfer]',_0x3bec1e[_0x2c0d('0x26')],util['inspect'](_0x2445ba,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x2c0d('0x1a')]=function(_0x545a01){var _0x1f2105='';try{if(this[_0x2c0d('0x22')](_0x545a01)){logger[_0x2c0d('0x28')](_0x2c0d('0x94'),_0x545a01['uniqueid'],util[_0x2c0d('0x34')](_0x545a01,{'showHidden':![],'depth':null}));if(_0x545a01[_0x2c0d('0x95')]){_0x1f2105=_0x545a01[_0x2c0d('0x95')][_0x2c0d('0x96')](0x0,_0x545a01[_0x2c0d('0x95')][_0x2c0d('0x97')]('-'));if(this['agents'][_0x1f2105]){logger[_0x2c0d('0x24')](_0x2c0d('0x98'),_0x545a01[_0x2c0d('0x26')],_0x1f2105);this[_0x2c0d('0xc')][_0x1f2105][_0x2c0d('0x99')]=!![];}}}}catch(_0x10eeab){logger[_0x2c0d('0x38')](_0x2c0d('0x9a'),_0x545a01['uniqueid'],util[_0x2c0d('0x34')](_0x10eeab,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x2c0d('0x20')][_0x2c0d('0x1c')]=function(_0x1b0b69){var _0xe9522e='';try{if(this[_0x2c0d('0x22')](_0x1b0b69)){logger[_0x2c0d('0x28')]('[%s][voiceAgentReport][musiconholdstop]\x20event:',_0x1b0b69[_0x2c0d('0x26')],util['inspect'](_0x1b0b69,{'showHidden':![],'depth':null}));if(_0x1b0b69['channel']){_0xe9522e=_0x1b0b69[_0x2c0d('0x95')][_0x2c0d('0x96')](0x0,_0x1b0b69[_0x2c0d('0x95')][_0x2c0d('0x97')]('-'));if(this[_0x2c0d('0xc')][_0xe9522e]){logger['info'](_0x2c0d('0x9b'),_0x1b0b69[_0x2c0d('0x26')],_0xe9522e);this[_0x2c0d('0xc')][_0xe9522e][_0x2c0d('0x99')]=![];}}}}catch(_0x1abeeb){logger['error']('[%s][voiceAgentReport][musiconholdstop]',_0x1b0b69[_0x2c0d('0x26')],util[_0x2c0d('0x34')](_0x1abeeb,{'showHidden':![],'depth':null}));}};module[_0x2c0d('0x9c')]=VoiceAgentReport;