Built motion from commit 19a84241.|2.5.34
[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 _0xee8f=['rtpaudioqosrtt','sipcallid','bridgepeer','memberinterface','memberpenalty','memberrealtime','isNil','[%s][voiceAgentReport][hangup]\x20event:','[%s][voiceAgentReport][hangup]\x20destuniqueid:%s','[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:','values','custom:voiceAgentReport','[%s][voiceAgentReport][hangup]','syncAttendedTransfer','transfereeuniqueid','origtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','diff','secondtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]','[%s][voiceAgentReport][blindtransfer]\x20event:','transfereruniqueid','[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','complete','seconds','[%s][voiceAgentReport][musiconholdstart]\x20event:','channel','lastIndexOf','[%s][voiceAgentReport][musiconholdstart]\x20interface:%s','[%s][voiceAgentReport][musiconholdstart]','substring','onhold','[%s][voiceAgentReport][musiconholdstop]','exports','moment','ioredis','../../../config/environment','../../../config/logger','ami','redis','localhost','socket.io-emitter','channels','voiceQueues','agents','agentcalled','syncAgentCalled','bind','agentconnect','syncAgentConnect','agentringnoanswer','syncAgentRingNoAnswer','agentcomplete','syncAgentComplete','syncVarSet','hangup','syncHangup','musiconholdstart','syncMusicOnHoldStart','musiconholdstop','syncMusicOnHoldStop','attendedtransfer','blindtransfer','syncBlindTransfer','prototype','emit','isNotNull','isUndefined','info','[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','uniqueid','membername','destuniqueid','debug','format','called','queue','mandatoryDisposition','type','inbound','variables','merge','omit','event','privilege','[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:','inspect','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:','[%s][voiceAgentReport][agentcalled]','[%s][voiceAgentReport][agentconnect]\x20event:','hasOwnProperty','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect','agentconnectAt','YYYY-MM-DD\x20HH:mm:ss','connectedlinenum','destchannelstate','destchannelstatedesc','holdtime','lastevent','voiceChannels','routealias','pick','destconnectedlinenum','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentconnect\x20event:','custom:agentconnect','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:agentconnect\x20event:','user:%s','user:agentconnect','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere','answeredelsewheredestinationuniqueid','answeredelsewheremembername','answered_elsewhere','reason','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:','custom:agentansweredelsewhere','error','[%s][voiceAgentReport][agentconnect]','[%s][voiceAgentReport][agentringnoanswer]\x20event:','[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected','agentringnoanswerAt','rejected','[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:','[%s][voiceAgentReport][agentringnoanswer]','syncQueueCallerAbandon','[%s][voiceAgentReport][queuecallerabandon]\x20event:','abandoned','[%s][voiceAgentReport][queuecallerabandon]\x20sending\x20agentqueuecallerabandon\x20event:','custom:agentqueuecallerabandon','[%s][voiceAgentReport][agentcomplete]\x20event:','[%s][voiceAgentReport][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','transfer','agent','talktime','acw','acwtime','agentacw','interface','custom:agentcomplete','[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:','user:agentcomplete','[%s][voiceAgentReport][agentcomplete]','[%s][voiceAgentReport][varset]\x20event:','addVariable','keys','value','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','variable','[%s][voiceAgentReport][varset]','rtpaudioqos','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged'];(function(_0x19980b,_0x4e3fc7){var _0x52fc1e=function(_0x23fe71){while(--_0x23fe71){_0x19980b['push'](_0x19980b['shift']());}};_0x52fc1e(++_0x4e3fc7);}(_0xee8f,0x1ed));var _0xfee8=function(_0x21a9d9,_0x4d5ac8){_0x21a9d9=_0x21a9d9-0x0;var _0x46adce=_0xee8f[_0x21a9d9];return _0x46adce;};'use strict';var _=require('lodash');var moment=require(_0xfee8('0x0'));var util=require('util');var Redis=require(_0xfee8('0x1'));var config=require(_0xfee8('0x2'));var logger=require(_0xfee8('0x3'))(_0xfee8('0x4'));var ami=require('../ami');config['redis']=_['defaults'](config[_0xfee8('0x5')],{'host':_0xfee8('0x6'),'port':0x18eb});var io=require(_0xfee8('0x7'))(new Redis(config['redis']));function VoiceAgentReport(_0x1edd18){this[_0xfee8('0x8')]={};this['voiceChannels']=_0x1edd18['channels'];this[_0xfee8('0x9')]=_0x1edd18[_0xfee8('0x9')];this[_0xfee8('0xa')]=_0x1edd18['agents'];this['variables']={};ami['on'](_0xfee8('0xb'),this[_0xfee8('0xc')][_0xfee8('0xd')](this));ami['on'](_0xfee8('0xe'),this[_0xfee8('0xf')][_0xfee8('0xd')](this));ami['on'](_0xfee8('0x10'),this[_0xfee8('0x11')]['bind'](this));ami['on']('queuecallerabandon',this['syncQueueCallerAbandon'][_0xfee8('0xd')](this));ami['on'](_0xfee8('0x12'),this[_0xfee8('0x13')]['bind'](this));ami['on']('varset',this[_0xfee8('0x14')][_0xfee8('0xd')](this));ami['on'](_0xfee8('0x15'),this[_0xfee8('0x16')][_0xfee8('0xd')](this));ami['on'](_0xfee8('0x17'),this[_0xfee8('0x18')][_0xfee8('0xd')](this));ami['on'](_0xfee8('0x19'),this[_0xfee8('0x1a')][_0xfee8('0xd')](this));ami['on'](_0xfee8('0x1b'),this['syncAttendedTransfer']['bind'](this));ami['on'](_0xfee8('0x1c'),this[_0xfee8('0x1d')]['bind'](this));}VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x1f')]=function(_0x59c29e,_0x45df7b,_0x587c14){io['to'](_0x59c29e)['emit'](_0x45df7b,_0x587c14);};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x20')]=function(_0x28e91d){return _0x28e91d!==null&&!_[_0xfee8('0x21')](_0x28e91d);};VoiceAgentReport['prototype'][_0xfee8('0xc')]=function(_0x3308e5){try{if(this[_0xfee8('0x20')](_0x3308e5)){logger[_0xfee8('0x22')](_0xfee8('0x23'),_0x3308e5[_0xfee8('0x24')],_0x3308e5[_0xfee8('0x25')],_0x3308e5[_0xfee8('0x26')]);logger[_0xfee8('0x27')]('[%s][voiceAgentReport][agentcalled]\x20event:',_0x3308e5[_0xfee8('0x24')],util['inspect'](_0x3308e5,{'showHidden':![],'depth':null}));if(_[_0xfee8('0x21')](this['channels'][_0x3308e5[_0xfee8('0x24')]])){this[_0xfee8('0x8')][_0x3308e5['uniqueid']]={};}if(_[_0xfee8('0x21')](this[_0xfee8('0x8')][_0x3308e5['uniqueid']][_0x3308e5[_0xfee8('0x26')]])){this[_0xfee8('0x8')][_0x3308e5[_0xfee8('0x24')]][_0x3308e5[_0xfee8('0x26')]]={'agentcalledAt':moment()[_0xfee8('0x28')]('YYYY-MM-DD\x20HH:mm:ss'),'lastevent':_0xfee8('0x29'),'mandatoryDisposition':this[_0xfee8('0x9')][_0x3308e5[_0xfee8('0x2a')]]?this[_0xfee8('0x9')][_0x3308e5[_0xfee8('0x2a')]][_0xfee8('0x2b')]||![]:![],'type':this[_0xfee8('0x9')][_0x3308e5[_0xfee8('0x2a')]]?this[_0xfee8('0x9')][_0x3308e5[_0xfee8('0x2a')]][_0xfee8('0x2c')]||_0xfee8('0x2d'):'inbound','variables':this[_0xfee8('0x2e')][_0x3308e5[_0xfee8('0x24')]],'motionChannel':'voice'};}_[_0xfee8('0x2f')](this['channels'][_0x3308e5['uniqueid']][_0x3308e5[_0xfee8('0x26')]],_[_0xfee8('0x30')](_0x3308e5,[_0xfee8('0x31'),_0xfee8('0x32')]));logger[_0xfee8('0x27')](_0xfee8('0x33'),_0x3308e5['uniqueid'],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x3308e5[_0xfee8('0x24')]][_0x3308e5[_0xfee8('0x26')]],{'showHidden':![],'depth':null}));ami['emit']('custom:agentcalled',this[_0xfee8('0x8')][_0x3308e5[_0xfee8('0x24')]][_0x3308e5[_0xfee8('0x26')]]);logger[_0xfee8('0x27')](_0xfee8('0x35'),_0x3308e5[_0xfee8('0x24')],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x3308e5[_0xfee8('0x24')]][_0x3308e5[_0xfee8('0x26')]],{'showHidden':![],'depth':null}));this['emit'](util[_0xfee8('0x28')]('user:%s',_0x3308e5['membername']),'user:called',this[_0xfee8('0x8')][_0x3308e5[_0xfee8('0x24')]][_0x3308e5[_0xfee8('0x26')]]);}}catch(_0x230003){logger['error'](_0xfee8('0x36'),_0x3308e5[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x230003,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0xf')]=function(_0x14aef8){try{if(this[_0xfee8('0x20')](_0x14aef8)){if(this['channels'][_0x14aef8[_0xfee8('0x24')]]){logger[_0xfee8('0x27')](_0xfee8('0x37'),_0x14aef8[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x14aef8,{'showHidden':![],'depth':null}));for(var _0x1b2531 in this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]]){if(this['channels'][_0x14aef8['uniqueid']][_0xfee8('0x38')](_0x1b2531)){if(_0x14aef8[_0xfee8('0x26')]===_0x1b2531){logger[_0xfee8('0x22')](_0xfee8('0x39'),_0x14aef8[_0xfee8('0x24')],_0x14aef8[_0xfee8('0x25')],_0x14aef8[_0xfee8('0x26')]);this['channels'][_0x14aef8['uniqueid']][_0x1b2531][_0xfee8('0x3a')]=moment()[_0xfee8('0x28')](_0xfee8('0x3b'));this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531]['connectedlinename']=_0x14aef8['connectedlinename'];this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x3c')]=_0x14aef8[_0xfee8('0x3c')];this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x3d')]=_0x14aef8['destchannelstate'];this[_0xfee8('0x8')][_0x14aef8['uniqueid']][_0x1b2531][_0xfee8('0x3e')]=_0x14aef8[_0xfee8('0x3e')];this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x3f')]=_0x14aef8[_0xfee8('0x3f')];this[_0xfee8('0x8')][_0x14aef8['uniqueid']][_0x1b2531][_0xfee8('0x40')]='connect';if(this[_0xfee8('0x41')][this['channels'][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x24')]]){var _0x174776=this[_0xfee8('0x41')][this['channels'][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x24')]][_0xfee8('0x42')];this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531]['routealias']=_0x174776;_0x14aef8[_0xfee8('0x42')]=_0x174776;}_['merge'](this[_0xfee8('0xa')][_0x14aef8['interface']],_[_0xfee8('0x43')](_0x14aef8,[_0xfee8('0x2a'),_0xfee8('0x44'),_0xfee8('0x42')]));logger[_0xfee8('0x27')](_0xfee8('0x45'),_0x14aef8[_0xfee8('0x24')],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x14aef8[_0xfee8('0x26')]],{'showHidden':![],'depth':null}));ami[_0xfee8('0x1f')](_0xfee8('0x46'),this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x14aef8[_0xfee8('0x26')]]);logger[_0xfee8('0x27')](_0xfee8('0x47'),_0x14aef8['uniqueid'],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x14aef8['uniqueid']][_0x14aef8[_0xfee8('0x26')]],{'showHidden':![],'depth':null}));this[_0xfee8('0x1f')](util[_0xfee8('0x28')](_0xfee8('0x48'),_0x14aef8[_0xfee8('0x25')]),_0xfee8('0x49'),this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x14aef8[_0xfee8('0x26')]]);}else if(!this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x10')]&&!this[_0xfee8('0x8')][_0x14aef8['uniqueid']][_0x1b2531][_0xfee8('0x12')]){logger['info'](_0xfee8('0x4a'),_0x14aef8[_0xfee8('0x24')],this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x25')],_0x1b2531);this['channels'][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x10')]=!![];this['channels'][_0x14aef8[_0xfee8('0x24')]][_0x1b2531]['agentringnoanswerAt']=moment()[_0xfee8('0x28')](_0xfee8('0x3b'));this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x4b')]=_0x14aef8['destuniqueid'];this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x4c')]=_0x14aef8[_0xfee8('0x25')];this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x40')]=_0xfee8('0x4d');this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531][_0xfee8('0x4e')]=_0xfee8('0x4d');logger[_0xfee8('0x27')](_0xfee8('0x4f'),_0x14aef8[_0xfee8('0x24')],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x14aef8[_0xfee8('0x24')]][_0x1b2531],{'showHidden':![],'depth':null}));ami[_0xfee8('0x1f')](_0xfee8('0x50'),this[_0xfee8('0x8')][_0x14aef8['uniqueid']][_0x1b2531]);}}}}}}catch(_0x443fb4){logger[_0xfee8('0x51')](_0xfee8('0x52'),_0x14aef8[_0xfee8('0x24')],util['inspect'](_0x443fb4,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x11')]=function(_0x4c85e2){try{if(this[_0xfee8('0x20')](_0x4c85e2)){logger['debug'](_0xfee8('0x53'),_0x4c85e2[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x4c85e2,{'showHidden':![],'depth':null}));if(this[_0xfee8('0x8')][_0x4c85e2[_0xfee8('0x24')]]&&this[_0xfee8('0x8')][_0x4c85e2['uniqueid']][_0x4c85e2[_0xfee8('0x26')]]){logger['info'](_0xfee8('0x54'),_0x4c85e2[_0xfee8('0x24')],_0x4c85e2[_0xfee8('0x25')],_0x4c85e2[_0xfee8('0x26')]);this[_0xfee8('0x8')][_0x4c85e2[_0xfee8('0x24')]][_0x4c85e2[_0xfee8('0x26')]][_0xfee8('0x10')]=!![];this[_0xfee8('0x8')][_0x4c85e2[_0xfee8('0x24')]][_0x4c85e2[_0xfee8('0x26')]][_0xfee8('0x55')]=moment()['format'](_0xfee8('0x3b'));this[_0xfee8('0x8')][_0x4c85e2[_0xfee8('0x24')]][_0x4c85e2['destuniqueid']][_0xfee8('0x40')]=_0xfee8('0x56');this[_0xfee8('0x8')][_0x4c85e2[_0xfee8('0x24')]][_0x4c85e2[_0xfee8('0x26')]][_0xfee8('0x4e')]='rejected';logger[_0xfee8('0x27')](_0xfee8('0x57'),_0x4c85e2[_0xfee8('0x24')],util[_0xfee8('0x34')](this['channels'][_0x4c85e2[_0xfee8('0x24')]][_0x4c85e2['destuniqueid']],{'showHidden':![],'depth':null}));ami['emit']('custom:agentringnoanswer',this['channels'][_0x4c85e2[_0xfee8('0x24')]][_0x4c85e2[_0xfee8('0x26')]]);}}}catch(_0x90b4a1){logger[_0xfee8('0x51')](_0xfee8('0x58'),_0x4c85e2['uniqueid'],util['inspect'](_0x90b4a1,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xfee8('0x59')]=function(_0x36dc1b){try{if(this[_0xfee8('0x20')](_0x36dc1b)){logger[_0xfee8('0x27')](_0xfee8('0x5a'),_0x36dc1b['uniqueid'],util[_0xfee8('0x34')](_0x36dc1b,{'showHidden':![],'depth':null}));if(this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]]){for(var _0x3ff608 in this[_0xfee8('0x8')][_0x36dc1b['uniqueid']]){if(this['channels'][_0x36dc1b['uniqueid']][_0xfee8('0x38')](_0x3ff608)&&!this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608][_0xfee8('0x10')]&&!this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608][_0xfee8('0x12')]){logger[_0xfee8('0x22')]('[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x36dc1b[_0xfee8('0x24')],this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608][_0xfee8('0x25')],_0x3ff608);this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608][_0xfee8('0x10')]=!![];this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608][_0xfee8('0x55')]=moment()[_0xfee8('0x28')](_0xfee8('0x3b'));this['channels'][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608][_0xfee8('0x40')]=_0xfee8('0x5b');this[_0xfee8('0x8')][_0x36dc1b['uniqueid']][_0x3ff608][_0xfee8('0x4e')]=_0xfee8('0x5b');logger[_0xfee8('0x27')](_0xfee8('0x5c'),_0x36dc1b[_0xfee8('0x24')],util['inspect'](this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608],{'showHidden':![],'depth':null}));ami[_0xfee8('0x1f')](_0xfee8('0x5d'),this[_0xfee8('0x8')][_0x36dc1b[_0xfee8('0x24')]][_0x3ff608]);}}}}}catch(_0x17cb1b){logger[_0xfee8('0x51')]('[%s][voiceAgentReport][queuecallerabandon]',_0x36dc1b[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x17cb1b,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xfee8('0x1e')]['syncAgentComplete']=function(_0x2fee25){try{if(this[_0xfee8('0x20')](_0x2fee25)){logger['debug'](_0xfee8('0x5e'),_0x2fee25[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x2fee25,{'showHidden':![],'depth':null}));if(this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]]){for(var _0x3e70d9 in this['channels'][_0x2fee25['uniqueid']]){if(this['channels'][_0x2fee25[_0xfee8('0x24')]][_0xfee8('0x38')](_0x3e70d9)){if(this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9]['agentconnectAt']&&!this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9][_0xfee8('0x12')]){logger['info'](_0xfee8('0x5f'),_0x2fee25[_0xfee8('0x24')],this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9]['membername'],_0x3e70d9);this[_0xfee8('0x8')][_0x2fee25['uniqueid']][_0x3e70d9][_0xfee8('0x12')]=!![];this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9][_0xfee8('0x60')]=moment()[_0xfee8('0x28')](_0xfee8('0x3b'));this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9][_0xfee8('0x40')]='complete';this['channels'][_0x2fee25['uniqueid']][_0x3e70d9][_0xfee8('0x4e')]=_0x2fee25['reason']==_0xfee8('0x61')?_0xfee8('0x62'):_0x2fee25[_0xfee8('0x4e')];this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9][_0xfee8('0x63')]=_0x2fee25['talktime'];if(this[_0xfee8('0x9')][_0x2fee25[_0xfee8('0x2a')]]&&this['voiceQueues'][_0x2fee25[_0xfee8('0x2a')]][_0xfee8('0x64')]){this[_0xfee8('0x8')][_0x2fee25['uniqueid']][_0x3e70d9][_0xfee8('0x65')]=this[_0xfee8('0x9')][_0x2fee25[_0xfee8('0x2a')]]['acwTimeout'];this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9][_0xfee8('0x66')]=!![];}this['agents'][_0x2fee25[_0xfee8('0x67')]]=_[_0xfee8('0x30')](this[_0xfee8('0xa')][_0x2fee25[_0xfee8('0x67')]],[_0xfee8('0x2a'),'destconnectedlinenum']);logger[_0xfee8('0x27')]('[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:',_0x2fee25[_0xfee8('0x24')],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9],{'showHidden':![],'depth':null}));ami[_0xfee8('0x1f')](_0xfee8('0x68'),this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9]);logger[_0xfee8('0x27')](_0xfee8('0x69'),_0x2fee25[_0xfee8('0x24')],util[_0xfee8('0x34')](this[_0xfee8('0x8')][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9],{'showHidden':![],'depth':null}));this['emit'](util[_0xfee8('0x28')](_0xfee8('0x48'),_0x2fee25[_0xfee8('0x25')]),_0xfee8('0x6a'),this['channels'][_0x2fee25[_0xfee8('0x24')]][_0x3e70d9]);}}}}}}catch(_0x28f171){logger[_0xfee8('0x51')](_0xfee8('0x6b'),_0x2fee25[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x28f171,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x14')]=function(_0x4dcdfb){try{if(this['isNotNull'](_0x4dcdfb)){logger[_0xfee8('0x27')](_0xfee8('0x6c'),_0x4dcdfb[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x4dcdfb,{'showHidden':![],'depth':null}));this[_0xfee8('0x6d')](_0x4dcdfb['uniqueid'],_[_0xfee8('0x6e')](_0x4dcdfb['variable'])[0x0],_0x4dcdfb[_0xfee8('0x6f')]);if(this[_0xfee8('0x8')][_0x4dcdfb['uniqueid']]){for(var _0x9d4369 in this[_0xfee8('0x8')][_0x4dcdfb[_0xfee8('0x24')]]){if(this[_0xfee8('0x8')][_0x4dcdfb[_0xfee8('0x24')]]['hasOwnProperty'](_0x9d4369)){logger[_0xfee8('0x22')](_0xfee8('0x70'),_0x4dcdfb[_0xfee8('0x24')],_0x9d4369,_['keys'](_0x4dcdfb[_0xfee8('0x71')])[0x0],_0x4dcdfb[_0xfee8('0x6f')]);if(_[_0xfee8('0x21')](this[_0xfee8('0x8')][_0x4dcdfb[_0xfee8('0x24')]][_0x9d4369][_0xfee8('0x2e')])){this['channels'][_0x4dcdfb[_0xfee8('0x24')]][_0x9d4369][_0xfee8('0x2e')]={};}this['channels'][_0x4dcdfb[_0xfee8('0x24')]][_0x9d4369][_0xfee8('0x2e')]=this[_0xfee8('0x2e')][_0x4dcdfb[_0xfee8('0x24')]];}}}}}catch(_0x3c795b){logger[_0xfee8('0x51')](_0xfee8('0x72'),_0x4dcdfb['uniqueid'],util['inspect'](_0x3c795b,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x6d')]=function(_0x78b82e,_0x3eba4c,_0xa03c4d){var _0x3e957b=[_0xfee8('0x73'),'rtpaudioqosbridged','rtpaudioqosjitter',_0xfee8('0x74'),_0xfee8('0x75'),_0xfee8('0x76'),_0xfee8('0x77'),'rtpaudioqosrttbridged',_0xfee8('0x78'),'sipuri',_0xfee8('0x79'),'bridgepvtcallid','membercalls','memberdynamic',_0xfee8('0x7a'),'memberlastcall',_0xfee8('0x25'),_0xfee8('0x7b'),_0xfee8('0x7c')];if(!_[_0xfee8('0x7d')](_0x3eba4c)&&!_['includes'](_0x3e957b,_0x3eba4c)){if(_[_0xfee8('0x21')](this[_0xfee8('0x2e')][_0x78b82e])){this[_0xfee8('0x2e')][_0x78b82e]={};}this['variables'][_0x78b82e][_0x3eba4c]=_0xa03c4d;}};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x16')]=function(_0x4fd7c1){try{if(this[_0xfee8('0x20')](_0x4fd7c1)){logger[_0xfee8('0x27')](_0xfee8('0x7e'),_0x4fd7c1[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x4fd7c1,{'showHidden':![],'depth':null}));if(this[_0xfee8('0x8')][_0x4fd7c1['uniqueid']]){for(var _0x4e69d6 in this[_0xfee8('0x8')][_0x4fd7c1['uniqueid']]){if(this['channels'][_0x4fd7c1[_0xfee8('0x24')]]['hasOwnProperty'](_0x4e69d6)){if(this['channels'][_0x4fd7c1[_0xfee8('0x24')]][_0x4e69d6][_0xfee8('0x4e')]==_0xfee8('0x61')&&this[_0xfee8('0x8')][_0x4fd7c1[_0xfee8('0x24')]][_0x4e69d6][_0xfee8('0x12')]){logger[_0xfee8('0x22')](_0xfee8('0x7f'),_0x4fd7c1['uniqueid'],_0x4e69d6);this[_0xfee8('0x8')][_0x4fd7c1[_0xfee8('0x24')]][_0x4e69d6][_0xfee8('0x60')]=moment()[_0xfee8('0x28')]('YYYY-MM-DD\x20HH:mm:ss');}}}logger['debug'](_0xfee8('0x80'),_0x4fd7c1[_0xfee8('0x24')],util[_0xfee8('0x34')](_[_0xfee8('0x81')](this[_0xfee8('0x8')][_0x4fd7c1[_0xfee8('0x24')]]),{'showHidden':![],'depth':null}));ami[_0xfee8('0x1f')](_0xfee8('0x82'),_[_0xfee8('0x81')](this[_0xfee8('0x8')][_0x4fd7c1[_0xfee8('0x24')]]));delete this[_0xfee8('0x8')][_0x4fd7c1[_0xfee8('0x24')]];}if(this[_0xfee8('0x2e')][_0x4fd7c1[_0xfee8('0x24')]]){delete this['variables'][_0x4fd7c1[_0xfee8('0x24')]];}}}catch(_0x1e9541){logger[_0xfee8('0x51')](_0xfee8('0x83'),_0x4fd7c1[_0xfee8('0x24')],util['inspect'](_0x1e9541,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xfee8('0x1e')][_0xfee8('0x84')]=function(_0xa54a6e){try{if(this[_0xfee8('0x20')](_0xa54a6e)){logger[_0xfee8('0x27')]('[%s][voiceAgentReport][attendedtransfer]\x20event:',_0xa54a6e[_0xfee8('0x24')],util['inspect'](_0xa54a6e,{'showHidden':![],'depth':null}));if(this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]]){for(var _0x12fcff in this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]]){if(this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]]['hasOwnProperty'](_0x12fcff)){if(_0xa54a6e[_0xfee8('0x86')]===_0x12fcff){logger['info'](_0xfee8('0x87'),_0xa54a6e['uniqueid'],this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]][_0x12fcff]['membername'],_0x12fcff);var _0x3028d6=moment();this[_0xfee8('0x8')][_0xa54a6e['transfereeuniqueid']][_0x12fcff]['agentcomplete']=!![];this[_0xfee8('0x8')][_0xa54a6e['transfereeuniqueid']][_0x12fcff][_0xfee8('0x60')]=moment()['format'](_0xfee8('0x3b'));this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]][_0x12fcff][_0xfee8('0x40')]='complete';this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]][_0x12fcff][_0xfee8('0x4e')]=_0xfee8('0x61');this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]][_0x12fcff][_0xfee8('0x63')]=_0x3028d6[_0xfee8('0x88')](this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]][_0x12fcff][_0xfee8('0x3a')],'seconds');}}}}if(this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x89')]]){var _0x2abe78=this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x89')]];this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x89')]]=this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]];this[_0xfee8('0x8')][_0xa54a6e[_0xfee8('0x85')]]=_0x2abe78;}}}catch(_0x1e16e5){logger[_0xfee8('0x51')](_0xfee8('0x8a'),_0xa54a6e[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x1e16e5,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype']['syncBlindTransfer']=function(_0xc251ef){try{if(this[_0xfee8('0x20')](_0xc251ef)){logger['debug'](_0xfee8('0x8b'),_0xc251ef[_0xfee8('0x24')],util['inspect'](_0xc251ef,{'showHidden':![],'depth':null}));if(this[_0xfee8('0x8')][_0xc251ef['transfereeuniqueid']]){for(var _0x31ea54 in this['channels'][_0xc251ef['transfereeuniqueid']]){if(this['channels'][_0xc251ef[_0xfee8('0x85')]][_0xfee8('0x38')](_0x31ea54)){if(_0xc251ef[_0xfee8('0x8c')]===_0x31ea54){logger['info'](_0xfee8('0x8d'),_0xc251ef[_0xfee8('0x24')],this['channels'][_0xc251ef[_0xfee8('0x85')]][_0x31ea54][_0xfee8('0x25')],_0x31ea54);var _0x3cf047=moment();this[_0xfee8('0x8')][_0xc251ef[_0xfee8('0x85')]][_0x31ea54][_0xfee8('0x12')]=!![];this[_0xfee8('0x8')][_0xc251ef[_0xfee8('0x85')]][_0x31ea54]['agentcompleteAt']=_0x3cf047;this[_0xfee8('0x8')][_0xc251ef['transfereeuniqueid']][_0x31ea54][_0xfee8('0x40')]=_0xfee8('0x8e');this[_0xfee8('0x8')][_0xc251ef[_0xfee8('0x85')]][_0x31ea54][_0xfee8('0x4e')]=_0xfee8('0x61');this['channels'][_0xc251ef[_0xfee8('0x85')]][_0x31ea54]['talktime']=_0x3cf047[_0xfee8('0x88')](this[_0xfee8('0x8')][_0xc251ef[_0xfee8('0x85')]][_0x31ea54][_0xfee8('0x3a')],_0xfee8('0x8f'));}}}}}}catch(_0x2b5bbb){logger[_0xfee8('0x51')]('[%s][voiceAgentReport][blindtransfer]',_0xc251ef[_0xfee8('0x24')],util['inspect'](_0x2b5bbb,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype']['syncMusicOnHoldStart']=function(_0x4dd4bd){var _0x1642f8='';try{if(this['isNotNull'](_0x4dd4bd)){logger[_0xfee8('0x27')](_0xfee8('0x90'),_0x4dd4bd[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x4dd4bd,{'showHidden':![],'depth':null}));if(_0x4dd4bd[_0xfee8('0x91')]){_0x1642f8=_0x4dd4bd[_0xfee8('0x91')]['substring'](0x0,_0x4dd4bd[_0xfee8('0x91')][_0xfee8('0x92')]('-'));if(this['agents'][_0x1642f8]){logger[_0xfee8('0x22')](_0xfee8('0x93'),_0x4dd4bd[_0xfee8('0x24')],_0x1642f8);this['agents'][_0x1642f8]['onhold']=!![];}}}}catch(_0x4da813){logger[_0xfee8('0x51')](_0xfee8('0x94'),_0x4dd4bd[_0xfee8('0x24')],util[_0xfee8('0x34')](_0x4da813,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xfee8('0x1a')]=function(_0x145f2c){var _0x60f089='';try{if(this['isNotNull'](_0x145f2c)){logger['debug']('[%s][voiceAgentReport][musiconholdstop]\x20event:',_0x145f2c[_0xfee8('0x24')],util['inspect'](_0x145f2c,{'showHidden':![],'depth':null}));if(_0x145f2c[_0xfee8('0x91')]){_0x60f089=_0x145f2c[_0xfee8('0x91')][_0xfee8('0x95')](0x0,_0x145f2c['channel'][_0xfee8('0x92')]('-'));if(this[_0xfee8('0xa')][_0x60f089]){logger[_0xfee8('0x22')]('[%s][voiceAgentReport][musiconholdstop]\x20interface:%s',_0x145f2c[_0xfee8('0x24')],_0x60f089);this['agents'][_0x60f089][_0xfee8('0x96')]=![];}}}}catch(_0xb0ad1c){logger[_0xfee8('0x51')](_0xfee8('0x97'),_0x145f2c[_0xfee8('0x24')],util[_0xfee8('0x34')](_0xb0ad1c,{'showHidden':![],'depth':null}));}};module[_0xfee8('0x98')]=VoiceAgentReport;