Built motion from commit (unavailable).|2.5.26
[motion2.git] / server / services / ami / report / voiceCallReport.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 _0x752c=['undefined','isEmpty','getSettings','stopRecordingOnTransfer','resolve','Action','StopMixMonitor','destinationchannel','catch','finally','webbar:stopmonitors','event','blindTransfers','type','custom:voiceCallReport','[%s][voiceCallReport][hangup]','[%s][voiceCallReport][attendedtransfer]\x20transfercalleridnum:%s\x20transferconnectedlinenum:%s','transfertargetcalleridnum','[%s][voiceCallReport][attendedtransfer]\x20event:','transfereeuniqueid','transfercalleridnum','origtransferercalleridnum','transferconnectedlinenum','secondtransfereruniqueid','transfertargetuniqueid','origtransfereruniqueid','origtransfererlinkedid','some','ATTENDED','[%s][voiceCallReport][attendedtransfer]','[%s][voiceCallReport][blindtransfer]\x20transfercalleridnum:%s\x20transferconnectedlinenum:%s','transfereecalleridnum','extension','BLIND','BlindTransfer','transfererchannel','[%s][voiceCallReport][blindtransfer]','[%s][voiceCallReport][musiconholdstart]\x20event:','mohstarttime','[%s][voiceCallReport][musiconholdstart]','[%s][voiceCallReport][musiconholdstop]\x20event:','mohtime','milliseconds','[%s][voiceCallReport][musiconholdstop]','exports','bluebird','moment','util','path','ioredis','../../../config/environment','../../../config/logger','ami','../ami','../model/channel','../rpc/setting','unknown','not_inuse','invalid','unavailable','ringing','ringinuse','agi','dial','playback','NO\x20ANSWER','FAILED','BUSY','redis','defaults','localhost','socket.io-emitter','channels','coreshowchannel','syncNewExten','newexten','bind','newchannel','syncNewChannel','newstate','syncNewState','hangup','syncHangup','syncNewCallerId','syncAttendedTransfer','syncBlindTransfer','musiconholdstart','syncMusicOnHoldStart','syncMusicOnHoldStop','info','error','[voiceCallReport][coreshowchannels]','inspect','prototype','isNotNull','emit','uniqueid','[%s][voiceCallReport][newcallerid]\x20event:','linkedid','isUndefined','merge','pick','[%s][voiceCallReport][newcallerid]','debug','[%s][voiceCallReport][newchannel]\x20event:','channel','OutgoingSpoolFailed','[%s][voiceCallReport][newchannel]\x20context:%s\x20exten:%s','context','exten','YYYY-MM-DD\x20HH:mm:ss','disposition','toNumber','keys','agents','split','destconnectedlinenum','[%s][voiceCallReport][newchannel]\x20sending\x20user:agentconnect\x20event:','accountcode','user:%s','name','user:agentconnect','[%s][voiceCallReport][newchannel]','application','toLowerCase','applicationdata','appdata','starttime','duration','subtract','seconds','format','includes','lastapplication','lastdata','startsWith','cdr(','queue','[%s][voiceCallReport][newexten]','calleridnum','answered','answertime','xcally-motion-preview','connectedlinenum','connectedlinename','channelstate','UserId','membername','[%s][voiceCallReport][newstate]','[%s][voiceCallReport][mixMonitorFilename]\x20monitorFilename:%s','monitor','.wav49','monitorFilename','find','monitors','isNil','rec','syncVarSet','[%s][voiceCallReport][varset]\x20event:','variable','mixmonitor_filename','value','syncMixMonitorFilename','[%s][voiceCallReport][varset]\x20variable:xmd-phone\x20value:%s','xmd-callerid','[%s][voiceCallReport][varset]\x20variable:xmd-callerid\x20value:%s','callerid','xmd-cdrtype','[%s][voiceCallReport][varset]\x20variable:xmd-cdrtype\x20value:%s','[%s][voiceCallReport][varset]\x20variable:xmd-queue\x20value:%s','xmd-destination','calleridpreview','xmcs-queue','[%s][voiceCallReport][varset]\x20variable:xmcs-queue\x20value:%s','sipcallid','sipcalluniqueid','[%s][voiceCallReport][varset]\x20variable:sipcallid\x20value:%s','sipcalllinkedid','[%s][voiceCallReport][hangup]\x20event:','[%s][voiceCallReport][hangup]\x20reason:%s','cause-txt','endtime','diff','billableseconds','omit','[%s][voiceCallReport][hangup]\x20sending\x20user:agentcomplete\x20event:','user:agentcomplete','then','transferType'];(function(_0x4d201f,_0x56b30d){var _0x2556a8=function(_0x4ec9d9){while(--_0x4ec9d9){_0x4d201f['push'](_0x4d201f['shift']());}};_0x2556a8(++_0x56b30d);}(_0x752c,0xea));var _0xc752=function(_0x51ae54,_0x346bc3){_0x51ae54=_0x51ae54-0x0;var _0x16e760=_0x752c[_0x51ae54];return _0x16e760;};'use strict';var BPromise=require(_0xc752('0x0'));var _=require('lodash');var moment=require(_0xc752('0x1'));var util=require(_0xc752('0x2'));var path=require(_0xc752('0x3'));var Redis=require(_0xc752('0x4'));var config=require(_0xc752('0x5'));var logger=require(_0xc752('0x6'))(_0xc752('0x7'));var ami=require(_0xc752('0x8'));var Channel=require(_0xc752('0x9'));var RpcSetting=require(_0xc752('0xa'));var statusDesc=[_0xc752('0xb'),_0xc752('0xc'),'inuse','busy',_0xc752('0xd'),_0xc752('0xe'),_0xc752('0xf'),_0xc752('0x10'),'onhold'];var applications=['set','queue',_0xc752('0x11'),_0xc752('0x12'),_0xc752('0x13'),'voicemail'];var dispositions=[_0xc752('0x14'),_0xc752('0x15'),_0xc752('0x15'),_0xc752('0x14'),_0xc752('0x14'),'NO\x20ANSWER','ANSWERED',_0xc752('0x16'),_0xc752('0x15'),_0xc752('0x15'),_0xc752('0x15')];var actions={};config[_0xc752('0x17')]=_[_0xc752('0x18')](config[_0xc752('0x17')],{'host':_0xc752('0x19'),'port':0x18eb});var io=require(_0xc752('0x1a'))(new Redis(config[_0xc752('0x17')]));function VoiceCallReport(_0x4f8d71){this['channels']=_0x4f8d71[_0xc752('0x1b')];this['agents']=_0x4f8d71['agents'];this['blindTransfers']={};ami['on'](_0xc752('0x1c'),this[_0xc752('0x1d')]['bind'](this));ami['on'](_0xc752('0x1e'),this[_0xc752('0x1d')][_0xc752('0x1f')](this));ami['on'](_0xc752('0x20'),this[_0xc752('0x21')][_0xc752('0x1f')](this));ami['on'](_0xc752('0x22'),this[_0xc752('0x23')][_0xc752('0x1f')](this));ami['on']('varset',this['syncVarSet'][_0xc752('0x1f')](this));ami['on'](_0xc752('0x24'),this[_0xc752('0x25')][_0xc752('0x1f')](this));ami['on']('newcallerid',this[_0xc752('0x26')]['bind'](this));ami['on']('attendedtransfer',this[_0xc752('0x27')][_0xc752('0x1f')](this));ami['on']('blindtransfer',this[_0xc752('0x28')]['bind'](this));ami['on'](_0xc752('0x29'),this[_0xc752('0x2a')][_0xc752('0x1f')](this));ami['on']('musiconholdstop',this[_0xc752('0x2b')][_0xc752('0x1f')](this));try{logger[_0xc752('0x2c')]('[voiceCallReport][coreshowchannels]\x20started');ami['actionCoreShowChannels']();}catch(_0x246df2){logger[_0xc752('0x2d')](_0xc752('0x2e'),util[_0xc752('0x2f')](_0x246df2,{'showHidden':![],'depth':null}));}}VoiceCallReport[_0xc752('0x30')][_0xc752('0x31')]=function(_0x580277){return _0x580277!==null&&!_['isUndefined'](_0x580277);};VoiceCallReport['prototype'][_0xc752('0x32')]=function(_0x5147d9,_0x1402e2,_0xe9ab20){io['to'](_0x5147d9)[_0xc752('0x32')](_0x1402e2,_0xe9ab20);};VoiceCallReport[_0xc752('0x30')][_0xc752('0x26')]=function(_0x2d582d){try{if(this[_0xc752('0x31')](_0x2d582d)){logger[_0xc752('0x2c')]('[%s][voiceCallReport][newcallerid]\x20calleridname:%s\x20calleridnum:%s',_0x2d582d[_0xc752('0x33')],_0x2d582d['calleridname'],_0x2d582d['calleridnum']);logger['debug'](_0xc752('0x34'),_0x2d582d[_0xc752('0x33')],util['inspect'](_0x2d582d,{'showHidden':![],'depth':null}));if(_0x2d582d['uniqueid']===_0x2d582d[_0xc752('0x35')]){if(!_[_0xc752('0x36')](this[_0xc752('0x1b')][_0x2d582d[_0xc752('0x33')]])){_[_0xc752('0x37')](this[_0xc752('0x1b')][_0x2d582d[_0xc752('0x33')]],_[_0xc752('0x38')](_0x2d582d,_['keys'](this[_0xc752('0x1b')][_0x2d582d[_0xc752('0x33')]])));}}}}catch(_0x4bb694){logger[_0xc752('0x2d')](_0xc752('0x39'),_0x2d582d[_0xc752('0x33')],util['inspect'](_0x4bb694,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')][_0xc752('0x21')]=function(_0x22f50f){try{if(this[_0xc752('0x31')](_0x22f50f)){logger[_0xc752('0x3a')](_0xc752('0x3b'),_0x22f50f['uniqueid'],util[_0xc752('0x2f')](_0x22f50f,{'showHidden':![],'depth':null}));if(_0x22f50f['uniqueid']===_0x22f50f[_0xc752('0x35')]&&_0x22f50f[_0xc752('0x3c')]!=_0xc752('0x3d')){if(_['isUndefined'](this[_0xc752('0x1b')][_0x22f50f[_0xc752('0x33')]])){logger[_0xc752('0x2c')](_0xc752('0x3e'),_0x22f50f[_0xc752('0x33')],_0x22f50f[_0xc752('0x3f')],_0x22f50f[_0xc752('0x40')]);this[_0xc752('0x1b')][_0x22f50f['uniqueid']]=new Channel();this[_0xc752('0x1b')][_0x22f50f[_0xc752('0x33')]]['starttime']=moment()['format'](_0xc752('0x41'));this[_0xc752('0x1b')][_0x22f50f[_0xc752('0x33')]][_0xc752('0x42')]=dispositions[_[_0xc752('0x43')](_0x22f50f['channelstate'])];_[_0xc752('0x37')](this[_0xc752('0x1b')][_0x22f50f[_0xc752('0x33')]],_[_0xc752('0x38')](_0x22f50f,_[_0xc752('0x44')](this[_0xc752('0x1b')][_0x22f50f['uniqueid']])));if(_0x22f50f[_0xc752('0x3f')]==='from-sip'){if(this[_0xc752('0x45')][_0x22f50f[_0xc752('0x3c')][_0xc752('0x46')]('-')[0x0]]){this[_0xc752('0x45')][_0x22f50f['channel'][_0xc752('0x46')]('-')[0x0]][_0xc752('0x47')]=_0x22f50f['exten'];logger[_0xc752('0x3a')](_0xc752('0x48'),_0x22f50f[_0xc752('0x33')],util[_0xc752('0x2f')]({'destaccountcode':this['agents'][_0x22f50f['channel'][_0xc752('0x46')]('-')[0x0]][_0xc752('0x49')],'destconnectedlinenum':_0x22f50f[_0xc752('0x40')]},{'showHidden':![],'depth':null}));this[_0xc752('0x32')](util['format'](_0xc752('0x4a'),this[_0xc752('0x45')][_0x22f50f[_0xc752('0x3c')]['split']('-')[0x0]][_0xc752('0x4b')]),_0xc752('0x4c'),{'destaccountcode':this[_0xc752('0x45')][_0x22f50f['channel'][_0xc752('0x46')]('-')[0x0]][_0xc752('0x49')],'destconnectedlinenum':_0x22f50f['exten']});}}}}}}catch(_0x14f70a){logger['error'](_0xc752('0x4d'),_0x22f50f[_0xc752('0x33')],util[_0xc752('0x2f')](_0x14f70a,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')]['syncNewExten']=function(_0x241148){try{if(this[_0xc752('0x31')](_0x241148)){logger['debug']('[%s][voiceCallReport][newexten]\x20event:',_0x241148[_0xc752('0x33')],util[_0xc752('0x2f')](_0x241148,{'showHidden':![],'depth':null}));if(_0x241148[_0xc752('0x33')]===_0x241148[_0xc752('0x35')]&&_0x241148[_0xc752('0x40')]!='h'&&_0x241148[_0xc752('0x3c')]!='OutgoingSpoolFailed'){_0x241148[_0xc752('0x4e')]=_0x241148[_0xc752('0x4e')][_0xc752('0x4f')]();_0x241148[_0xc752('0x50')]=(_0x241148[_0xc752('0x51')]||_0x241148[_0xc752('0x50')])['toLowerCase']();logger[_0xc752('0x2c')]('[%s][voiceCallReport][newexten]\x20application:%s\x20appdata:%s',_0x241148[_0xc752('0x33')],_0x241148[_0xc752('0x4e')],_0x241148[_0xc752('0x50')]);if(_[_0xc752('0x36')](this['channels'][_0x241148['uniqueid']])){this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]]=new Channel();this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]][_0xc752('0x52')]=_0x241148[_0xc752('0x53')]?moment()[_0xc752('0x54')](moment['duration'](_0x241148[_0xc752('0x53')])['seconds'](),_0xc752('0x55'))[_0xc752('0x56')](_0xc752('0x41')):moment()[_0xc752('0x56')](_0xc752('0x41'));this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]]['disposition']=_0xc752('0x14');}_[_0xc752('0x37')](this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]],_[_0xc752('0x38')](_0x241148,_['keys'](this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]])));if(_[_0xc752('0x57')](applications,_0x241148['application'])){this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]][_0xc752('0x58')]=_0x241148[_0xc752('0x4e')];this['channels'][_0x241148[_0xc752('0x33')]][_0xc752('0x59')]=_0x241148[_0xc752('0x50')];if(_0x241148[_0xc752('0x4e')]==='set'&&_[_0xc752('0x5a')](_0x241148[_0xc752('0x50')],_0xc752('0x5b'))){var _0x45ec3c=_0x241148[_0xc752('0x50')][_0xc752('0x46')]('=');var _0x22efab=_0x45ec3c[0x0]['match'](/cdr\((.*)\)/);if(_0x22efab){this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]][_0x22efab[0x1]]=_0x45ec3c[0x1];}}else if(_0x241148[_0xc752('0x4e')]===_0xc752('0x5c')){this[_0xc752('0x1b')][_0x241148[_0xc752('0x33')]]['queue']=_0x241148['applicationdata']['split'](',')[0x0];}}}}}catch(_0x4a2447){logger['error'](_0xc752('0x5d'),_0x241148['uniqueid'],util[_0xc752('0x2f')](_0x4a2447,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')][_0xc752('0x23')]=function(_0x1a509a){try{if(this['isNotNull'](_0x1a509a)){logger[_0xc752('0x2c')]('[%s][voiceCallReport][newstate]\x20linkedid:%s\x20calleridname:%s\x20calleridnum:%s',_0x1a509a[_0xc752('0x33')],_0x1a509a[_0xc752('0x35')],_0x1a509a['calleridname'],_0x1a509a[_0xc752('0x5e')]);logger['debug']('[%s][voiceCallReport][newstate]\x20event:',_0x1a509a[_0xc752('0x33')],util[_0xc752('0x2f')](_0x1a509a,{'showHidden':![],'depth':null}));if(_0x1a509a[_0xc752('0x33')]!==_0x1a509a[_0xc752('0x35')]){if(this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]]){if(_0x1a509a['channelstate']==='6'){if(!this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x5f')]){var _0x50e745=moment();this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x5f')]=!![];this[_0xc752('0x1b')][_0x1a509a['linkedid']][_0xc752('0x60')]=_0x50e745[_0xc752('0x56')](_0xc752('0x41'));if(this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x52')]){this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]]['holdtime']=_0x50e745['diff'](this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x52')],'seconds');}}this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x35')]=_0x1a509a[_0xc752('0x33')];if(_0x1a509a[_0xc752('0x5e')]!==_0xc752('0x61')){this[_0xc752('0x1b')][_0x1a509a['linkedid']][_0xc752('0x62')]=_0x1a509a['calleridnum'];}this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x63')]=_0x1a509a['calleridname'];this[_0xc752('0x1b')][_0x1a509a['linkedid']]['destinationchannel']=_0x1a509a['channel'];this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]][_0xc752('0x42')]=dispositions[_[_0xc752('0x43')](_0x1a509a[_0xc752('0x64')])];if(this[_0xc752('0x45')][_0x1a509a[_0xc752('0x3c')][_0xc752('0x46')]('-')[0x0]]){this['channels'][_0x1a509a[_0xc752('0x35')]]['UserId']=this[_0xc752('0x45')][_0x1a509a['channel'][_0xc752('0x46')]('-')[0x0]]['id'];this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x35')]]['membername']=this[_0xc752('0x45')][_0x1a509a[_0xc752('0x3c')][_0xc752('0x46')]('-')[0x0]][_0xc752('0x4b')];}}}}else{if(this['channels'][_0x1a509a['uniqueid']]){if(_0x1a509a[_0xc752('0x64')]==='6'){if(this[_0xc752('0x45')][_0x1a509a[_0xc752('0x3c')]['split']('-')[0x0]]){this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x33')]][_0xc752('0x65')]=this['agents'][_0x1a509a['channel'][_0xc752('0x46')]('-')[0x0]]['id'];this[_0xc752('0x1b')][_0x1a509a[_0xc752('0x33')]][_0xc752('0x66')]=this[_0xc752('0x45')][_0x1a509a['channel'][_0xc752('0x46')]('-')[0x0]][_0xc752('0x4b')];}}}}}}catch(_0x5b5a4e){logger['error'](_0xc752('0x67'),_0x1a509a['uniqueid'],util['inspect'](_0x5b5a4e,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')]['syncMixMonitorFilename']=function(_0x375048,_0x5db799){try{if(this['channels'][_0x375048]){logger[_0xc752('0x2c')](_0xc752('0x68'),_0x375048,_0x5db799);this[_0xc752('0x1b')][_0x375048][_0xc752('0x69')]=!![];if(_['endsWith'](_0x5db799,'.wav49')){_0x5db799=_0x5db799['replace'](_0xc752('0x6a'),'.WAV');}this[_0xc752('0x1b')][_0x375048][_0xc752('0x6b')]=_0x5db799;var _0xca80e3=_[_0xc752('0x6c')](this[_0xc752('0x1b')][_0x375048][_0xc752('0x6d')],{'filename':_0x5db799});if(_[_0xc752('0x6e')](_0xca80e3)){this[_0xc752('0x1b')][_0x375048]['monitors']['push']({'filename':_0x5db799,'createdAt':moment()['format']('YYYY-MM-DD\x20HH:mm:ss'),'mixmonitorid':'','status':_0xc752('0x6f')});}}}catch(_0x1684e5){logger[_0xc752('0x2d')]('[%s][voiceCallReport][mixMonitorFilename]',_0x375048,util[_0xc752('0x2f')](_0x1684e5,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype'][_0xc752('0x70')]=function(_0x5c7394){try{if(this[_0xc752('0x31')](_0x5c7394)){logger['debug'](_0xc752('0x71'),_0x5c7394[_0xc752('0x33')],util[_0xc752('0x2f')](_0x5c7394,{'showHidden':![],'depth':null}));if(this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]]&&_0x5c7394[_0xc752('0x3c')]!=_0xc752('0x3d')){if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')])){if(this['isNotNull'](_0x5c7394[_0xc752('0x72')][_0xc752('0x73')])){logger[_0xc752('0x2c')]('[%s][voiceCallReport][varset]\x20variable:mixmonitor_filename\x20value:%s',_0x5c7394[_0xc752('0x33')],_0x5c7394[_0xc752('0x74')]);this[_0xc752('0x75')](_0x5c7394[_0xc752('0x33')],_0x5c7394[_0xc752('0x74')]);}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')]['xmd-phone'])){logger[_0xc752('0x2c')](_0xc752('0x76'),_0x5c7394[_0xc752('0x33')],_0x5c7394[_0xc752('0x74')]);this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]][_0xc752('0x5e')]=_0x5c7394[_0xc752('0x74')];}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')][_0xc752('0x77')])){logger['info'](_0xc752('0x78'),_0x5c7394['uniqueid'],_0x5c7394[_0xc752('0x74')]);this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]][_0xc752('0x79')]=_0x5c7394[_0xc752('0x74')];}else if(this['isNotNull'](_0x5c7394[_0xc752('0x72')][_0xc752('0x7a')])){logger[_0xc752('0x2c')](_0xc752('0x7b'),_0x5c7394[_0xc752('0x33')],_0x5c7394[_0xc752('0x74')]);this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]]['type']=_0x5c7394[_0xc752('0x74')];}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')]['xmd-queue'])){logger[_0xc752('0x2c')](_0xc752('0x7c'),_0x5c7394['uniqueid'],_0x5c7394[_0xc752('0x74')][_0xc752('0x46')](',')[0x0]);this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]][_0xc752('0x5c')]=_0x5c7394[_0xc752('0x74')][_0xc752('0x46')](',')[0x0];}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')]['xmd-originatecalleridnum'])){logger[_0xc752('0x2c')]('[%s][voiceCallReport][varset]\x20variable:xmd-originatecalleridnum\x20value:%s',_0x5c7394[_0xc752('0x33')],_0x5c7394['value']);this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]]['originatecalleridnum']=_0x5c7394[_0xc752('0x74')];}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')][_0xc752('0x7d')])){logger[_0xc752('0x2c')]('[%s][voiceCallReport][varset]\x20variable:xmd-destination\x20value:%s',_0x5c7394[_0xc752('0x33')],_0x5c7394[_0xc752('0x74')]);this['channels'][_0x5c7394[_0xc752('0x33')]]['destination']=_0x5c7394[_0xc752('0x74')];}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')]['xmd-callerid-preview'])){logger[_0xc752('0x2c')]('[%s][voiceCallReport][varset]\x20variable:xmd-callerid-preview\x20value:%s',_0x5c7394[_0xc752('0x33')],_0x5c7394['value']);this['channels'][_0x5c7394[_0xc752('0x33')]][_0xc752('0x7e')]=_0x5c7394[_0xc752('0x74')];}else if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')][_0xc752('0x7f')])){logger[_0xc752('0x2c')](_0xc752('0x80'),_0x5c7394[_0xc752('0x33')],_0x5c7394['value']);this[_0xc752('0x1b')][_0x5c7394[_0xc752('0x33')]][_0xc752('0x5c')]=_0x5c7394[_0xc752('0x74')];}else if(this[_0xc752('0x31')](_0x5c7394['variable'][_0xc752('0x81')])){logger[_0xc752('0x2c')]('[%s][voiceCallReport][varset]\x20variable:sipcallid\x20value:%s',_0x5c7394[_0xc752('0x33')],_0x5c7394[_0xc752('0x74')]);this['channels'][_0x5c7394[_0xc752('0x33')]][_0xc752('0x82')]=_0x5c7394[_0xc752('0x74')];}}}else if(this['isNotNull'](_0x5c7394['variable']['mixmonitor_filename'])){if(_0x5c7394[_0xc752('0x74')]){var _0x1f4511=path['parse'](_0x5c7394[_0xc752('0x74')])['name'];logger[_0xc752('0x2c')]('[%s][voiceCallReport][varset]\x20variable:mixmonitor_filename\x20value:%s',_0x1f4511,_0x5c7394['value']);this['syncMixMonitorFilename'](_0x1f4511,_0x5c7394[_0xc752('0x74')]);}}else if(this['channels'][_0x5c7394[_0xc752('0x35')]]){if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')])){if(this[_0xc752('0x31')](_0x5c7394[_0xc752('0x72')][_0xc752('0x81')])){logger[_0xc752('0x2c')](_0xc752('0x83'),_0x5c7394[_0xc752('0x35')],_0x5c7394['value']);this[_0xc752('0x1b')][_0x5c7394['linkedid']][_0xc752('0x84')]=_0x5c7394[_0xc752('0x74')];}}}}}catch(_0x1e25c2){logger[_0xc752('0x2d')]('[%s][voiceCallReport][varset]',_0x5c7394[_0xc752('0x33')],util[_0xc752('0x2f')](_0x1e25c2,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')][_0xc752('0x25')]=function(_0x54d377){try{if(this[_0xc752('0x31')](_0x54d377)){logger[_0xc752('0x3a')](_0xc752('0x85'),_0x54d377[_0xc752('0x33')],util[_0xc752('0x2f')](_0x54d377,{'showHidden':![],'depth':null}));if(this[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]]){logger[_0xc752('0x2c')](_0xc752('0x86'),_0x54d377[_0xc752('0x33')],_0x54d377[_0xc752('0x87')]);var _0x56e8f1=moment();this[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]][_0xc752('0x88')]=_0x56e8f1[_0xc752('0x56')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]][_0xc752('0x53')]=_0x56e8f1[_0xc752('0x89')](this[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]]['starttime'],_0xc752('0x55'));if(this[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]][_0xc752('0x5f')]){this['channels'][_0x54d377['uniqueid']][_0xc752('0x8a')]=_0x56e8f1[_0xc752('0x89')](this[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]][_0xc752('0x60')],_0xc752('0x55'));this['channels'][_0x54d377[_0xc752('0x33')]]['holdtime']=this['channels'][_0x54d377[_0xc752('0x33')]][_0xc752('0x53')]-this[_0xc752('0x1b')][_0x54d377['uniqueid']][_0xc752('0x8a')];}if(_0x54d377['context']==='from-sip'){if(this[_0xc752('0x45')][_0x54d377[_0xc752('0x3c')][_0xc752('0x46')]('-')[0x0]]){this['agents'][_0x54d377[_0xc752('0x3c')]['split']('-')[0x0]]=_[_0xc752('0x8b')](this['agents'][_0x54d377[_0xc752('0x3c')][_0xc752('0x46')]('-')[0x0]],[_0xc752('0x47')]);logger[_0xc752('0x3a')](_0xc752('0x8c'),_0x54d377[_0xc752('0x33')],util[_0xc752('0x2f')]({'destaccountcode':this[_0xc752('0x45')][_0x54d377[_0xc752('0x3c')][_0xc752('0x46')]('-')[0x0]][_0xc752('0x49')]},{'showHidden':![],'depth':null}));this[_0xc752('0x32')](util[_0xc752('0x56')](_0xc752('0x4a'),this[_0xc752('0x45')][_0x54d377['channel'][_0xc752('0x46')]('-')[0x0]][_0xc752('0x4b')]),_0xc752('0x8d'),{'destaccountcode':this[_0xc752('0x45')][_0x54d377['channel'][_0xc752('0x46')]('-')[0x0]][_0xc752('0x49')]});}}var _0x534a15=this;Promise['resolve']()[_0xc752('0x8e')](function(){var _0x299748=_0x534a15['channels'][_0x54d377['uniqueid']];if(typeof _0x299748[_0xc752('0x8f')]===_0xc752('0x90'))return;if(_[_0xc752('0x91')](_0x299748[_0xc752('0x6d')]))return;return RpcSetting[_0xc752('0x92')]()[_0xc752('0x8e')](function(_0x1432fc){if(!_0x1432fc[_0xc752('0x93')])return;return Promise[_0xc752('0x94')]()[_0xc752('0x8e')](function(){return ami[_0xc752('0x95')]({'action':'StopMixMonitor','channel':_0x299748['channel']})['catch'](function(){});})['then'](function(){return ami[_0xc752('0x95')]({'action':_0xc752('0x96'),'channel':_0x299748[_0xc752('0x97')]})[_0xc752('0x98')](function(){})[_0xc752('0x99')](function(){var _0x543e98=_0x534a15[_0xc752('0x45')][_0x299748[_0xc752('0x97')][_0xc752('0x46')]('-')[0x0]];if(!_0x543e98)return;io[_0xc752('0x32')](_0xc752('0x9a'),{'agentId':_0x543e98['id'],'uniqueid':_0x299748[_0xc752('0x33')]});});});});})[_0xc752('0x8e')](function(){if(_0x54d377[_0xc752('0x9b')]==='BlindTransfer'){_0x534a15[_0xc752('0x9c')][_0x54d377[_0xc752('0x33')]]=_0x534a15[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]];}else{if(_0x534a15[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]][_0xc752('0x9d')]==='outbound'&&_0x534a15[_0xc752('0x9c')][_0x54d377[_0xc752('0x33')]]){_0x534a15[_0xc752('0x1b')][_0x54d377['uniqueid']][_0xc752('0x33')]=[_0x534a15['channels'][_0x54d377['uniqueid']][_0xc752('0x35')],_0x534a15[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]][_0xc752('0x35')]=_0x534a15['channels'][_0x54d377[_0xc752('0x33')]][_0xc752('0x33')]][0x0];delete _0x534a15['blindTransfers'][_0x54d377[_0xc752('0x33')]];}}logger['debug']('[%s][voiceCallReport][hangup]\x20sending\x20hangup\x20event:',_0x54d377[_0xc752('0x33')],util[_0xc752('0x2f')](_0x534a15[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]],{'showHidden':![],'depth':null}));ami[_0xc752('0x32')](_0xc752('0x9e'),_0x534a15[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]]);delete _0x534a15[_0xc752('0x1b')][_0x54d377[_0xc752('0x33')]];});}}}catch(_0x3db480){logger[_0xc752('0x2d')](_0xc752('0x9f'),_0x54d377[_0xc752('0x33')],util['inspect'](_0x3db480,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')][_0xc752('0x27')]=function(_0x534c8e){try{if(this[_0xc752('0x31')](_0x534c8e)){logger[_0xc752('0x2c')](_0xc752('0xa0'),_0x534c8e['uniqueid'],_0x534c8e['origtransferercalleridnum'],_0x534c8e[_0xc752('0xa1')]);logger[_0xc752('0x3a')](_0xc752('0xa2'),_0x534c8e['uniqueid'],util[_0xc752('0x2f')](_0x534c8e,{'showHidden':![],'depth':null}));if(this[_0xc752('0x1b')][_0x534c8e['transfereeuniqueid']]){this['channels'][_0x534c8e[_0xc752('0xa3')]][_0xc752('0xa4')]=_0x534c8e[_0xc752('0xa5')];this[_0xc752('0x1b')][_0x534c8e['transfereeuniqueid']][_0xc752('0xa6')]=_0x534c8e[_0xc752('0xa1')];if(this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa7')]]){var _0x2cc273=this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa7')]];this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa7')]]=this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa3')]];this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa3')]]=_0x2cc273;}}else if(this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa8')]]){this['channels'][_0x534c8e[_0xc752('0xa8')]][_0xc752('0xa4')]=_0x534c8e[_0xc752('0xa5')];this['channels'][_0x534c8e[_0xc752('0xa8')]][_0xc752('0xa6')]=_0x534c8e[_0xc752('0xa1')];if(this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa9')]]){var _0x2cc273=this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa9')]];this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa9')]]=this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa8')]];this[_0xc752('0x1b')][_0x534c8e['transfertargetuniqueid']]=_0x2cc273;}}if((this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa9')]]||this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xaa')]])&&this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa7')]]){var _0x2e958c=_[_0xc752('0xab')]([this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa9')]],this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xaa')]],this['channels'][_0x534c8e['secondtransfereruniqueid']]],function(_0x55d7f1){return _0x55d7f1&&_0x55d7f1[_0xc752('0x9d')]==='outbound'&&_0x55d7f1['routeid'];});if(_0x2e958c){if(this[_0xc752('0x1b')][_0x534c8e['origtransfereruniqueid']])this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa9')]]['transferType']='ATTENDED';if(this['channels'][_0x534c8e[_0xc752('0xaa')]])this['channels'][_0x534c8e['origtransfererlinkedid']][_0xc752('0x8f')]=_0xc752('0xac');this[_0xc752('0x1b')][_0x534c8e[_0xc752('0xa7')]][_0xc752('0x8f')]=_0xc752('0xac');}}}}catch(_0x200d15){logger[_0xc752('0x2d')](_0xc752('0xad'),_0x534c8e[_0xc752('0x33')],util[_0xc752('0x2f')](_0x200d15,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')][_0xc752('0x28')]=function(_0x275d41){try{if(this[_0xc752('0x31')](_0x275d41)){logger[_0xc752('0x2c')](_0xc752('0xae'),_0x275d41[_0xc752('0x33')],_0x275d41[_0xc752('0xaf')],_0x275d41[_0xc752('0xb0')]);logger[_0xc752('0x3a')]('[%s][voiceCallReport][blindtransfer]\x20event:',_0x275d41['uniqueid'],util[_0xc752('0x2f')](_0x275d41,{'showHidden':![],'depth':null}));if(this[_0xc752('0x1b')][_0x275d41['transfereeuniqueid']]){this[_0xc752('0x1b')][_0x275d41[_0xc752('0xa3')]][_0xc752('0xa4')]=_0x275d41[_0xc752('0xaf')];this['channels'][_0x275d41[_0xc752('0xa3')]]['transferconnectedlinenum']=_0x275d41[_0xc752('0xb0')];this[_0xc752('0x1b')][_0x275d41[_0xc752('0xa3')]][_0xc752('0x8f')]=_0xc752('0xb1');this[_0xc752('0x25')]({'event':_0xc752('0xb2'),'uniqueid':_0x275d41[_0xc752('0xa3')],'context':_0x275d41['context'],'channel':_0x275d41[_0xc752('0xb3')]});}else{this[_0xc752('0x1b')][_0x275d41['transfereruniqueid']][_0xc752('0x8f')]=_0xc752('0xb1');}}}catch(_0x42ce20){logger['error'](_0xc752('0xb4'),_0x275d41[_0xc752('0x33')],util[_0xc752('0x2f')](_0x42ce20,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xc752('0x30')]['syncMusicOnHoldStart']=function(_0x255a7c){try{if(this['isNotNull'](_0x255a7c)){logger[_0xc752('0x3a')](_0xc752('0xb5'),_0x255a7c[_0xc752('0x33')],util[_0xc752('0x2f')](_0x255a7c,{'showHidden':![],'depth':null}));if(this['channels'][_0x255a7c['uniqueid']]){if(!_[_0xc752('0x6e')](this[_0xc752('0x1b')][_0x255a7c[_0xc752('0x33')]]['answertime'])){this[_0xc752('0x1b')][_0x255a7c['uniqueid']][_0xc752('0xb6')]=moment()['format'](_0xc752('0x41'));logger[_0xc752('0x2c')]('[%s][voiceCallReport][musiconholdstart]\x20mohstarttime:%s',_0x255a7c['uniqueid'],this[_0xc752('0x1b')][_0x255a7c['uniqueid']]['mohstarttime']);}}}}catch(_0x3057e0){logger['error'](_0xc752('0xb7'),_0x255a7c['uniqueid'],util[_0xc752('0x2f')](_0x3057e0,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype'][_0xc752('0x2b')]=function(_0x1a7c43){try{if(this[_0xc752('0x31')](_0x1a7c43)){logger[_0xc752('0x3a')](_0xc752('0xb8'),_0x1a7c43[_0xc752('0x33')],util[_0xc752('0x2f')](_0x1a7c43,{'showHidden':![],'depth':null}));if(this[_0xc752('0x1b')][_0x1a7c43[_0xc752('0x33')]]){if(!_[_0xc752('0x6e')](this[_0xc752('0x1b')][_0x1a7c43[_0xc752('0x33')]][_0xc752('0xb6')])){this[_0xc752('0x1b')][_0x1a7c43[_0xc752('0x33')]][_0xc752('0xb9')]+=moment()[_0xc752('0xba')](0x0)[_0xc752('0x89')](this[_0xc752('0x1b')][_0x1a7c43[_0xc752('0x33')]]['mohstarttime'],'seconds');logger[_0xc752('0x2c')]('[%s][voiceCallReport][musiconholdstop]\x20mohtime:%s',_0x1a7c43[_0xc752('0x33')],this[_0xc752('0x1b')][_0x1a7c43[_0xc752('0x33')]][_0xc752('0xb9')]);delete this[_0xc752('0x1b')][_0x1a7c43[_0xc752('0x33')]][_0xc752('0xb6')];}}}}catch(_0x28474d){logger[_0xc752('0x2d')](_0xc752('0xbb'),_0x1a7c43['uniqueid'],util[_0xc752('0x2f')](_0x28474d,{'showHidden':![],'depth':null}));}};module[_0xc752('0xbc')]=VoiceCallReport;