Built motion from commit (unavailable).|2.5.19
[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 _0xfc1c=['redis','socket.io-emitter','channels','voiceQueues','agents','variables','agentcalled','syncAgentCalled','bind','syncAgentConnect','agentringnoanswer','queuecallerabandon','syncQueueCallerAbandon','syncAgentComplete','varset','syncVarSet','hangup','syncHangup','musiconholdstart','musiconholdstop','syncMusicOnHoldStop','blindtransfer','prototype','emit','isUndefined','isNotNull','info','membername','destuniqueid','[%s][voiceAgentReport][agentcalled]\x20event:','uniqueid','inspect','format','YYYY-MM-DD\x20HH:mm:ss','called','queue','mandatoryDisposition','inbound','omit','event','privilege','debug','[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:','custom:agentcalled','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:','user:%s','user:called','error','[%s][voiceAgentReport][agentcalled]','hasOwnProperty','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect','agentconnectAt','connectedlinename','connectedlinenum','destchannelstate','destchannelstatedesc','lastevent','connect','interface','pick','destconnectedlinenum','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentconnect\x20event:','custom:agentconnect','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:agentconnect\x20event:','user:agentconnect','agentcomplete','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere','agentringnoanswerAt','answeredelsewheremembername','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:','custom:agentansweredelsewhere','syncAgentRingNoAnswer','[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected','reason','rejected','[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:','custom:agentringnoanswer','[%s][voiceAgentReport][agentringnoanswer]','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','agent','talktime','acw','agentacw','[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:','custom:agentcomplete','[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:','user:agentcomplete','addVariable','variable','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','keys','value','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqoslossbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','sipcallid','bridgepeer','bridgepvtcallid','membercalls','memberinterface','memberlastcall','memberpenalty','memberrealtime','includes','[%s][voiceAgentReport][hangup]\x20event:','[%s][voiceAgentReport][hangup]\x20destuniqueid:%s','values','[%s][voiceAgentReport][hangup]','syncAttendedTransfer','transfereeuniqueid','origtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','diff','seconds','secondtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]','syncBlindTransfer','transfereruniqueid','[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','[%s][voiceAgentReport][blindtransfer]','syncMusicOnHoldStart','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','moment','util','ami'];(function(_0x250fc1,_0x49bba8){var _0x37aedb=function(_0x4d48e5){while(--_0x4d48e5){_0x250fc1['push'](_0x250fc1['shift']());}};_0x37aedb(++_0x49bba8);}(_0xfc1c,0x8e));var _0xcfc1=function(_0x5f1c59,_0x3fff4c){_0x5f1c59=_0x5f1c59-0x0;var _0xbfb242=_0xfc1c[_0x5f1c59];return _0xbfb242;};'use strict';var _=require('lodash');var moment=require(_0xcfc1('0x0'));var util=require(_0xcfc1('0x1'));var Redis=require('ioredis');var config=require('../../../config/environment');var logger=require('../../../config/logger')(_0xcfc1('0x2'));var ami=require('../ami');config[_0xcfc1('0x3')]=_['defaults'](config[_0xcfc1('0x3')],{'host':'localhost','port':0x18eb});var io=require(_0xcfc1('0x4'))(new Redis(config[_0xcfc1('0x3')]));function VoiceAgentReport(_0x192e90){this[_0xcfc1('0x5')]={};this['voiceQueues']=_0x192e90[_0xcfc1('0x6')];this[_0xcfc1('0x7')]=_0x192e90[_0xcfc1('0x7')];this[_0xcfc1('0x8')]={};ami['on'](_0xcfc1('0x9'),this[_0xcfc1('0xa')][_0xcfc1('0xb')](this));ami['on']('agentconnect',this[_0xcfc1('0xc')][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0xd'),this['syncAgentRingNoAnswer'][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0xe'),this[_0xcfc1('0xf')][_0xcfc1('0xb')](this));ami['on']('agentcomplete',this[_0xcfc1('0x10')][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0x11'),this[_0xcfc1('0x12')][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0x13'),this[_0xcfc1('0x14')][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0x15'),this['syncMusicOnHoldStart'][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0x16'),this[_0xcfc1('0x17')]['bind'](this));ami['on']('attendedtransfer',this['syncAttendedTransfer'][_0xcfc1('0xb')](this));ami['on'](_0xcfc1('0x18'),this['syncBlindTransfer']['bind'](this));}VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0x1a')]=function(_0x115a00,_0xc85ed0,_0x1f1910){io['to'](_0x115a00)[_0xcfc1('0x1a')](_0xc85ed0,_0x1f1910);};VoiceAgentReport[_0xcfc1('0x19')]['isNotNull']=function(_0x10fc67){return _0x10fc67!==null&&!_[_0xcfc1('0x1b')](_0x10fc67);};VoiceAgentReport[_0xcfc1('0x19')]['syncAgentCalled']=function(_0x1d09aa){try{if(this[_0xcfc1('0x1c')](_0x1d09aa)){logger[_0xcfc1('0x1d')]('[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called',_0x1d09aa['uniqueid'],_0x1d09aa[_0xcfc1('0x1e')],_0x1d09aa[_0xcfc1('0x1f')]);logger['debug'](_0xcfc1('0x20'),_0x1d09aa[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x1d09aa,{'showHidden':![],'depth':null}));if(_[_0xcfc1('0x1b')](this[_0xcfc1('0x5')][_0x1d09aa['uniqueid']])){this['channels'][_0x1d09aa[_0xcfc1('0x21')]]={};}if(_[_0xcfc1('0x1b')](this['channels'][_0x1d09aa[_0xcfc1('0x21')]][_0x1d09aa[_0xcfc1('0x1f')]])){this[_0xcfc1('0x5')][_0x1d09aa[_0xcfc1('0x21')]][_0x1d09aa[_0xcfc1('0x1f')]]={'agentcalledAt':moment()[_0xcfc1('0x23')](_0xcfc1('0x24')),'lastevent':_0xcfc1('0x25'),'mandatoryDisposition':this[_0xcfc1('0x6')][_0x1d09aa[_0xcfc1('0x26')]]?this['voiceQueues'][_0x1d09aa[_0xcfc1('0x26')]][_0xcfc1('0x27')]||![]:![],'type':this[_0xcfc1('0x6')][_0x1d09aa[_0xcfc1('0x26')]]?this['voiceQueues'][_0x1d09aa[_0xcfc1('0x26')]]['type']||_0xcfc1('0x28'):_0xcfc1('0x28'),'variables':this[_0xcfc1('0x8')][_0x1d09aa[_0xcfc1('0x21')]]};}_['merge'](this[_0xcfc1('0x5')][_0x1d09aa['uniqueid']][_0x1d09aa['destuniqueid']],_[_0xcfc1('0x29')](_0x1d09aa,[_0xcfc1('0x2a'),_0xcfc1('0x2b')]));logger[_0xcfc1('0x2c')](_0xcfc1('0x2d'),_0x1d09aa[_0xcfc1('0x21')],util['inspect'](this['channels'][_0x1d09aa['uniqueid']][_0x1d09aa[_0xcfc1('0x1f')]],{'showHidden':![],'depth':null}));ami['emit'](_0xcfc1('0x2e'),this['channels'][_0x1d09aa['uniqueid']][_0x1d09aa['destuniqueid']]);logger['debug'](_0xcfc1('0x2f'),_0x1d09aa[_0xcfc1('0x21')],util['inspect'](this['channels'][_0x1d09aa[_0xcfc1('0x21')]][_0x1d09aa[_0xcfc1('0x1f')]],{'showHidden':![],'depth':null}));this[_0xcfc1('0x1a')](util['format'](_0xcfc1('0x30'),_0x1d09aa[_0xcfc1('0x1e')]),_0xcfc1('0x31'),this[_0xcfc1('0x5')][_0x1d09aa[_0xcfc1('0x21')]][_0x1d09aa[_0xcfc1('0x1f')]]);}}catch(_0x1812e8){logger[_0xcfc1('0x32')](_0xcfc1('0x33'),_0x1d09aa[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x1812e8,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')]['syncAgentConnect']=function(_0x5ee017){try{if(this[_0xcfc1('0x1c')](_0x5ee017)){if(this['channels'][_0x5ee017[_0xcfc1('0x21')]]){logger['debug']('[%s][voiceAgentReport][agentconnect]\x20event:',_0x5ee017[_0xcfc1('0x21')],util['inspect'](_0x5ee017,{'showHidden':![],'depth':null}));for(var _0x342608 in this['channels'][_0x5ee017[_0xcfc1('0x21')]]){if(this['channels'][_0x5ee017[_0xcfc1('0x21')]][_0xcfc1('0x34')](_0x342608)){if(_0x5ee017[_0xcfc1('0x1f')]===_0x342608){logger[_0xcfc1('0x1d')](_0xcfc1('0x35'),_0x5ee017[_0xcfc1('0x21')],_0x5ee017['membername'],_0x5ee017['destuniqueid']);this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x36')]=moment()[_0xcfc1('0x23')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x37')]=_0x5ee017['connectedlinename'];this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x38')]=_0x5ee017[_0xcfc1('0x38')];this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x39')]=_0x5ee017[_0xcfc1('0x39')];this['channels'][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x3a')]=_0x5ee017[_0xcfc1('0x3a')];this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608]['holdtime']=_0x5ee017['holdtime'];this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x3b')]=_0xcfc1('0x3c');_['merge'](this[_0xcfc1('0x7')][_0x5ee017[_0xcfc1('0x3d')]],_[_0xcfc1('0x3e')](_0x5ee017,[_0xcfc1('0x26'),_0xcfc1('0x3f')]));logger['debug'](_0xcfc1('0x40'),_0x5ee017[_0xcfc1('0x21')],util[_0xcfc1('0x22')](this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x5ee017[_0xcfc1('0x1f')]],{'showHidden':![],'depth':null}));ami[_0xcfc1('0x1a')](_0xcfc1('0x41'),this['channels'][_0x5ee017[_0xcfc1('0x21')]][_0x5ee017[_0xcfc1('0x1f')]]);logger[_0xcfc1('0x2c')](_0xcfc1('0x42'),_0x5ee017['uniqueid'],util['inspect'](this['channels'][_0x5ee017['uniqueid']][_0x5ee017['destuniqueid']],{'showHidden':![],'depth':null}));this['emit'](util[_0xcfc1('0x23')](_0xcfc1('0x30'),_0x5ee017['membername']),_0xcfc1('0x43'),this['channels'][_0x5ee017[_0xcfc1('0x21')]][_0x5ee017[_0xcfc1('0x1f')]]);}else if(!this['channels'][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0xd')]&&!this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x44')]){logger[_0xcfc1('0x1d')](_0xcfc1('0x45'),_0x5ee017[_0xcfc1('0x21')],this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x1e')],_0x342608);this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0xd')]=!![];this[_0xcfc1('0x5')][_0x5ee017['uniqueid']][_0x342608][_0xcfc1('0x46')]=moment()[_0xcfc1('0x23')](_0xcfc1('0x24'));this[_0xcfc1('0x5')][_0x5ee017['uniqueid']][_0x342608]['answeredelsewheredestinationuniqueid']=_0x5ee017[_0xcfc1('0x1f')];this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608][_0xcfc1('0x47')]=_0x5ee017['membername'];this[_0xcfc1('0x5')][_0x5ee017['uniqueid']][_0x342608][_0xcfc1('0x3b')]='answered_elsewhere';this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608]['reason']='answered_elsewhere';logger[_0xcfc1('0x2c')](_0xcfc1('0x48'),_0x5ee017[_0xcfc1('0x21')],util[_0xcfc1('0x22')](this[_0xcfc1('0x5')][_0x5ee017['uniqueid']][_0x342608],{'showHidden':![],'depth':null}));ami[_0xcfc1('0x1a')](_0xcfc1('0x49'),this[_0xcfc1('0x5')][_0x5ee017[_0xcfc1('0x21')]][_0x342608]);}}}}}}catch(_0x887152){logger[_0xcfc1('0x32')]('[%s][voiceAgentReport][agentconnect]',_0x5ee017[_0xcfc1('0x21')],util['inspect'](_0x887152,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0x4a')]=function(_0x2daf0d){try{if(this[_0xcfc1('0x1c')](_0x2daf0d)){logger[_0xcfc1('0x2c')]('[%s][voiceAgentReport][agentringnoanswer]\x20event:',_0x2daf0d[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x2daf0d,{'showHidden':![],'depth':null}));if(this['channels'][_0x2daf0d[_0xcfc1('0x21')]]&&this['channels'][_0x2daf0d['uniqueid']][_0x2daf0d['destuniqueid']]){logger[_0xcfc1('0x1d')](_0xcfc1('0x4b'),_0x2daf0d[_0xcfc1('0x21')],_0x2daf0d['membername'],_0x2daf0d['destuniqueid']);this[_0xcfc1('0x5')][_0x2daf0d[_0xcfc1('0x21')]][_0x2daf0d['destuniqueid']][_0xcfc1('0xd')]=!![];this[_0xcfc1('0x5')][_0x2daf0d[_0xcfc1('0x21')]][_0x2daf0d[_0xcfc1('0x1f')]]['agentringnoanswerAt']=moment()['format']('YYYY-MM-DD\x20HH:mm:ss');this['channels'][_0x2daf0d[_0xcfc1('0x21')]][_0x2daf0d[_0xcfc1('0x1f')]][_0xcfc1('0x3b')]='rejected';this['channels'][_0x2daf0d['uniqueid']][_0x2daf0d[_0xcfc1('0x1f')]][_0xcfc1('0x4c')]=_0xcfc1('0x4d');logger['debug'](_0xcfc1('0x4e'),_0x2daf0d[_0xcfc1('0x21')],util[_0xcfc1('0x22')](this[_0xcfc1('0x5')][_0x2daf0d[_0xcfc1('0x21')]][_0x2daf0d[_0xcfc1('0x1f')]],{'showHidden':![],'depth':null}));ami['emit'](_0xcfc1('0x4f'),this[_0xcfc1('0x5')][_0x2daf0d['uniqueid']][_0x2daf0d[_0xcfc1('0x1f')]]);}}}catch(_0x46b262){logger[_0xcfc1('0x32')](_0xcfc1('0x50'),_0x2daf0d[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x46b262,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0xf')]=function(_0x3a440c){try{if(this[_0xcfc1('0x1c')](_0x3a440c)){logger[_0xcfc1('0x2c')]('[%s][voiceAgentReport][queuecallerabandon]\x20event:',_0x3a440c[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x3a440c,{'showHidden':![],'depth':null}));if(this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]]){for(var _0x52cf1e in this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]]){if(this[_0xcfc1('0x5')][_0x3a440c['uniqueid']][_0xcfc1('0x34')](_0x52cf1e)&&!this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0xd')]&&!this['channels'][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0x44')]){logger[_0xcfc1('0x1d')]('[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x3a440c[_0xcfc1('0x21')],this['channels'][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0x1e')],_0x52cf1e);this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0xd')]=!![];this['channels'][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0x46')]=moment()[_0xcfc1('0x23')](_0xcfc1('0x24'));this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0x3b')]=_0xcfc1('0x51');this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e][_0xcfc1('0x4c')]=_0xcfc1('0x51');logger[_0xcfc1('0x2c')](_0xcfc1('0x52'),_0x3a440c['uniqueid'],util[_0xcfc1('0x22')](this[_0xcfc1('0x5')][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e],{'showHidden':![],'depth':null}));ami[_0xcfc1('0x1a')](_0xcfc1('0x53'),this['channels'][_0x3a440c[_0xcfc1('0x21')]][_0x52cf1e]);}}}}}catch(_0x2227eb){logger[_0xcfc1('0x32')](_0xcfc1('0x54'),_0x3a440c['uniqueid'],util['inspect'](_0x2227eb,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')]['syncAgentComplete']=function(_0x22d085){try{if(this[_0xcfc1('0x1c')](_0x22d085)){logger['debug'](_0xcfc1('0x55'),_0x22d085[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x22d085,{'showHidden':![],'depth':null}));if(this[_0xcfc1('0x5')][_0x22d085['uniqueid']]){for(var _0x1f29ce in this['channels'][_0x22d085[_0xcfc1('0x21')]]){if(this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0xcfc1('0x34')](_0x1f29ce)){if(this[_0xcfc1('0x5')][_0x22d085['uniqueid']][_0x1f29ce]['agentconnectAt']&&!this['channels'][_0x22d085['uniqueid']][_0x1f29ce]['agentcomplete']){logger[_0xcfc1('0x1d')](_0xcfc1('0x56'),_0x22d085['uniqueid'],this['channels'][_0x22d085['uniqueid']][_0x1f29ce][_0xcfc1('0x1e')],_0x1f29ce);this['channels'][_0x22d085['uniqueid']][_0x1f29ce][_0xcfc1('0x44')]=!![];this[_0xcfc1('0x5')][_0x22d085['uniqueid']][_0x1f29ce][_0xcfc1('0x57')]=moment()[_0xcfc1('0x23')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0x1f29ce]['lastevent']=_0xcfc1('0x58');this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0x1f29ce][_0xcfc1('0x4c')]=_0x22d085[_0xcfc1('0x4c')]==_0xcfc1('0x59')?_0xcfc1('0x5a'):_0x22d085[_0xcfc1('0x4c')];this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0x1f29ce][_0xcfc1('0x5b')]=_0x22d085[_0xcfc1('0x5b')];if(this[_0xcfc1('0x6')][_0x22d085['queue']]&&this[_0xcfc1('0x6')][_0x22d085[_0xcfc1('0x26')]][_0xcfc1('0x5c')]){this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0x1f29ce]['acwtime']=this[_0xcfc1('0x6')][_0x22d085['queue']]['acwTimeout'];this['channels'][_0x22d085['uniqueid']][_0x1f29ce][_0xcfc1('0x5d')]=!![];}this[_0xcfc1('0x7')][_0x22d085[_0xcfc1('0x3d')]]=_[_0xcfc1('0x29')](this[_0xcfc1('0x7')][_0x22d085[_0xcfc1('0x3d')]],[_0xcfc1('0x26'),_0xcfc1('0x3f')]);logger[_0xcfc1('0x2c')](_0xcfc1('0x5e'),_0x22d085[_0xcfc1('0x21')],util[_0xcfc1('0x22')](this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0x1f29ce],{'showHidden':![],'depth':null}));ami['emit'](_0xcfc1('0x5f'),this[_0xcfc1('0x5')][_0x22d085[_0xcfc1('0x21')]][_0x1f29ce]);logger['debug'](_0xcfc1('0x60'),_0x22d085[_0xcfc1('0x21')],util[_0xcfc1('0x22')](this[_0xcfc1('0x5')][_0x22d085['uniqueid']][_0x1f29ce],{'showHidden':![],'depth':null}));this[_0xcfc1('0x1a')](util['format'](_0xcfc1('0x30'),_0x22d085[_0xcfc1('0x1e')]),_0xcfc1('0x61'),this[_0xcfc1('0x5')][_0x22d085['uniqueid']][_0x1f29ce]);}}}}}}catch(_0x34917c){logger['error']('[%s][voiceAgentReport][agentcomplete]',_0x22d085[_0xcfc1('0x21')],util['inspect'](_0x34917c,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')]['syncVarSet']=function(_0x20f0ef){try{if(this['isNotNull'](_0x20f0ef)){logger[_0xcfc1('0x2c')]('[%s][voiceAgentReport][varset]\x20event:',_0x20f0ef[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x20f0ef,{'showHidden':![],'depth':null}));this[_0xcfc1('0x62')](_0x20f0ef[_0xcfc1('0x21')],_['keys'](_0x20f0ef[_0xcfc1('0x63')])[0x0],_0x20f0ef['value']);if(this[_0xcfc1('0x5')][_0x20f0ef[_0xcfc1('0x21')]]){for(var _0x363943 in this[_0xcfc1('0x5')][_0x20f0ef['uniqueid']]){if(this[_0xcfc1('0x5')][_0x20f0ef['uniqueid']][_0xcfc1('0x34')](_0x363943)){logger['info'](_0xcfc1('0x64'),_0x20f0ef['uniqueid'],_0x363943,_[_0xcfc1('0x65')](_0x20f0ef[_0xcfc1('0x63')])[0x0],_0x20f0ef[_0xcfc1('0x66')]);if(_[_0xcfc1('0x1b')](this['channels'][_0x20f0ef[_0xcfc1('0x21')]][_0x363943][_0xcfc1('0x8')])){this[_0xcfc1('0x5')][_0x20f0ef[_0xcfc1('0x21')]][_0x363943][_0xcfc1('0x8')]={};}this[_0xcfc1('0x5')][_0x20f0ef[_0xcfc1('0x21')]][_0x363943][_0xcfc1('0x8')]=this[_0xcfc1('0x8')][_0x20f0ef[_0xcfc1('0x21')]];}}}}}catch(_0x16c882){logger[_0xcfc1('0x32')]('[%s][voiceAgentReport][varset]',_0x20f0ef['uniqueid'],util['inspect'](_0x16c882,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0x62')]=function(_0x42af57,_0x4dac18,_0x5a3b5e){var _0x33844c=['rtpaudioqos',_0xcfc1('0x67'),_0xcfc1('0x68'),_0xcfc1('0x69'),'rtpaudioqosloss',_0xcfc1('0x6a'),_0xcfc1('0x6b'),_0xcfc1('0x6c'),_0xcfc1('0x6d'),'sipuri',_0xcfc1('0x6e'),_0xcfc1('0x6f'),_0xcfc1('0x70'),'memberdynamic',_0xcfc1('0x71'),_0xcfc1('0x72'),_0xcfc1('0x1e'),_0xcfc1('0x73'),_0xcfc1('0x74')];if(!_['isNil'](_0x4dac18)&&!_[_0xcfc1('0x75')](_0x33844c,_0x4dac18)){if(_[_0xcfc1('0x1b')](this[_0xcfc1('0x8')][_0x42af57])){this['variables'][_0x42af57]={};}this['variables'][_0x42af57][_0x4dac18]=_0x5a3b5e;}};VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0x14')]=function(_0x1ba733){try{if(this[_0xcfc1('0x1c')](_0x1ba733)){logger[_0xcfc1('0x2c')](_0xcfc1('0x76'),_0x1ba733[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x1ba733,{'showHidden':![],'depth':null}));if(this['channels'][_0x1ba733[_0xcfc1('0x21')]]){for(var _0x169be7 in this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]]){if(this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]][_0xcfc1('0x34')](_0x169be7)){if(this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]][_0x169be7]['reason']==_0xcfc1('0x59')&&this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]][_0x169be7][_0xcfc1('0x44')]){logger[_0xcfc1('0x1d')](_0xcfc1('0x77'),_0x1ba733['uniqueid'],_0x169be7);this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]][_0x169be7]['agentcompleteAt']=moment()[_0xcfc1('0x23')](_0xcfc1('0x24'));}}}logger[_0xcfc1('0x2c')]('[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:',_0x1ba733[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_[_0xcfc1('0x78')](this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]]),{'showHidden':![],'depth':null}));ami[_0xcfc1('0x1a')]('custom:voiceAgentReport',_[_0xcfc1('0x78')](this[_0xcfc1('0x5')][_0x1ba733[_0xcfc1('0x21')]]));delete this['channels'][_0x1ba733[_0xcfc1('0x21')]];}if(this[_0xcfc1('0x8')][_0x1ba733[_0xcfc1('0x21')]]){delete this[_0xcfc1('0x8')][_0x1ba733[_0xcfc1('0x21')]];}}}catch(_0x34e677){logger[_0xcfc1('0x32')](_0xcfc1('0x79'),_0x1ba733[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x34e677,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0x7a')]=function(_0xebfb32){try{if(this[_0xcfc1('0x1c')](_0xebfb32)){logger['debug']('[%s][voiceAgentReport][attendedtransfer]\x20event:',_0xebfb32[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0xebfb32,{'showHidden':![],'depth':null}));if(this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x7b')]]){for(var _0x35bf83 in this['channels'][_0xebfb32['transfereeuniqueid']]){if(this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x7b')]][_0xcfc1('0x34')](_0x35bf83)){if(_0xebfb32[_0xcfc1('0x7c')]===_0x35bf83){logger[_0xcfc1('0x1d')](_0xcfc1('0x7d'),_0xebfb32[_0xcfc1('0x21')],this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x7b')]][_0x35bf83][_0xcfc1('0x1e')],_0x35bf83);var _0x195b38=moment();this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x7b')]][_0x35bf83]['agentcomplete']=!![];this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x7b')]][_0x35bf83][_0xcfc1('0x57')]=moment()[_0xcfc1('0x23')]('YYYY-MM-DD\x20HH:mm:ss');this['channels'][_0xebfb32[_0xcfc1('0x7b')]][_0x35bf83][_0xcfc1('0x3b')]=_0xcfc1('0x58');this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x7b')]][_0x35bf83][_0xcfc1('0x4c')]=_0xcfc1('0x59');this['channels'][_0xebfb32['transfereeuniqueid']][_0x35bf83]['talktime']=_0x195b38[_0xcfc1('0x7e')](this['channels'][_0xebfb32[_0xcfc1('0x7b')]][_0x35bf83][_0xcfc1('0x36')],_0xcfc1('0x7f'));}}}}if(this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x80')]]){var _0x1157fc=this[_0xcfc1('0x5')][_0xebfb32[_0xcfc1('0x80')]];this['channels'][_0xebfb32[_0xcfc1('0x80')]]=this['channels'][_0xebfb32['transfereeuniqueid']];this['channels'][_0xebfb32[_0xcfc1('0x7b')]]=_0x1157fc;}}}catch(_0x3d1347){logger[_0xcfc1('0x32')](_0xcfc1('0x81'),_0xebfb32[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x3d1347,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xcfc1('0x82')]=function(_0x1267b5){try{if(this[_0xcfc1('0x1c')](_0x1267b5)){logger['debug']('[%s][voiceAgentReport][blindtransfer]\x20event:',_0x1267b5[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x1267b5,{'showHidden':![],'depth':null}));if(this[_0xcfc1('0x5')][_0x1267b5[_0xcfc1('0x7b')]]){for(var _0x2412a7 in this[_0xcfc1('0x5')][_0x1267b5['transfereeuniqueid']]){if(this[_0xcfc1('0x5')][_0x1267b5[_0xcfc1('0x7b')]][_0xcfc1('0x34')](_0x2412a7)){if(_0x1267b5[_0xcfc1('0x83')]===_0x2412a7){logger[_0xcfc1('0x1d')](_0xcfc1('0x84'),_0x1267b5[_0xcfc1('0x21')],this[_0xcfc1('0x5')][_0x1267b5['transfereeuniqueid']][_0x2412a7][_0xcfc1('0x1e')],_0x2412a7);var _0x17969d=moment();this['channels'][_0x1267b5[_0xcfc1('0x7b')]][_0x2412a7][_0xcfc1('0x44')]=!![];this[_0xcfc1('0x5')][_0x1267b5[_0xcfc1('0x7b')]][_0x2412a7][_0xcfc1('0x57')]=_0x17969d;this[_0xcfc1('0x5')][_0x1267b5[_0xcfc1('0x7b')]][_0x2412a7]['lastevent']=_0xcfc1('0x58');this['channels'][_0x1267b5[_0xcfc1('0x7b')]][_0x2412a7]['reason']='transfer';this['channels'][_0x1267b5[_0xcfc1('0x7b')]][_0x2412a7]['talktime']=_0x17969d[_0xcfc1('0x7e')](this['channels'][_0x1267b5[_0xcfc1('0x7b')]][_0x2412a7][_0xcfc1('0x36')],'seconds');}}}}}}catch(_0xe1d0b6){logger[_0xcfc1('0x32')](_0xcfc1('0x85'),_0x1267b5[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0xe1d0b6,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xcfc1('0x86')]=function(_0x14fc8e){var _0x414ef2='';try{if(this[_0xcfc1('0x1c')](_0x14fc8e)){logger['debug']('[%s][voiceAgentReport][musiconholdstart]\x20event:',_0x14fc8e[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x14fc8e,{'showHidden':![],'depth':null}));if(_0x14fc8e[_0xcfc1('0x87')]){_0x414ef2=_0x14fc8e[_0xcfc1('0x87')][_0xcfc1('0x88')](0x0,_0x14fc8e[_0xcfc1('0x87')][_0xcfc1('0x89')]('-'));if(this[_0xcfc1('0x7')][_0x414ef2]){logger['info'](_0xcfc1('0x8a'),_0x14fc8e[_0xcfc1('0x21')],_0x414ef2);this[_0xcfc1('0x7')][_0x414ef2][_0xcfc1('0x8b')]=!![];}}}}catch(_0x34f74f){logger[_0xcfc1('0x32')](_0xcfc1('0x8c'),_0x14fc8e[_0xcfc1('0x21')],util['inspect'](_0x34f74f,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xcfc1('0x19')][_0xcfc1('0x17')]=function(_0x1386ba){var _0x3d5b2d='';try{if(this[_0xcfc1('0x1c')](_0x1386ba)){logger[_0xcfc1('0x2c')](_0xcfc1('0x8d'),_0x1386ba[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x1386ba,{'showHidden':![],'depth':null}));if(_0x1386ba['channel']){_0x3d5b2d=_0x1386ba[_0xcfc1('0x87')][_0xcfc1('0x88')](0x0,_0x1386ba[_0xcfc1('0x87')][_0xcfc1('0x89')]('-'));if(this[_0xcfc1('0x7')][_0x3d5b2d]){logger[_0xcfc1('0x1d')](_0xcfc1('0x8e'),_0x1386ba[_0xcfc1('0x21')],_0x3d5b2d);this[_0xcfc1('0x7')][_0x3d5b2d]['onhold']=![];}}}}catch(_0x538513){logger[_0xcfc1('0x32')](_0xcfc1('0x8f'),_0x1386ba[_0xcfc1('0x21')],util[_0xcfc1('0x22')](_0x538513,{'showHidden':![],'depth':null}));}};module[_0xcfc1('0x90')]=VoiceAgentReport;