Built motion from commit 5b761a7b.|2.5.36
[motion2.git] / server / services / ami / report / voiceCallReport.js
index a29e8aa..54f3dd5 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x074a=['lodash','moment','util','ioredis','../../../config/logger','../model/channel','unknown','not_inuse','inuse','busy','invalid','unavailable','ringing','ringinuse','onhold','set','queue','agi','dial','playback','voicemail','NO\x20ANSWER','FAILED','ANSWERED','BUSY','redis','defaults','localhost','socket.io-emitter','channels','agents','coreshowchannel','syncNewExten','newexten','bind','syncNewChannel','newstate','syncNewState','varset','syncVarSet','hangup','syncHangup','newcallerid','syncNewCallerId','attendedtransfer','syncAttendedTransfer','blindtransfer','syncBlindTransfer','musiconholdstop','resolve','actionCoreShowChannels','catch','log','prototype','isNotNull','emit','linkedid','merge','uniqueid','keys','error','inspect','channel','OutgoingSpoolFailed','isUndefined','starttime','format','YYYY-MM-DD\x20HH:mm:ss','disposition','channelstate','pick','split','destconnectedlinenum','exten','user:%s','name','user:agentconnect','accountcode','[syncNewChannel][VoiceCallReport]','application','toLowerCase','applicationdata','duration','subtract','seconds','lastapplication','lastdata','startsWith','match','[syncNewExten][VoiceCallReport]','answered','holdtime','calleridnum','xcally-motion-preview','connectedlinenum','connectedlinename','calleridname','destinationchannel','toNumber','UserId','membername','syncMixMonitorFilename','endsWith','.WAV','find','isNil','monitors','push','rec','variable','mixmonitor_filename','xmd-phone','xmd-callerid','xmd-cdrtype','value','xmd-queue','xmd-originatecalleridnum','originatecalleridnum','destination','xmd-callerid-preview','xmcs-queue','sipcallid','sipcalluniqueid','sipcalllinkedid','diff','billableseconds','answertime','context','from-sip','omit','user:agentcomplete','custom:voiceCallReport','[syncHangup][VoiceCallReport]','transfereeuniqueid','transfercalleridnum','origtransferercalleridnum','transferconnectedlinenum','transfertargetcalleridnum','secondtransfereruniqueid','transfertargetuniqueid','origtransfereruniqueid','[syncAttendedTransfer][VoiceCallReport]','transfereecalleridnum','extension','transfererchannel','[syncBlindTransfer][VoiceCallReport]','syncMusicOnHoldStart','mohstarttime','syncMusicOnHoldStop','mohtime','milliseconds','bluebird'];(function(_0x3b27d1,_0x30fe89){var _0x30e16c=function(_0x220223){while(--_0x220223){_0x3b27d1['push'](_0x3b27d1['shift']());}};_0x30e16c(++_0x30fe89);}(_0x074a,0x97));var _0xa074=function(_0x20a584,_0xe384a5){_0x20a584=_0x20a584-0x0;var _0x4b41a8=_0x074a[_0x20a584];return _0x4b41a8;};'use strict';var BPromise=require(_0xa074('0x0'));var _=require(_0xa074('0x1'));var moment=require(_0xa074('0x2'));var util=require(_0xa074('0x3'));var path=require('path');var Redis=require(_0xa074('0x4'));var config=require('../../../config/environment');var logger=require(_0xa074('0x5'))('ami');var ami=require('../ami');var Channel=require(_0xa074('0x6'));var statusDesc=[_0xa074('0x7'),_0xa074('0x8'),_0xa074('0x9'),_0xa074('0xa'),_0xa074('0xb'),_0xa074('0xc'),_0xa074('0xd'),_0xa074('0xe'),_0xa074('0xf')];var applications=[_0xa074('0x10'),_0xa074('0x11'),_0xa074('0x12'),_0xa074('0x13'),_0xa074('0x14'),_0xa074('0x15')];var dispositions=[_0xa074('0x16'),_0xa074('0x17'),_0xa074('0x17'),_0xa074('0x16'),_0xa074('0x16'),_0xa074('0x16'),_0xa074('0x18'),_0xa074('0x19'),_0xa074('0x17'),_0xa074('0x17'),_0xa074('0x17')];var actions={};config[_0xa074('0x1a')]=_[_0xa074('0x1b')](config[_0xa074('0x1a')],{'host':_0xa074('0x1c'),'port':0x18eb});var io=require(_0xa074('0x1d'))(new Redis(config['redis']));function VoiceCallReport(_0x6a23b8){this[_0xa074('0x1e')]=_0x6a23b8[_0xa074('0x1e')];this[_0xa074('0x1f')]=_0x6a23b8[_0xa074('0x1f')];ami['on'](_0xa074('0x20'),this[_0xa074('0x21')]['bind'](this));ami['on'](_0xa074('0x22'),this['syncNewExten'][_0xa074('0x23')](this));ami['on']('newchannel',this[_0xa074('0x24')][_0xa074('0x23')](this));ami['on'](_0xa074('0x25'),this[_0xa074('0x26')][_0xa074('0x23')](this));ami['on'](_0xa074('0x27'),this[_0xa074('0x28')][_0xa074('0x23')](this));ami['on'](_0xa074('0x29'),this[_0xa074('0x2a')]['bind'](this));ami['on'](_0xa074('0x2b'),this[_0xa074('0x2c')][_0xa074('0x23')](this));ami['on'](_0xa074('0x2d'),this[_0xa074('0x2e')]['bind'](this));ami['on'](_0xa074('0x2f'),this[_0xa074('0x30')][_0xa074('0x23')](this));ami['on']('musiconholdstart',this['syncMusicOnHoldStart'][_0xa074('0x23')](this));ami['on'](_0xa074('0x31'),this['syncMusicOnHoldStop']['bind'](this));return BPromise[_0xa074('0x32')]()['then'](ami[_0xa074('0x33')]())[_0xa074('0x34')](function(_0xcdf3c){console[_0xa074('0x35')](_0xcdf3c);});}VoiceCallReport[_0xa074('0x36')][_0xa074('0x37')]=function(_0x5aa091){return _0x5aa091!==null&&!_['isUndefined'](_0x5aa091);};VoiceCallReport[_0xa074('0x36')][_0xa074('0x38')]=function(_0x13a58a,_0x354a03,_0x404eb8){io['to'](_0x13a58a)[_0xa074('0x38')](_0x354a03,_0x404eb8);};VoiceCallReport[_0xa074('0x36')][_0xa074('0x2c')]=function(_0xfc9241){try{if(this[_0xa074('0x37')](_0xfc9241)){if(_0xfc9241['uniqueid']===_0xfc9241[_0xa074('0x39')]){if(!_['isUndefined'](this[_0xa074('0x1e')][_0xfc9241['uniqueid']])){_[_0xa074('0x3a')](this[_0xa074('0x1e')][_0xfc9241[_0xa074('0x3b')]],_['pick'](_0xfc9241,_[_0xa074('0x3c')](this[_0xa074('0x1e')][_0xfc9241['uniqueid']])));}}}}catch(_0x15527b){logger[_0xa074('0x3d')]('[syncNewCallerId][VoiceCallReport]',util[_0xa074('0x3e')](_0x15527b,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype']['syncNewChannel']=function(_0x238096){try{if(this[_0xa074('0x37')](_0x238096)){if(_0x238096['uniqueid']===_0x238096[_0xa074('0x39')]&&_0x238096[_0xa074('0x3f')]!=_0xa074('0x40')){if(_[_0xa074('0x41')](this[_0xa074('0x1e')][_0x238096[_0xa074('0x3b')]])){this[_0xa074('0x1e')][_0x238096[_0xa074('0x3b')]]=new Channel();this[_0xa074('0x1e')][_0x238096['uniqueid']][_0xa074('0x42')]=moment()[_0xa074('0x43')](_0xa074('0x44'));this[_0xa074('0x1e')][_0x238096[_0xa074('0x3b')]][_0xa074('0x45')]=dispositions[_['toNumber'](_0x238096[_0xa074('0x46')])];_['merge'](this[_0xa074('0x1e')][_0x238096[_0xa074('0x3b')]],_[_0xa074('0x47')](_0x238096,_['keys'](this['channels'][_0x238096['uniqueid']])));if(_0x238096['context']==='from-sip'){if(this[_0xa074('0x1f')][_0x238096[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]]){this[_0xa074('0x1f')][_0x238096[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]][_0xa074('0x49')]=_0x238096[_0xa074('0x4a')];this[_0xa074('0x38')](util['format'](_0xa074('0x4b'),this[_0xa074('0x1f')][_0x238096[_0xa074('0x3f')]['split']('-')[0x0]][_0xa074('0x4c')]),_0xa074('0x4d'),{'destaccountcode':this[_0xa074('0x1f')][_0x238096[_0xa074('0x3f')]['split']('-')[0x0]][_0xa074('0x4e')],'destconnectedlinenum':_0x238096['exten']});}}}}}}catch(_0x5708d5){logger['error'](_0xa074('0x4f'),util[_0xa074('0x3e')](_0x5708d5,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xa074('0x36')]['syncNewExten']=function(_0x288820){try{if(this['isNotNull'](_0x288820)){if(_0x288820['uniqueid']===_0x288820[_0xa074('0x39')]&&_0x288820[_0xa074('0x4a')]!='h'&&_0x288820[_0xa074('0x3f')]!=_0xa074('0x40')){_0x288820[_0xa074('0x50')]=_0x288820[_0xa074('0x50')][_0xa074('0x51')]();_0x288820[_0xa074('0x52')]=(_0x288820['appdata']||_0x288820[_0xa074('0x52')])[_0xa074('0x51')]();if(_[_0xa074('0x41')](this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]])){this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]]=new Channel();this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]][_0xa074('0x42')]=_0x288820[_0xa074('0x53')]?moment()[_0xa074('0x54')](moment[_0xa074('0x53')](_0x288820[_0xa074('0x53')])['seconds'](),_0xa074('0x55'))['format'](_0xa074('0x44')):moment()[_0xa074('0x43')](_0xa074('0x44'));this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]][_0xa074('0x45')]=_0xa074('0x16');}_[_0xa074('0x3a')](this['channels'][_0x288820[_0xa074('0x3b')]],_['pick'](_0x288820,_['keys'](this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]])));if(_['includes'](applications,_0x288820[_0xa074('0x50')])){this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]][_0xa074('0x56')]=_0x288820['application'];this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]][_0xa074('0x57')]=_0x288820[_0xa074('0x52')];if(_0x288820['application']==='set'&&_[_0xa074('0x58')](_0x288820['applicationdata'],'cdr(')){var _0x50ced6=_0x288820[_0xa074('0x52')][_0xa074('0x48')]('=');var _0x32c053=_0x50ced6[0x0][_0xa074('0x59')](/cdr\((.*)\)/);if(_0x32c053){this['channels'][_0x288820[_0xa074('0x3b')]][_0x32c053[0x1]]=_0x50ced6[0x1];}}else if(_0x288820[_0xa074('0x50')]===_0xa074('0x11')){this[_0xa074('0x1e')][_0x288820[_0xa074('0x3b')]][_0xa074('0x11')]=_0x288820[_0xa074('0x52')][_0xa074('0x48')](',')[0x0];}}}}}catch(_0x419e29){logger[_0xa074('0x3d')](_0xa074('0x5a'),util[_0xa074('0x3e')](_0x419e29,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xa074('0x36')][_0xa074('0x26')]=function(_0x239d40){try{if(this[_0xa074('0x37')](_0x239d40)){if(_0x239d40[_0xa074('0x3b')]!==_0x239d40[_0xa074('0x39')]){if(this['channels'][_0x239d40[_0xa074('0x39')]]){if(_0x239d40[_0xa074('0x46')]==='6'){if(!this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x5b')]){var _0x53cee7=moment();this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x5b')]=!![];this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]]['answertime']=_0x53cee7['format'](_0xa074('0x44'));if(this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x42')]){this['channels'][_0x239d40[_0xa074('0x39')]][_0xa074('0x5c')]=_0x53cee7['diff'](this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x42')],_0xa074('0x55'));}}this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x39')]=_0x239d40['uniqueid'];if(_0x239d40[_0xa074('0x5d')]!==_0xa074('0x5e')){this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x5f')]=_0x239d40[_0xa074('0x5d')];}this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x60')]=_0x239d40[_0xa074('0x61')];this[_0xa074('0x1e')][_0x239d40['linkedid']][_0xa074('0x62')]=_0x239d40[_0xa074('0x3f')];this[_0xa074('0x1e')][_0x239d40[_0xa074('0x39')]][_0xa074('0x45')]=dispositions[_[_0xa074('0x63')](_0x239d40[_0xa074('0x46')])];if(this[_0xa074('0x1f')][_0x239d40[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]]){this[_0xa074('0x1e')][_0x239d40['linkedid']][_0xa074('0x64')]=this[_0xa074('0x1f')][_0x239d40['channel'][_0xa074('0x48')]('-')[0x0]]['id'];this['channels'][_0x239d40[_0xa074('0x39')]][_0xa074('0x65')]=this[_0xa074('0x1f')][_0x239d40['channel'][_0xa074('0x48')]('-')[0x0]][_0xa074('0x4c')];}}}}else{if(this[_0xa074('0x1e')][_0x239d40[_0xa074('0x3b')]]){if(_0x239d40[_0xa074('0x46')]==='6'){if(this[_0xa074('0x1f')][_0x239d40[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]]){this[_0xa074('0x1e')][_0x239d40[_0xa074('0x3b')]][_0xa074('0x64')]=this[_0xa074('0x1f')][_0x239d40[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]]['id'];this['channels'][_0x239d40['uniqueid']][_0xa074('0x65')]=this[_0xa074('0x1f')][_0x239d40[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]][_0xa074('0x4c')];}}}}}}catch(_0x57f392){logger[_0xa074('0x3d')]('[syncNewState][VoiceCallReport]',util['inspect'](_0x57f392,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xa074('0x36')][_0xa074('0x66')]=function(_0x1f87d2,_0x184129){if(this[_0xa074('0x1e')][_0x1f87d2]){this[_0xa074('0x1e')][_0x1f87d2]['monitor']=!![];if(_[_0xa074('0x67')](_0x184129,'.wav49')){_0x184129=_0x184129['replace']('.wav49',_0xa074('0x68'));}this['channels'][_0x1f87d2]['monitorFilename']=_0x184129;var _0x3278e0=_[_0xa074('0x69')](this[_0xa074('0x1e')][_0x1f87d2]['monitors'],{'filename':_0x184129});if(_[_0xa074('0x6a')](_0x3278e0)){this[_0xa074('0x1e')][_0x1f87d2][_0xa074('0x6b')][_0xa074('0x6c')]({'filename':_0x184129,'createdAt':moment()[_0xa074('0x43')](_0xa074('0x44')),'mixmonitorid':'','status':_0xa074('0x6d')});}}};VoiceCallReport[_0xa074('0x36')][_0xa074('0x28')]=function(_0x2c2f37){try{if(this['isNotNull'](_0x2c2f37)){if(this[_0xa074('0x1e')][_0x2c2f37['uniqueid']]&&_0x2c2f37[_0xa074('0x3f')]!=_0xa074('0x40')){if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')])){if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x6f')])){this[_0xa074('0x66')](_0x2c2f37[_0xa074('0x3b')],_0x2c2f37['value']);}else if(this[_0xa074('0x37')](_0x2c2f37['variable'][_0xa074('0x70')])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]][_0xa074('0x5d')]=_0x2c2f37['value'];}else if(this['isNotNull'](_0x2c2f37['variable'][_0xa074('0x71')])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]]['callerid']=_0x2c2f37['value'];}else if(this['isNotNull'](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x72')])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]]['type']=_0x2c2f37[_0xa074('0x73')];}else if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x74')])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]][_0xa074('0x11')]=_0x2c2f37['value'][_0xa074('0x48')](',')[0x0];}else if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x75')])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]][_0xa074('0x76')]=_0x2c2f37['value'];}else if(this['isNotNull'](_0x2c2f37[_0xa074('0x6e')]['xmd-destination'])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]][_0xa074('0x77')]=_0x2c2f37[_0xa074('0x73')];}else if(this['isNotNull'](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x78')])){this['channels'][_0x2c2f37['uniqueid']]['calleridpreview']=_0x2c2f37[_0xa074('0x73')];}else if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x79')])){this[_0xa074('0x1e')][_0x2c2f37['uniqueid']]['queue']=_0x2c2f37[_0xa074('0x73')];}else if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')][_0xa074('0x7a')])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x3b')]][_0xa074('0x7b')]=_0x2c2f37[_0xa074('0x73')];}}}else if(this[_0xa074('0x37')](_0x2c2f37['variable'][_0xa074('0x6f')])){if(_0x2c2f37[_0xa074('0x73')]){var _0x383ce8=path['parse'](_0x2c2f37[_0xa074('0x73')])['name'];this['syncMixMonitorFilename'](_0x383ce8,_0x2c2f37[_0xa074('0x73')]);}}else if(this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x39')]]){if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')])){if(this[_0xa074('0x37')](_0x2c2f37[_0xa074('0x6e')]['sipcallid'])){this[_0xa074('0x1e')][_0x2c2f37[_0xa074('0x39')]][_0xa074('0x7c')]=_0x2c2f37[_0xa074('0x73')];}}}}}catch(_0x2bef5f){logger['error']('[syncVarSet][VoiceCallReport]',util[_0xa074('0x3e')](_0x2bef5f,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype'][_0xa074('0x2a')]=function(_0x30a63d){try{if(this[_0xa074('0x37')](_0x30a63d)){if(this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]]){var _0xfd446a=moment();this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]]['endtime']=_0xfd446a['format']('YYYY-MM-DD\x20HH:mm:ss');this['channels'][_0x30a63d['uniqueid']][_0xa074('0x53')]=_0xfd446a[_0xa074('0x7d')](this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x42')],'seconds');if(this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x5b')]){this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x7e')]=_0xfd446a[_0xa074('0x7d')](this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x7f')],_0xa074('0x55'));this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x5c')]=this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x53')]-this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]][_0xa074('0x7e')];}if(_0x30a63d[_0xa074('0x80')]===_0xa074('0x81')){if(this[_0xa074('0x1f')][_0x30a63d['channel'][_0xa074('0x48')]('-')[0x0]]){this[_0xa074('0x1f')][_0x30a63d[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]]=_[_0xa074('0x82')](this[_0xa074('0x1f')][_0x30a63d[_0xa074('0x3f')][_0xa074('0x48')]('-')[0x0]],[_0xa074('0x49')]);this[_0xa074('0x38')](util[_0xa074('0x43')]('user:%s',this[_0xa074('0x1f')][_0x30a63d['channel']['split']('-')[0x0]]['name']),_0xa074('0x83'),{'destaccountcode':this['agents'][_0x30a63d['channel'][_0xa074('0x48')]('-')[0x0]][_0xa074('0x4e')]});}}ami[_0xa074('0x38')](_0xa074('0x84'),this[_0xa074('0x1e')][_0x30a63d['uniqueid']]);delete this[_0xa074('0x1e')][_0x30a63d[_0xa074('0x3b')]];}}}catch(_0x25b3bb){logger[_0xa074('0x3d')](_0xa074('0x85'),util['inspect'](_0x25b3bb,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xa074('0x36')][_0xa074('0x2e')]=function(_0x251051){try{if(this[_0xa074('0x37')](_0x251051)){if(this[_0xa074('0x1e')][_0x251051['transfereeuniqueid']]){this[_0xa074('0x1e')][_0x251051[_0xa074('0x86')]][_0xa074('0x87')]=_0x251051[_0xa074('0x88')];this[_0xa074('0x1e')][_0x251051[_0xa074('0x86')]][_0xa074('0x89')]=_0x251051[_0xa074('0x8a')];if(this[_0xa074('0x1e')][_0x251051[_0xa074('0x8b')]]){var _0x26f9cc=this[_0xa074('0x1e')][_0x251051['secondtransfereruniqueid']];this[_0xa074('0x1e')][_0x251051['secondtransfereruniqueid']]=this[_0xa074('0x1e')][_0x251051['transfereeuniqueid']];this[_0xa074('0x1e')][_0x251051['transfereeuniqueid']]=_0x26f9cc;}}else if(this[_0xa074('0x1e')][_0x251051[_0xa074('0x8c')]]){this[_0xa074('0x1e')][_0x251051[_0xa074('0x8c')]][_0xa074('0x87')]=_0x251051[_0xa074('0x88')];this[_0xa074('0x1e')][_0x251051[_0xa074('0x8c')]][_0xa074('0x89')]=_0x251051['transfertargetcalleridnum'];if(this[_0xa074('0x1e')][_0x251051[_0xa074('0x8d')]]){var _0x26f9cc=this['channels'][_0x251051['origtransfereruniqueid']];this['channels'][_0x251051[_0xa074('0x8d')]]=this[_0xa074('0x1e')][_0x251051['transfertargetuniqueid']];this[_0xa074('0x1e')][_0x251051[_0xa074('0x8c')]]=_0x26f9cc;}}}}catch(_0xbdc51e){logger[_0xa074('0x3d')](_0xa074('0x8e'),util[_0xa074('0x3e')](_0xbdc51e,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xa074('0x36')][_0xa074('0x30')]=function(_0x168c44){try{if(this[_0xa074('0x37')](_0x168c44)){if(this[_0xa074('0x1e')][_0x168c44[_0xa074('0x86')]]){this[_0xa074('0x1e')][_0x168c44[_0xa074('0x86')]][_0xa074('0x87')]=_0x168c44[_0xa074('0x8f')];this[_0xa074('0x1e')][_0x168c44[_0xa074('0x86')]][_0xa074('0x89')]=_0x168c44[_0xa074('0x90')];this[_0xa074('0x2a')]({'event':'BlindTransfer','uniqueid':_0x168c44[_0xa074('0x86')],'context':_0x168c44['context'],'channel':_0x168c44[_0xa074('0x91')]});}}}catch(_0x5c8a1a){logger['error'](_0xa074('0x92'),util[_0xa074('0x3e')](_0x5c8a1a,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xa074('0x36')][_0xa074('0x93')]=function(_0x5a780a){try{if(this[_0xa074('0x37')](_0x5a780a)){if(this['channels'][_0x5a780a[_0xa074('0x3b')]]){if(!_[_0xa074('0x6a')](this[_0xa074('0x1e')][_0x5a780a[_0xa074('0x3b')]]['answertime'])){this['channels'][_0x5a780a[_0xa074('0x3b')]][_0xa074('0x94')]=moment()[_0xa074('0x43')](_0xa074('0x44'));}}}}catch(_0x3dedb5){logger[_0xa074('0x3d')]('[syncMusicOnHoldStart][VoiceCallReport]',util['inspect'](_0x3dedb5,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype'][_0xa074('0x95')]=function(_0x108596){try{if(this[_0xa074('0x37')](_0x108596)){if(this[_0xa074('0x1e')][_0x108596[_0xa074('0x3b')]]){if(!_['isNil'](this[_0xa074('0x1e')][_0x108596['uniqueid']][_0xa074('0x94')])){this[_0xa074('0x1e')][_0x108596[_0xa074('0x3b')]][_0xa074('0x96')]+=moment()[_0xa074('0x97')](0x0)[_0xa074('0x7d')](this[_0xa074('0x1e')][_0x108596[_0xa074('0x3b')]][_0xa074('0x94')],_0xa074('0x55'));delete this[_0xa074('0x1e')][_0x108596['uniqueid']][_0xa074('0x94')];}}}}catch(_0x5c9041){logger[_0xa074('0x3d')]('[syncMusicOnHoldStop][VoiceCallReport]',util['inspect'](_0x5c9041,{'showHidden':![],'depth':null}));}};module['exports']=VoiceCallReport;
\ No newline at end of file
+var _0x800f=['transfereecalleridnum','[%s][voiceCallReport][blindtransfer]\x20event:','extension','BLIND','transfereruniqueid','[%s][voiceCallReport][blindtransfer]','[%s][voiceCallReport][musiconholdstart]\x20event:','isNil','[%s][voiceCallReport][musiconholdstart]\x20mohstarttime:%s','mohstarttime','[%s][voiceCallReport][musiconholdstart]','[%s][voiceCallReport][musiconholdstop]\x20mohtime:%s','mohtime','[%s][voiceCallReport][musiconholdstop]','lodash','util','path','ioredis','../../../config/environment','ami','../ami','../model/channel','set','agi','dial','playback','voicemail','NO\x20ANSWER','FAILED','ANSWERED','BUSY','redis','defaults','socket.io-emitter','channels','agents','blindTransfers','syncNewExten','newexten','bind','newchannel','newstate','syncNewState','syncVarSet','syncHangup','newcallerid','attendedtransfer','syncAttendedTransfer','blindtransfer','syncMusicOnHoldStart','musiconholdstop','info','[voiceCallReport][coreshowchannels]\x20started','actionCoreShowChannels','error','[voiceCallReport][coreshowchannels]','inspect','prototype','isUndefined','syncNewCallerId','isNotNull','[%s][voiceCallReport][newcallerid]\x20calleridname:%s\x20calleridnum:%s','uniqueid','calleridname','calleridnum','debug','merge','pick','keys','from-sip','channel','split','exten','xcally-motion-preview','emit','format','user:%s','name','user:agentconnect','connectedlinenum','[%s][voiceCallReport][newcallerid]','syncNewChannel','[%s][voiceCallReport][newchannel]\x20event:','OutgoingSpoolFailed','starttime','YYYY-MM-DD\x20HH:mm:ss','disposition','channelstate','destconnectedlinenum','[%s][voiceCallReport][newchannel]\x20sending\x20user:agentconnect\x20event:','accountcode','[%s][voiceCallReport][newexten]\x20event:','linkedid','toLowerCase','applicationdata','appdata','startsWith','[%s][voiceCallReport][newexten]\x20application:%s\x20appdata:%s','application','subtract','duration','seconds','lastapplication','lastdata','cdr(','match','queue','[%s][voiceCallReport][newexten]','answered','diff','toNumber','UserId','membername','routealias','[%s][voiceCallReport][newstate]','syncMixMonitorFilename','[%s][voiceCallReport][mixMonitorFilename]\x20monitorFilename:%s','monitor','endsWith','replace','.WAV','monitorFilename','monitors','push','rec','[%s][voiceCallReport][mixMonitorFilename]','[%s][voiceCallReport][varset]\x20event:','variable','mixmonitor_filename','value','xmd-phone','[%s][voiceCallReport][varset]\x20variable:xmd-callerid\x20value:%s','xmd-cdrtype','[%s][voiceCallReport][varset]\x20variable:xmd-cdrtype\x20value:%s','[%s][voiceCallReport][varset]\x20variable:xmd-queue\x20value:%s','xmd-originatecalleridnum','[%s][voiceCallReport][varset]\x20variable:xmd-originatecalleridnum\x20value:%s','originatecalleridnum','xmd-destination','[%s][voiceCallReport][varset]\x20variable:xmd-destination\x20value:%s','[%s][voiceCallReport][varset]\x20variable:xmd-callerid-preview\x20value:%s','calleridpreview','xmcs-queue','[%s][voiceCallReport][varset]\x20variable:xmcs-queue\x20value:%s','sipcallid','[%s][voiceCallReport][varset]\x20variable:sipcallid\x20value:%s','sipcalluniqueid','parse','[%s][voiceCallReport][varset]\x20variable:mixmonitor_filename\x20value:%s','sipcalllinkedid','[%s][voiceCallReport][varset]','[%s][voiceCallReport][hangup]\x20event:','[%s][voiceCallReport][hangup]\x20reason:%s','cause-txt','endtime','answertime','holdtime','billableseconds','context','omit','[%s][voiceCallReport][hangup]\x20sending\x20user:agentcomplete\x20event:','user:agentcomplete','length','transferType','undefined','getSettings','stopRecordingOnTransfer','resolve','then','Action','StopMixMonitor','catch','destinationchannel','webbar:stopmonitors','BlindTransfer','outbound','custom:voiceCallReport','[%s][voiceCallReport][attendedtransfer]\x20transfercalleridnum:%s\x20transferconnectedlinenum:%s','origtransferercalleridnum','transfertargetcalleridnum','[%s][voiceCallReport][attendedtransfer]\x20event:','transfereeuniqueid','transfercalleridnum','transferconnectedlinenum','secondtransfereruniqueid','transfertargetuniqueid','origtransfereruniqueid','origtransfererlinkedid','type','ATTENDED','syncBlindTransfer'];(function(_0xf738ad,_0x5e1d7f){var _0x598570=function(_0x35088e){while(--_0x35088e){_0xf738ad['push'](_0xf738ad['shift']());}};_0x598570(++_0x5e1d7f);}(_0x800f,0x18c));var _0xf800=function(_0x361dda,_0x38b470){_0x361dda=_0x361dda-0x0;var _0x2c73c7=_0x800f[_0x361dda];return _0x2c73c7;};'use strict';var _=require(_0xf800('0x0'));var moment=require('moment');var util=require(_0xf800('0x1'));var path=require(_0xf800('0x2'));var Redis=require(_0xf800('0x3'));var config=require(_0xf800('0x4'));var logger=require('../../../config/logger')(_0xf800('0x5'));var ami=require(_0xf800('0x6'));var Channel=require(_0xf800('0x7'));var RpcSetting=require('../rpc/setting');var applications=[_0xf800('0x8'),'queue',_0xf800('0x9'),_0xf800('0xa'),_0xf800('0xb'),_0xf800('0xc')];var dispositions=[_0xf800('0xd'),_0xf800('0xe'),'FAILED',_0xf800('0xd'),_0xf800('0xd'),_0xf800('0xd'),_0xf800('0xf'),_0xf800('0x10'),'FAILED',_0xf800('0xe'),_0xf800('0xe')];config[_0xf800('0x11')]=_[_0xf800('0x12')](config[_0xf800('0x11')],{'host':'localhost','port':0x18eb});var io=require(_0xf800('0x13'))(new Redis(config[_0xf800('0x11')]));function VoiceCallReport(_0x44bb29){this[_0xf800('0x14')]=_0x44bb29[_0xf800('0x14')];this[_0xf800('0x15')]=_0x44bb29[_0xf800('0x15')];this[_0xf800('0x16')]={};ami['on']('coreshowchannel',this[_0xf800('0x17')]['bind'](this));ami['on'](_0xf800('0x18'),this['syncNewExten'][_0xf800('0x19')](this));ami['on'](_0xf800('0x1a'),this['syncNewChannel'][_0xf800('0x19')](this));ami['on'](_0xf800('0x1b'),this[_0xf800('0x1c')][_0xf800('0x19')](this));ami['on']('varset',this[_0xf800('0x1d')][_0xf800('0x19')](this));ami['on']('hangup',this[_0xf800('0x1e')]['bind'](this));ami['on'](_0xf800('0x1f'),this['syncNewCallerId'][_0xf800('0x19')](this));ami['on'](_0xf800('0x20'),this[_0xf800('0x21')][_0xf800('0x19')](this));ami['on'](_0xf800('0x22'),this['syncBlindTransfer']['bind'](this));ami['on']('musiconholdstart',this[_0xf800('0x23')][_0xf800('0x19')](this));ami['on'](_0xf800('0x24'),this['syncMusicOnHoldStop'][_0xf800('0x19')](this));try{logger[_0xf800('0x25')](_0xf800('0x26'));ami[_0xf800('0x27')]();}catch(_0x437f91){logger[_0xf800('0x28')](_0xf800('0x29'),util[_0xf800('0x2a')](_0x437f91,{'showHidden':![],'depth':null}));}}VoiceCallReport[_0xf800('0x2b')]['isNotNull']=function(_0x2c51eb){return _0x2c51eb!==null&&!_[_0xf800('0x2c')](_0x2c51eb);};VoiceCallReport[_0xf800('0x2b')]['emit']=function(_0xf4fed1,_0x3fdcca,_0x4a328e){io['to'](_0xf4fed1)['emit'](_0x3fdcca,_0x4a328e);};VoiceCallReport['prototype'][_0xf800('0x2d')]=function(_0x4ab1df){try{if(this[_0xf800('0x2e')](_0x4ab1df)){logger[_0xf800('0x25')](_0xf800('0x2f'),_0x4ab1df[_0xf800('0x30')],_0x4ab1df[_0xf800('0x31')],_0x4ab1df[_0xf800('0x32')]);logger[_0xf800('0x33')]('[%s][voiceCallReport][newcallerid]\x20event:',_0x4ab1df[_0xf800('0x30')],util[_0xf800('0x2a')](_0x4ab1df,{'showHidden':![],'depth':null}));if(_0x4ab1df[_0xf800('0x30')]===_0x4ab1df['linkedid']){if(!_['isUndefined'](this[_0xf800('0x14')][_0x4ab1df['uniqueid']])){_[_0xf800('0x34')](this['channels'][_0x4ab1df[_0xf800('0x30')]],_[_0xf800('0x35')](_0x4ab1df,_[_0xf800('0x36')](this[_0xf800('0x14')][_0x4ab1df['uniqueid']])));}}if(_0x4ab1df['context']===_0xf800('0x37')){if(this['agents'][_0x4ab1df[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]){if(_0x4ab1df[_0xf800('0x3a')]==_0xf800('0x3b')){this['agents'][_0x4ab1df['channel'][_0xf800('0x39')]('-')[0x0]]['destconnectedlinenum']=_0x4ab1df['connectedlinenum'];this[_0xf800('0x3c')](util[_0xf800('0x3d')](_0xf800('0x3e'),this[_0xf800('0x15')][_0x4ab1df[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x3f')]),_0xf800('0x40'),{'destaccountcode':this[_0xf800('0x15')][_0x4ab1df[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['accountcode'],'destconnectedlinenum':_0x4ab1df[_0xf800('0x41')]});}}}}}catch(_0x471496){logger[_0xf800('0x28')](_0xf800('0x42'),_0x4ab1df['uniqueid'],util[_0xf800('0x2a')](_0x471496,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')][_0xf800('0x43')]=function(_0x3e04b8){try{if(this[_0xf800('0x2e')](_0x3e04b8)){logger[_0xf800('0x33')](_0xf800('0x44'),_0x3e04b8[_0xf800('0x30')],util['inspect'](_0x3e04b8,{'showHidden':![],'depth':null}));if(_0x3e04b8[_0xf800('0x30')]===_0x3e04b8['linkedid']&&_0x3e04b8[_0xf800('0x38')]!=_0xf800('0x45')){if(_['isUndefined'](this[_0xf800('0x14')][_0x3e04b8[_0xf800('0x30')]])){logger[_0xf800('0x25')]('[%s][voiceCallReport][newchannel]\x20context:%s\x20exten:%s',_0x3e04b8[_0xf800('0x30')],_0x3e04b8['context'],_0x3e04b8[_0xf800('0x3a')]);this[_0xf800('0x14')][_0x3e04b8[_0xf800('0x30')]]=new Channel();this['channels'][_0x3e04b8[_0xf800('0x30')]][_0xf800('0x46')]=moment()[_0xf800('0x3d')](_0xf800('0x47'));this[_0xf800('0x14')][_0x3e04b8[_0xf800('0x30')]][_0xf800('0x48')]=dispositions[_['toNumber'](_0x3e04b8[_0xf800('0x49')])];_['merge'](this[_0xf800('0x14')][_0x3e04b8[_0xf800('0x30')]],_[_0xf800('0x35')](_0x3e04b8,_[_0xf800('0x36')](this[_0xf800('0x14')][_0x3e04b8[_0xf800('0x30')]])));if(_0x3e04b8['context']==='from-sip'){if(this[_0xf800('0x15')][_0x3e04b8[_0xf800('0x38')]['split']('-')[0x0]]){if(_[_0xf800('0x2c')](this[_0xf800('0x15')][_0x3e04b8[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x4a')])){this[_0xf800('0x15')][_0x3e04b8[_0xf800('0x38')]['split']('-')[0x0]]['destconnectedlinenum']=_0x3e04b8[_0xf800('0x3a')];logger['debug'](_0xf800('0x4b'),_0x3e04b8['uniqueid'],util[_0xf800('0x2a')]({'id':this[_0xf800('0x15')][_0x3e04b8[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['id'],'destaccountcode':this['agents'][_0x3e04b8['channel']['split']('-')[0x0]][_0xf800('0x4c')],'destconnectedlinenum':_0x3e04b8[_0xf800('0x3a')]},{'showHidden':![],'depth':null}));this[_0xf800('0x3c')](util['format']('user:%s',this[_0xf800('0x15')][_0x3e04b8['channel']['split']('-')[0x0]]['name']),_0xf800('0x40'),{'id':this[_0xf800('0x15')][_0x3e04b8[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['id'],'destaccountcode':this[_0xf800('0x15')][_0x3e04b8[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x4c')],'destconnectedlinenum':_0x3e04b8['exten']});}}}}}}}catch(_0x2e6fd3){logger['error']('[%s][voiceCallReport][newchannel]',_0x3e04b8['uniqueid'],util[_0xf800('0x2a')](_0x2e6fd3,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')][_0xf800('0x17')]=function(_0x27d55b){try{if(this[_0xf800('0x2e')](_0x27d55b)){logger[_0xf800('0x33')](_0xf800('0x4d'),_0x27d55b[_0xf800('0x30')],util['inspect'](_0x27d55b,{'showHidden':![],'depth':null}));if(_0x27d55b['uniqueid']===_0x27d55b[_0xf800('0x4e')]&&_0x27d55b[_0xf800('0x3a')]!='h'&&_0x27d55b[_0xf800('0x38')]!=_0xf800('0x45')){_0x27d55b['application']=_0x27d55b['application'][_0xf800('0x4f')]();_0x27d55b[_0xf800('0x50')]=_0x27d55b[_0xf800('0x51')]&&_0x27d55b[_0xf800('0x51')][_0xf800('0x52')]('CDR(routeAlias)')?_0x27d55b[_0xf800('0x51')]:(_0x27d55b[_0xf800('0x51')]||_0x27d55b[_0xf800('0x50')])[_0xf800('0x4f')]();logger['info'](_0xf800('0x53'),_0x27d55b[_0xf800('0x30')],_0x27d55b[_0xf800('0x54')],_0x27d55b[_0xf800('0x50')]);if(_[_0xf800('0x2c')](this['channels'][_0x27d55b[_0xf800('0x30')]])){this[_0xf800('0x14')][_0x27d55b[_0xf800('0x30')]]=new Channel();this[_0xf800('0x14')][_0x27d55b['uniqueid']][_0xf800('0x46')]=_0x27d55b['duration']?moment()[_0xf800('0x55')](moment[_0xf800('0x56')](_0x27d55b['duration'])[_0xf800('0x57')](),_0xf800('0x57'))['format'](_0xf800('0x47')):moment()[_0xf800('0x3d')](_0xf800('0x47'));this[_0xf800('0x14')][_0x27d55b['uniqueid']][_0xf800('0x48')]='NO\x20ANSWER';}_[_0xf800('0x34')](this[_0xf800('0x14')][_0x27d55b[_0xf800('0x30')]],_[_0xf800('0x35')](_0x27d55b,_[_0xf800('0x36')](this[_0xf800('0x14')][_0x27d55b[_0xf800('0x30')]])));if(_['includes'](applications,_0x27d55b[_0xf800('0x54')])){this['channels'][_0x27d55b[_0xf800('0x30')]][_0xf800('0x58')]=_0x27d55b[_0xf800('0x54')];this[_0xf800('0x14')][_0x27d55b[_0xf800('0x30')]][_0xf800('0x59')]=_0x27d55b[_0xf800('0x50')];if(_0x27d55b[_0xf800('0x54')]===_0xf800('0x8')&&_[_0xf800('0x52')](_0x27d55b[_0xf800('0x50')][_0xf800('0x4f')](),_0xf800('0x5a'))){var _0x4356ba=_0x27d55b['applicationdata']['split']('=');var _0x17d274=_0x4356ba[0x0][_0xf800('0x4f')]()[_0xf800('0x5b')](/cdr\((.*)\)/);if(_0x17d274){this[_0xf800('0x14')][_0x27d55b[_0xf800('0x30')]][_0x17d274[0x1]]=_0x4356ba[0x1];}}else if(_0x27d55b[_0xf800('0x54')]===_0xf800('0x5c')){this[_0xf800('0x14')][_0x27d55b['uniqueid']]['queue']=_0x27d55b[_0xf800('0x50')][_0xf800('0x39')](',')[0x0];}}}}}catch(_0x1b6718){logger['error'](_0xf800('0x5d'),_0x27d55b[_0xf800('0x30')],util[_0xf800('0x2a')](_0x1b6718,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype'][_0xf800('0x1c')]=function(_0x167a93){try{if(this[_0xf800('0x2e')](_0x167a93)){logger[_0xf800('0x25')]('[%s][voiceCallReport][newstate]\x20linkedid:%s\x20calleridname:%s\x20calleridnum:%s',_0x167a93[_0xf800('0x30')],_0x167a93[_0xf800('0x4e')],_0x167a93[_0xf800('0x31')],_0x167a93[_0xf800('0x32')]);logger['debug']('[%s][voiceCallReport][newstate]\x20event:',_0x167a93[_0xf800('0x30')],util[_0xf800('0x2a')](_0x167a93,{'showHidden':![],'depth':null}));if(_0x167a93['uniqueid']!==_0x167a93[_0xf800('0x4e')]){if(this[_0xf800('0x14')][_0x167a93['linkedid']]){if(_0x167a93[_0xf800('0x49')]==='6'){if(!this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]]['answered']){var _0x4381e6=moment();this['channels'][_0x167a93[_0xf800('0x4e')]][_0xf800('0x5e')]=!![];this[_0xf800('0x14')][_0x167a93['linkedid']]['answertime']=_0x4381e6[_0xf800('0x3d')]('YYYY-MM-DD\x20HH:mm:ss');if(this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]]['starttime']){this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]]['holdtime']=_0x4381e6[_0xf800('0x5f')](this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]][_0xf800('0x46')],_0xf800('0x57'));}}this['channels'][_0x167a93['linkedid']][_0xf800('0x4e')]=_0x167a93[_0xf800('0x30')];if(_0x167a93[_0xf800('0x32')]!==_0xf800('0x3b')){this['channels'][_0x167a93[_0xf800('0x4e')]][_0xf800('0x41')]=_0x167a93[_0xf800('0x32')];}this['channels'][_0x167a93['linkedid']]['connectedlinename']=_0x167a93[_0xf800('0x31')];this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]]['destinationchannel']=_0x167a93[_0xf800('0x38')];this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]][_0xf800('0x48')]=dispositions[_[_0xf800('0x60')](_0x167a93['channelstate'])];if(this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]){this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]][_0xf800('0x61')]=this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['id'];this[_0xf800('0x14')][_0x167a93['linkedid']][_0xf800('0x62')]=this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')]['split']('-')[0x0]][_0xf800('0x3f')];}}}}else{if(this[_0xf800('0x14')][_0x167a93[_0xf800('0x30')]]){if(_0x167a93[_0xf800('0x49')]==='6'){if(this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]){this[_0xf800('0x14')][_0x167a93[_0xf800('0x30')]][_0xf800('0x61')]=this[_0xf800('0x15')][_0x167a93['channel'][_0xf800('0x39')]('-')[0x0]]['id'];this[_0xf800('0x14')][_0x167a93[_0xf800('0x30')]][_0xf800('0x62')]=this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x3f')];}}}}if(_0x167a93['channelstate']==='6'&&_0x167a93['context']==='from-sip'){if(this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]){this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')]['split']('-')[0x0]][_0xf800('0x4a')]=_0x167a93['exten'];var _0x26945e,_0x26409c;if(this['channels'][_0x167a93['uniqueid']]){_0x26945e=this[_0xf800('0x14')][_0x167a93['uniqueid']][_0xf800('0x63')];_0x26409c=this[_0xf800('0x14')][_0x167a93[_0xf800('0x30')]][_0xf800('0x5c')];}else if(this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]]){_0x26945e=this[_0xf800('0x14')][_0x167a93[_0xf800('0x4e')]][_0xf800('0x63')];_0x26409c=this[_0xf800('0x14')][_0x167a93['linkedid']][_0xf800('0x5c')];}logger[_0xf800('0x33')]('[%s][voiceCallReport][newstate]\x20sending\x20user:agentconnect\x20event:',_0x167a93[_0xf800('0x30')],util[_0xf800('0x2a')]({'id':this['agents'][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['id'],'destaccountcode':this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x4c')],'destconnectedlinenum':_0x167a93['exten'],'routealias':_0x26945e,'queue':_0x26409c||undefined},{'showHidden':![],'depth':null}));this[_0xf800('0x3c')](util[_0xf800('0x3d')]('user:%s',this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['name']),_0xf800('0x40'),{'id':this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['id'],'agentconnected':!![],'destaccountcode':this[_0xf800('0x15')][_0x167a93[_0xf800('0x38')]['split']('-')[0x0]]['accountcode'],'destconnectedlinenum':_0x167a93[_0xf800('0x3a')],'routealias':_0x26945e,'queue':_0x26409c||undefined});}}}}catch(_0xd57b94){logger['error'](_0xf800('0x64'),_0x167a93[_0xf800('0x30')],util[_0xf800('0x2a')](_0xd57b94,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')][_0xf800('0x65')]=function(_0x18ce21,_0x4fb3ce){try{if(this[_0xf800('0x14')][_0x18ce21]){logger['info'](_0xf800('0x66'),_0x18ce21,_0x4fb3ce);this['channels'][_0x18ce21][_0xf800('0x67')]=!![];if(_[_0xf800('0x68')](_0x4fb3ce,'.wav49')){_0x4fb3ce=_0x4fb3ce[_0xf800('0x69')]('.wav49',_0xf800('0x6a'));}this['channels'][_0x18ce21][_0xf800('0x6b')]=_0x4fb3ce;var _0x4dcf73=_['find'](this[_0xf800('0x14')][_0x18ce21][_0xf800('0x6c')],{'filename':_0x4fb3ce});if(_['isNil'](_0x4dcf73)){this['channels'][_0x18ce21][_0xf800('0x6c')][_0xf800('0x6d')]({'filename':_0x4fb3ce,'createdAt':moment()[_0xf800('0x3d')](_0xf800('0x47')),'mixmonitorid':'','status':_0xf800('0x6e')});}}}catch(_0x5a22f0){logger[_0xf800('0x28')](_0xf800('0x6f'),_0x18ce21,util[_0xf800('0x2a')](_0x5a22f0,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')]['syncVarSet']=function(_0x387939){try{if(this[_0xf800('0x2e')](_0x387939)){logger['debug'](_0xf800('0x70'),_0x387939['uniqueid'],util['inspect'](_0x387939,{'showHidden':![],'depth':null}));if(this[_0xf800('0x14')][_0x387939['uniqueid']]&&_0x387939['channel']!='OutgoingSpoolFailed'){if(this['isNotNull'](_0x387939['variable'])){if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')][_0xf800('0x72')])){logger[_0xf800('0x25')]('[%s][voiceCallReport][varset]\x20variable:mixmonitor_filename\x20value:%s',_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);this['syncMixMonitorFilename'](_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')][_0xf800('0x74')])){logger[_0xf800('0x25')]('[%s][voiceCallReport][varset]\x20variable:xmd-phone\x20value:%s',_0x387939[_0xf800('0x30')],_0x387939['value']);this[_0xf800('0x14')][_0x387939[_0xf800('0x30')]][_0xf800('0x32')]=_0x387939[_0xf800('0x73')];}else if(this[_0xf800('0x2e')](_0x387939['variable']['xmd-callerid'])){logger['info'](_0xf800('0x75'),_0x387939['uniqueid'],_0x387939[_0xf800('0x73')]);this[_0xf800('0x14')][_0x387939[_0xf800('0x30')]]['callerid']=_0x387939[_0xf800('0x73')];}else if(this['isNotNull'](_0x387939[_0xf800('0x71')][_0xf800('0x76')])){logger[_0xf800('0x25')](_0xf800('0x77'),_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);this['channels'][_0x387939[_0xf800('0x30')]]['type']=_0x387939['value'];}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')]['xmd-queue'])){logger[_0xf800('0x25')](_0xf800('0x78'),_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')][_0xf800('0x39')](',')[0x0]);this[_0xf800('0x14')][_0x387939[_0xf800('0x30')]][_0xf800('0x5c')]=_0x387939['value'][_0xf800('0x39')](',')[0x0];}else if(this[_0xf800('0x2e')](_0x387939['variable'][_0xf800('0x79')])){logger['info'](_0xf800('0x7a'),_0x387939['uniqueid'],_0x387939[_0xf800('0x73')]);this[_0xf800('0x14')][_0x387939['uniqueid']][_0xf800('0x7b')]=_0x387939[_0xf800('0x73')];}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')][_0xf800('0x7c')])){logger[_0xf800('0x25')](_0xf800('0x7d'),_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);this[_0xf800('0x14')][_0x387939['uniqueid']]['destination']=_0x387939[_0xf800('0x73')];}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')]['xmd-callerid-preview'])){logger[_0xf800('0x25')](_0xf800('0x7e'),_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);this[_0xf800('0x14')][_0x387939[_0xf800('0x30')]][_0xf800('0x7f')]=_0x387939['value'];}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')][_0xf800('0x80')])){logger['info'](_0xf800('0x81'),_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);this[_0xf800('0x14')][_0x387939['uniqueid']]['queue']=_0x387939[_0xf800('0x73')];}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')][_0xf800('0x82')])){logger[_0xf800('0x25')](_0xf800('0x83'),_0x387939[_0xf800('0x30')],_0x387939[_0xf800('0x73')]);this['channels'][_0x387939[_0xf800('0x30')]][_0xf800('0x84')]=_0x387939['value'];}}}else if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')][_0xf800('0x72')])){if(_0x387939[_0xf800('0x73')]){var _0x4d9cd9=path[_0xf800('0x85')](_0x387939[_0xf800('0x73')])[_0xf800('0x3f')];logger[_0xf800('0x25')](_0xf800('0x86'),_0x4d9cd9,_0x387939['value']);this[_0xf800('0x65')](_0x4d9cd9,_0x387939['value']);}}else if(this['channels'][_0x387939[_0xf800('0x4e')]]){if(this[_0xf800('0x2e')](_0x387939[_0xf800('0x71')])){if(this[_0xf800('0x2e')](_0x387939['variable'][_0xf800('0x82')])){logger[_0xf800('0x25')](_0xf800('0x83'),_0x387939[_0xf800('0x4e')],_0x387939[_0xf800('0x73')]);this[_0xf800('0x14')][_0x387939['linkedid']][_0xf800('0x87')]=_0x387939['value'];}}}}}catch(_0x43e48c){logger[_0xf800('0x28')](_0xf800('0x88'),_0x387939[_0xf800('0x30')],util[_0xf800('0x2a')](_0x43e48c,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')]['syncHangup']=function(_0x89b726){try{if(this['isNotNull'](_0x89b726)){logger[_0xf800('0x33')](_0xf800('0x89'),_0x89b726['uniqueid'],util[_0xf800('0x2a')](_0x89b726,{'showHidden':![],'depth':null}));if(this[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]]){logger[_0xf800('0x25')](_0xf800('0x8a'),_0x89b726[_0xf800('0x30')],_0x89b726[_0xf800('0x8b')]);var _0x38616b=moment();this['channels'][_0x89b726[_0xf800('0x30')]][_0xf800('0x8c')]=_0x38616b[_0xf800('0x3d')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]][_0xf800('0x56')]=_0x38616b[_0xf800('0x5f')](this[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]][_0xf800('0x46')],_0xf800('0x57'));if(this['channels'][_0x89b726[_0xf800('0x30')]][_0xf800('0x5e')]){this['channels'][_0x89b726[_0xf800('0x30')]]['billableseconds']=_0x38616b['diff'](this[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]][_0xf800('0x8d')],'seconds');this['channels'][_0x89b726[_0xf800('0x30')]][_0xf800('0x8e')]=this[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]]['duration']-this[_0xf800('0x14')][_0x89b726['uniqueid']][_0xf800('0x8f')];}if(_0x89b726[_0xf800('0x90')]===_0xf800('0x37')){if(this[_0xf800('0x15')][_0x89b726['channel']['split']('-')[0x0]]){this['agents'][_0x89b726[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]=_[_0xf800('0x91')](this[_0xf800('0x15')][_0x89b726[_0xf800('0x38')]['split']('-')[0x0]],[_0xf800('0x4a')]);logger['debug'](_0xf800('0x92'),_0x89b726['uniqueid'],util[_0xf800('0x2a')]({'id':this['agents'][_0x89b726['channel'][_0xf800('0x39')]('-')[0x0]]['id'],'destaccountcode':this[_0xf800('0x15')][_0x89b726[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]]['accountcode']},{'showHidden':![],'depth':null}));this[_0xf800('0x3c')](util['format']('user:%s',this[_0xf800('0x15')][_0x89b726[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x3f')]),_0xf800('0x93'),{'id':this[_0xf800('0x15')][_0x89b726['channel'][_0xf800('0x39')]('-')[0x0]]['id'],'destaccountcode':this[_0xf800('0x15')][_0x89b726[_0xf800('0x38')][_0xf800('0x39')]('-')[0x0]][_0xf800('0x4c')]});for(var _0x473231=0x0;_0x473231<Object[_0xf800('0x36')](this[_0xf800('0x15')])[_0xf800('0x94')];_0x473231++){var _0x17f152=Object[_0xf800('0x36')](this[_0xf800('0x15')])[_0x473231];var _0x5cd2ec=this['agents'][_0x17f152];if(_0x5cd2ec[_0xf800('0x4c')]===Number(_0x89b726['connectedlinenum'])){this[_0xf800('0x3c')](util['format'](_0xf800('0x3e'),_0x5cd2ec[_0xf800('0x3f')]),'user:agentcomplete',{'id':_0x5cd2ec['id'],'destaccountcode':_0x5cd2ec[_0xf800('0x4c')]});break;}}}}var _0x4f1755=this;Promise['resolve']()['then'](function(){var _0x1e8bd0=_0x4f1755[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]];if(typeof _0x1e8bd0[_0xf800('0x95')]===_0xf800('0x96'))return;if(_['isEmpty'](_0x1e8bd0['monitors']))return;return RpcSetting[_0xf800('0x97')]()['then'](function(_0x19eb45){if(!_0x19eb45[_0xf800('0x98')])return;return Promise[_0xf800('0x99')]()[_0xf800('0x9a')](function(){return ami[_0xf800('0x9b')]({'action':_0xf800('0x9c'),'channel':_0x1e8bd0[_0xf800('0x38')]})[_0xf800('0x9d')](function(){});})['then'](function(){return ami[_0xf800('0x9b')]({'action':_0xf800('0x9c'),'channel':_0x1e8bd0[_0xf800('0x9e')]})[_0xf800('0x9d')](function(){})['finally'](function(){var _0xf55d5a=_0x4f1755['agents'][_0x1e8bd0[_0xf800('0x9e')][_0xf800('0x39')]('-')[0x0]];if(!_0xf55d5a)return;io[_0xf800('0x3c')](_0xf800('0x9f'),{'agentId':_0xf55d5a['id'],'uniqueid':_0x1e8bd0[_0xf800('0x30')]});});});});})['then'](function(){if(_0x89b726['event']===_0xf800('0xa0')){_0x4f1755[_0xf800('0x16')][_0x89b726[_0xf800('0x30')]]=_0x4f1755['channels'][_0x89b726[_0xf800('0x30')]];}else{if(_0x4f1755[_0xf800('0x14')][_0x89b726['uniqueid']]['type']===_0xf800('0xa1')&&_0x4f1755['blindTransfers'][_0x89b726['uniqueid']]){_0x4f1755[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]][_0xf800('0x30')]=[_0x4f1755[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]][_0xf800('0x4e')],_0x4f1755[_0xf800('0x14')][_0x89b726['uniqueid']][_0xf800('0x4e')]=_0x4f1755[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]][_0xf800('0x30')]][0x0];delete _0x4f1755[_0xf800('0x16')][_0x89b726[_0xf800('0x30')]];}}logger[_0xf800('0x33')]('[%s][voiceCallReport][hangup]\x20sending\x20hangup\x20event:',_0x89b726[_0xf800('0x30')],util[_0xf800('0x2a')](_0x4f1755[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]],{'showHidden':![],'depth':null}));ami[_0xf800('0x3c')](_0xf800('0xa2'),_0x4f1755['channels'][_0x89b726[_0xf800('0x30')]]);delete _0x4f1755[_0xf800('0x14')][_0x89b726[_0xf800('0x30')]];});}}}catch(_0x3461c6){logger[_0xf800('0x28')]('[%s][voiceCallReport][hangup]',_0x89b726[_0xf800('0x30')],util[_0xf800('0x2a')](_0x3461c6,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')][_0xf800('0x21')]=function(_0x343495){try{if(this[_0xf800('0x2e')](_0x343495)){logger[_0xf800('0x25')](_0xf800('0xa3'),_0x343495[_0xf800('0x30')],_0x343495[_0xf800('0xa4')],_0x343495[_0xf800('0xa5')]);logger[_0xf800('0x33')](_0xf800('0xa6'),_0x343495[_0xf800('0x30')],util[_0xf800('0x2a')](_0x343495,{'showHidden':![],'depth':null}));var _0x187807;if(this[_0xf800('0x14')][_0x343495[_0xf800('0xa7')]]){this[_0xf800('0x14')][_0x343495[_0xf800('0xa7')]][_0xf800('0xa8')]=_0x343495[_0xf800('0xa4')];this[_0xf800('0x14')][_0x343495[_0xf800('0xa7')]][_0xf800('0xa9')]=_0x343495[_0xf800('0xa5')];if(this[_0xf800('0x14')][_0x343495['secondtransfereruniqueid']]){_0x187807=this[_0xf800('0x14')][_0x343495[_0xf800('0xaa')]];this[_0xf800('0x14')][_0x343495['secondtransfereruniqueid']]=this['channels'][_0x343495[_0xf800('0xa7')]];this[_0xf800('0x14')][_0x343495['transfereeuniqueid']]=_0x187807;}}else if(this[_0xf800('0x14')][_0x343495['transfertargetuniqueid']]){this[_0xf800('0x14')][_0x343495[_0xf800('0xab')]][_0xf800('0xa8')]=_0x343495[_0xf800('0xa4')];this[_0xf800('0x14')][_0x343495[_0xf800('0xab')]][_0xf800('0xa9')]=_0x343495[_0xf800('0xa5')];if(this[_0xf800('0x14')][_0x343495[_0xf800('0xac')]]){_0x187807=this['channels'][_0x343495[_0xf800('0xac')]];this[_0xf800('0x14')][_0x343495[_0xf800('0xac')]]=this['channels'][_0x343495[_0xf800('0xab')]];this[_0xf800('0x14')][_0x343495['transfertargetuniqueid']]=_0x187807;}}if((this[_0xf800('0x14')][_0x343495[_0xf800('0xac')]]||this[_0xf800('0x14')][_0x343495[_0xf800('0xad')]])&&this['channels'][_0x343495[_0xf800('0xaa')]]){var _0xa63c39=_['some']([this[_0xf800('0x14')][_0x343495[_0xf800('0xac')]],this[_0xf800('0x14')][_0x343495[_0xf800('0xad')]],this[_0xf800('0x14')][_0x343495[_0xf800('0xaa')]]],function(_0x31015c){return _0x31015c&&_0x31015c[_0xf800('0xae')]===_0xf800('0xa1')&&_0x31015c['routeid'];});if(_0xa63c39){if(this[_0xf800('0x14')][_0x343495['origtransfereruniqueid']])this['channels'][_0x343495[_0xf800('0xac')]][_0xf800('0x95')]='ATTENDED';if(this[_0xf800('0x14')][_0x343495[_0xf800('0xad')]])this[_0xf800('0x14')][_0x343495['origtransfererlinkedid']]['transferType']='ATTENDED';this[_0xf800('0x14')][_0x343495[_0xf800('0xaa')]][_0xf800('0x95')]=_0xf800('0xaf');}}}}catch(_0x1e2836){logger['error']('[%s][voiceCallReport][attendedtransfer]',_0x343495[_0xf800('0x30')],util[_0xf800('0x2a')](_0x1e2836,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')][_0xf800('0xb0')]=function(_0x5e0444){try{if(this[_0xf800('0x2e')](_0x5e0444)){logger[_0xf800('0x25')]('[%s][voiceCallReport][blindtransfer]\x20transfercalleridnum:%s\x20transferconnectedlinenum:%s',_0x5e0444[_0xf800('0x30')],_0x5e0444[_0xf800('0xb1')],_0x5e0444['extension']);logger[_0xf800('0x33')](_0xf800('0xb2'),_0x5e0444[_0xf800('0x30')],util[_0xf800('0x2a')](_0x5e0444,{'showHidden':![],'depth':null}));if(this[_0xf800('0x14')][_0x5e0444[_0xf800('0xa7')]]){this[_0xf800('0x14')][_0x5e0444[_0xf800('0xa7')]][_0xf800('0xa8')]=_0x5e0444[_0xf800('0xb1')];this[_0xf800('0x14')][_0x5e0444[_0xf800('0xa7')]][_0xf800('0xa9')]=_0x5e0444[_0xf800('0xb3')];this[_0xf800('0x14')][_0x5e0444[_0xf800('0xa7')]][_0xf800('0x95')]=_0xf800('0xb4');this[_0xf800('0x1e')]({'event':'BlindTransfer','uniqueid':_0x5e0444[_0xf800('0xa7')],'context':_0x5e0444['context'],'channel':_0x5e0444['transfererchannel']});}else{this[_0xf800('0x14')][_0x5e0444[_0xf800('0xb5')]]['transferType']=_0xf800('0xb4');}}}catch(_0x23b44c){logger['error'](_0xf800('0xb6'),_0x5e0444[_0xf800('0x30')],util[_0xf800('0x2a')](_0x23b44c,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')]['syncMusicOnHoldStart']=function(_0x24cec3){try{if(this[_0xf800('0x2e')](_0x24cec3)){logger[_0xf800('0x33')](_0xf800('0xb7'),_0x24cec3[_0xf800('0x30')],util[_0xf800('0x2a')](_0x24cec3,{'showHidden':![],'depth':null}));if(this['channels'][_0x24cec3[_0xf800('0x30')]]){if(!_[_0xf800('0xb8')](this[_0xf800('0x14')][_0x24cec3[_0xf800('0x30')]][_0xf800('0x8d')])){this['channels'][_0x24cec3[_0xf800('0x30')]]['mohstarttime']=moment()[_0xf800('0x3d')](_0xf800('0x47'));logger[_0xf800('0x25')](_0xf800('0xb9'),_0x24cec3[_0xf800('0x30')],this['channels'][_0x24cec3[_0xf800('0x30')]][_0xf800('0xba')]);}}}}catch(_0x1062e6){logger[_0xf800('0x28')](_0xf800('0xbb'),_0x24cec3[_0xf800('0x30')],util[_0xf800('0x2a')](_0x1062e6,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0xf800('0x2b')]['syncMusicOnHoldStop']=function(_0x2675a8){try{if(this[_0xf800('0x2e')](_0x2675a8)){logger['debug']('[%s][voiceCallReport][musiconholdstop]\x20event:',_0x2675a8[_0xf800('0x30')],util[_0xf800('0x2a')](_0x2675a8,{'showHidden':![],'depth':null}));if(this[_0xf800('0x14')][_0x2675a8[_0xf800('0x30')]]){if(!_[_0xf800('0xb8')](this[_0xf800('0x14')][_0x2675a8[_0xf800('0x30')]][_0xf800('0xba')])){this[_0xf800('0x14')][_0x2675a8['uniqueid']]['mohtime']+=moment()['milliseconds'](0x0)[_0xf800('0x5f')](this[_0xf800('0x14')][_0x2675a8[_0xf800('0x30')]][_0xf800('0xba')],_0xf800('0x57'));logger[_0xf800('0x25')](_0xf800('0xbc'),_0x2675a8[_0xf800('0x30')],this[_0xf800('0x14')][_0x2675a8[_0xf800('0x30')]][_0xf800('0xbd')]);delete this[_0xf800('0x14')][_0x2675a8[_0xf800('0x30')]][_0xf800('0xba')];}}}}catch(_0x1bbedf){logger[_0xf800('0x28')](_0xf800('0xbe'),_0x2675a8[_0xf800('0x30')],util[_0xf800('0x2a')](_0x1bbedf,{'showHidden':![],'depth':null}));}};module['exports']=VoiceCallReport;
\ No newline at end of file