Built motion from commit 5b761a7b.|2.5.36
[motion2.git] / server / services / ami / report / voiceCallReport.js
index 48768f0..54f3dd5 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x8375=['ioredis','../../../config/environment','ami','../ami','unknown','not_inuse','inuse','busy','unavailable','ringing','ringinuse','onhold','set','queue','agi','dial','playback','NO\x20ANSWER','FAILED','ANSWERED','redis','localhost','socket.io-emitter','channels','agents','coreshowchannel','syncNewExten','bind','newchannel','syncNewChannel','newstate','syncNewState','varset','syncVarSet','hangup','syncHangup','syncNewCallerId','attendedtransfer','blindtransfer','musiconholdstart','musiconholdstop','syncMusicOnHoldStop','resolve','actionCoreShowChannels','catch','log','prototype','isNotNull','isUndefined','emit','uniqueid','linkedid','pick','keys','error','[syncNewCallerId][VoiceCallReport]','OutgoingSpoolFailed','YYYY-MM-DD\x20HH:mm:ss','disposition','toNumber','merge','from-sip','channel','split','destconnectedlinenum','exten','user:%s','name','accountcode','[syncNewChannel][VoiceCallReport]','inspect','application','applicationdata','appdata','toLowerCase','starttime','duration','subtract','seconds','format','includes','lastapplication','lastdata','startsWith','cdr(','match','[syncNewExten][VoiceCallReport]','channelstate','answered','answertime','diff','xcally-motion-preview','connectedlinenum','calleridnum','connectedlinename','UserId','membername','[syncNewState][VoiceCallReport]','syncMixMonitorFilename','monitor','endsWith','replace','.wav49','.WAV','monitorFilename','find','monitors','isNil','variable','mixmonitor_filename','value','xmd-phone','xmd-callerid','callerid','type','xmd-queue','originatecalleridnum','xmd-destination','destination','xmd-callerid-preview','calleridpreview','sipcalluniqueid','parse','sipcallid','sipcalllinkedid','[syncVarSet][VoiceCallReport]','billableseconds','context','omit','user:agentcomplete','custom:voiceCallReport','[syncHangup][VoiceCallReport]','syncAttendedTransfer','transfereeuniqueid','origtransferercalleridnum','secondtransfereruniqueid','transfertargetuniqueid','transfercalleridnum','transferconnectedlinenum','transfertargetcalleridnum','origtransfereruniqueid','[syncAttendedTransfer][VoiceCallReport]','syncBlindTransfer','transfereecalleridnum','extension','BlindTransfer','transfererchannel','syncMusicOnHoldStart','mohstarttime','milliseconds','exports','lodash','moment','util','path'];(function(_0x2aef18,_0x48832f){var _0x32af9b=function(_0x2ccd81){while(--_0x2ccd81){_0x2aef18['push'](_0x2aef18['shift']());}};_0x32af9b(++_0x48832f);}(_0x8375,0x132));var _0x5837=function(_0x5ad34e,_0x2c9e6d){_0x5ad34e=_0x5ad34e-0x0;var _0x5d921f=_0x8375[_0x5ad34e];return _0x5d921f;};'use strict';var BPromise=require('bluebird');var _=require(_0x5837('0x0'));var moment=require(_0x5837('0x1'));var util=require(_0x5837('0x2'));var path=require(_0x5837('0x3'));var Redis=require(_0x5837('0x4'));var config=require(_0x5837('0x5'));var logger=require('../../../config/logger')(_0x5837('0x6'));var ami=require(_0x5837('0x7'));var Channel=require('../model/channel');var statusDesc=[_0x5837('0x8'),_0x5837('0x9'),_0x5837('0xa'),_0x5837('0xb'),'invalid',_0x5837('0xc'),_0x5837('0xd'),_0x5837('0xe'),_0x5837('0xf')];var applications=[_0x5837('0x10'),_0x5837('0x11'),_0x5837('0x12'),_0x5837('0x13'),_0x5837('0x14'),'voicemail'];var dispositions=[_0x5837('0x15'),_0x5837('0x16'),'FAILED',_0x5837('0x15'),_0x5837('0x15'),'NO\x20ANSWER',_0x5837('0x17'),'BUSY',_0x5837('0x16'),_0x5837('0x16'),_0x5837('0x16')];var actions={};config[_0x5837('0x18')]=_['defaults'](config[_0x5837('0x18')],{'host':_0x5837('0x19'),'port':0x18eb});var io=require(_0x5837('0x1a'))(new Redis(config['redis']));function VoiceCallReport(_0x292949){this[_0x5837('0x1b')]=_0x292949[_0x5837('0x1b')];this[_0x5837('0x1c')]=_0x292949[_0x5837('0x1c')];ami['on'](_0x5837('0x1d'),this['syncNewExten']['bind'](this));ami['on']('newexten',this[_0x5837('0x1e')][_0x5837('0x1f')](this));ami['on'](_0x5837('0x20'),this[_0x5837('0x21')][_0x5837('0x1f')](this));ami['on'](_0x5837('0x22'),this[_0x5837('0x23')]['bind'](this));ami['on'](_0x5837('0x24'),this[_0x5837('0x25')][_0x5837('0x1f')](this));ami['on'](_0x5837('0x26'),this[_0x5837('0x27')]['bind'](this));ami['on']('newcallerid',this[_0x5837('0x28')][_0x5837('0x1f')](this));ami['on'](_0x5837('0x29'),this['syncAttendedTransfer'][_0x5837('0x1f')](this));ami['on'](_0x5837('0x2a'),this['syncBlindTransfer'][_0x5837('0x1f')](this));ami['on'](_0x5837('0x2b'),this['syncMusicOnHoldStart'][_0x5837('0x1f')](this));ami['on'](_0x5837('0x2c'),this[_0x5837('0x2d')]['bind'](this));return BPromise[_0x5837('0x2e')]()['then'](ami[_0x5837('0x2f')]())[_0x5837('0x30')](function(_0x31d25b){console[_0x5837('0x31')](_0x31d25b);});}VoiceCallReport[_0x5837('0x32')][_0x5837('0x33')]=function(_0x22564a){return _0x22564a!==null&&!_[_0x5837('0x34')](_0x22564a);};VoiceCallReport[_0x5837('0x32')][_0x5837('0x35')]=function(_0x24b941,_0x27848d,_0x16d1ad){io['to'](_0x24b941)[_0x5837('0x35')](_0x27848d,_0x16d1ad);};VoiceCallReport[_0x5837('0x32')]['syncNewCallerId']=function(_0x321c49){try{if(this[_0x5837('0x33')](_0x321c49)){if(_0x321c49[_0x5837('0x36')]===_0x321c49[_0x5837('0x37')]){if(!_[_0x5837('0x34')](this[_0x5837('0x1b')][_0x321c49[_0x5837('0x36')]])){_['merge'](this[_0x5837('0x1b')][_0x321c49[_0x5837('0x36')]],_[_0x5837('0x38')](_0x321c49,_[_0x5837('0x39')](this['channels'][_0x321c49['uniqueid']])));}}}}catch(_0x42d16c){logger[_0x5837('0x3a')](_0x5837('0x3b'),util['inspect'](_0x42d16c,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x21')]=function(_0x33b918){try{if(this[_0x5837('0x33')](_0x33b918)){if(_0x33b918[_0x5837('0x36')]===_0x33b918[_0x5837('0x37')]&&_0x33b918['channel']!=_0x5837('0x3c')){if(_[_0x5837('0x34')](this['channels'][_0x33b918[_0x5837('0x36')]])){this[_0x5837('0x1b')][_0x33b918[_0x5837('0x36')]]=new Channel();this['channels'][_0x33b918['uniqueid']]['starttime']=moment()['format'](_0x5837('0x3d'));this['channels'][_0x33b918['uniqueid']][_0x5837('0x3e')]=dispositions[_[_0x5837('0x3f')](_0x33b918['channelstate'])];_[_0x5837('0x40')](this['channels'][_0x33b918[_0x5837('0x36')]],_[_0x5837('0x38')](_0x33b918,_['keys'](this[_0x5837('0x1b')][_0x33b918[_0x5837('0x36')]])));if(_0x33b918['context']===_0x5837('0x41')){if(this['agents'][_0x33b918[_0x5837('0x42')]['split']('-')[0x0]]){this['agents'][_0x33b918[_0x5837('0x42')][_0x5837('0x43')]('-')[0x0]][_0x5837('0x44')]=_0x33b918[_0x5837('0x45')];this[_0x5837('0x35')](util['format'](_0x5837('0x46'),this['agents'][_0x33b918['channel'][_0x5837('0x43')]('-')[0x0]][_0x5837('0x47')]),'user:agentconnect',{'destaccountcode':this[_0x5837('0x1c')][_0x33b918[_0x5837('0x42')][_0x5837('0x43')]('-')[0x0]][_0x5837('0x48')],'destconnectedlinenum':_0x33b918[_0x5837('0x45')]});}}}}}}catch(_0x40b390){logger[_0x5837('0x3a')](_0x5837('0x49'),util[_0x5837('0x4a')](_0x40b390,{'showHidden':![],'depth':null}));}};VoiceCallReport['prototype'][_0x5837('0x1e')]=function(_0x537aa6){try{if(this['isNotNull'](_0x537aa6)){if(_0x537aa6[_0x5837('0x36')]===_0x537aa6[_0x5837('0x37')]&&_0x537aa6['exten']!='h'&&_0x537aa6[_0x5837('0x42')]!=_0x5837('0x3c')){_0x537aa6[_0x5837('0x4b')]=_0x537aa6[_0x5837('0x4b')]['toLowerCase']();_0x537aa6[_0x5837('0x4c')]=(_0x537aa6[_0x5837('0x4d')]||_0x537aa6[_0x5837('0x4c')])[_0x5837('0x4e')]();if(_[_0x5837('0x34')](this['channels'][_0x537aa6[_0x5837('0x36')]])){this[_0x5837('0x1b')][_0x537aa6[_0x5837('0x36')]]=new Channel();this['channels'][_0x537aa6[_0x5837('0x36')]][_0x5837('0x4f')]=_0x537aa6[_0x5837('0x50')]?moment()[_0x5837('0x51')](moment[_0x5837('0x50')](_0x537aa6[_0x5837('0x50')])[_0x5837('0x52')](),_0x5837('0x52'))[_0x5837('0x53')](_0x5837('0x3d')):moment()[_0x5837('0x53')]('YYYY-MM-DD\x20HH:mm:ss');this[_0x5837('0x1b')][_0x537aa6[_0x5837('0x36')]]['disposition']='NO\x20ANSWER';}_[_0x5837('0x40')](this['channels'][_0x537aa6[_0x5837('0x36')]],_[_0x5837('0x38')](_0x537aa6,_[_0x5837('0x39')](this[_0x5837('0x1b')][_0x537aa6['uniqueid']])));if(_[_0x5837('0x54')](applications,_0x537aa6[_0x5837('0x4b')])){this[_0x5837('0x1b')][_0x537aa6[_0x5837('0x36')]][_0x5837('0x55')]=_0x537aa6[_0x5837('0x4b')];this[_0x5837('0x1b')][_0x537aa6[_0x5837('0x36')]][_0x5837('0x56')]=_0x537aa6['applicationdata'];if(_0x537aa6[_0x5837('0x4b')]===_0x5837('0x10')&&_[_0x5837('0x57')](_0x537aa6[_0x5837('0x4c')],_0x5837('0x58'))){var _0x30a9fc=_0x537aa6['applicationdata'][_0x5837('0x43')]('=');var _0x3d88df=_0x30a9fc[0x0][_0x5837('0x59')](/cdr\((.*)\)/);if(_0x3d88df){this[_0x5837('0x1b')][_0x537aa6[_0x5837('0x36')]][_0x3d88df[0x1]]=_0x30a9fc[0x1];}}else if(_0x537aa6['application']===_0x5837('0x11')){this['channels'][_0x537aa6[_0x5837('0x36')]][_0x5837('0x11')]=_0x537aa6[_0x5837('0x4c')]['split'](',')[0x0];}}}}}catch(_0x14cad6){logger[_0x5837('0x3a')](_0x5837('0x5a'),util[_0x5837('0x4a')](_0x14cad6,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x23')]=function(_0x41604b){try{if(this[_0x5837('0x33')](_0x41604b)){if(_0x41604b[_0x5837('0x36')]!==_0x41604b['linkedid']){if(this['channels'][_0x41604b[_0x5837('0x37')]]){if(_0x41604b[_0x5837('0x5b')]==='6'){if(!this['channels'][_0x41604b['linkedid']][_0x5837('0x5c')]){var _0x3e8006=moment();this[_0x5837('0x1b')][_0x41604b[_0x5837('0x37')]][_0x5837('0x5c')]=!![];this['channels'][_0x41604b[_0x5837('0x37')]][_0x5837('0x5d')]=_0x3e8006[_0x5837('0x53')]('YYYY-MM-DD\x20HH:mm:ss');if(this['channels'][_0x41604b[_0x5837('0x37')]][_0x5837('0x4f')]){this[_0x5837('0x1b')][_0x41604b[_0x5837('0x37')]]['holdtime']=_0x3e8006[_0x5837('0x5e')](this['channels'][_0x41604b['linkedid']][_0x5837('0x4f')],_0x5837('0x52'));}}this['channels'][_0x41604b[_0x5837('0x37')]][_0x5837('0x37')]=_0x41604b[_0x5837('0x36')];if(_0x41604b['calleridnum']!==_0x5837('0x5f')){this[_0x5837('0x1b')][_0x41604b[_0x5837('0x37')]][_0x5837('0x60')]=_0x41604b[_0x5837('0x61')];}this['channels'][_0x41604b[_0x5837('0x37')]][_0x5837('0x62')]=_0x41604b['calleridname'];this[_0x5837('0x1b')][_0x41604b[_0x5837('0x37')]]['destinationchannel']=_0x41604b[_0x5837('0x42')];this['channels'][_0x41604b[_0x5837('0x37')]][_0x5837('0x3e')]=dispositions[_['toNumber'](_0x41604b['channelstate'])];if(this[_0x5837('0x1c')][_0x41604b[_0x5837('0x42')]['split']('-')[0x0]]){this['channels'][_0x41604b['linkedid']][_0x5837('0x63')]=this[_0x5837('0x1c')][_0x41604b[_0x5837('0x42')][_0x5837('0x43')]('-')[0x0]]['id'];this[_0x5837('0x1b')][_0x41604b['linkedid']][_0x5837('0x64')]=this[_0x5837('0x1c')][_0x41604b[_0x5837('0x42')][_0x5837('0x43')]('-')[0x0]][_0x5837('0x47')];}}}}else{if(this['channels'][_0x41604b[_0x5837('0x36')]]){if(_0x41604b['channelstate']==='6'){if(this[_0x5837('0x1c')][_0x41604b[_0x5837('0x42')]['split']('-')[0x0]]){this[_0x5837('0x1b')][_0x41604b[_0x5837('0x36')]][_0x5837('0x63')]=this[_0x5837('0x1c')][_0x41604b[_0x5837('0x42')]['split']('-')[0x0]]['id'];this[_0x5837('0x1b')][_0x41604b[_0x5837('0x36')]][_0x5837('0x64')]=this[_0x5837('0x1c')][_0x41604b['channel']['split']('-')[0x0]]['name'];}}}}}}catch(_0x2bc195){logger['error'](_0x5837('0x65'),util[_0x5837('0x4a')](_0x2bc195,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x66')]=function(_0x5ab004,_0x4d9912){if(this[_0x5837('0x1b')][_0x5ab004]){this['channels'][_0x5ab004][_0x5837('0x67')]=!![];if(_[_0x5837('0x68')](_0x4d9912,'.wav49')){_0x4d9912=_0x4d9912[_0x5837('0x69')](_0x5837('0x6a'),_0x5837('0x6b'));}this[_0x5837('0x1b')][_0x5ab004][_0x5837('0x6c')]=_0x4d9912;var _0x44ab5b=_[_0x5837('0x6d')](this['channels'][_0x5ab004][_0x5837('0x6e')],{'filename':_0x4d9912});if(_[_0x5837('0x6f')](_0x44ab5b)){this[_0x5837('0x1b')][_0x5ab004][_0x5837('0x6e')]['push']({'filename':_0x4d9912,'createdAt':moment()['format'](_0x5837('0x3d')),'mixmonitorid':'','status':'rec'});}}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x25')]=function(_0x3ff148){try{if(this[_0x5837('0x33')](_0x3ff148)){if(this[_0x5837('0x1b')][_0x3ff148['uniqueid']]&&_0x3ff148[_0x5837('0x42')]!=_0x5837('0x3c')){if(this[_0x5837('0x33')](_0x3ff148['variable'])){if(this['isNotNull'](_0x3ff148[_0x5837('0x70')][_0x5837('0x71')])){this[_0x5837('0x66')](_0x3ff148[_0x5837('0x36')],_0x3ff148[_0x5837('0x72')]);}else if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')][_0x5837('0x73')])){this[_0x5837('0x1b')][_0x3ff148['uniqueid']][_0x5837('0x61')]=_0x3ff148[_0x5837('0x72')];}else if(this['isNotNull'](_0x3ff148['variable'][_0x5837('0x74')])){this['channels'][_0x3ff148['uniqueid']][_0x5837('0x75')]=_0x3ff148[_0x5837('0x72')];}else if(this['isNotNull'](_0x3ff148[_0x5837('0x70')]['xmd-cdrtype'])){this[_0x5837('0x1b')][_0x3ff148[_0x5837('0x36')]][_0x5837('0x76')]=_0x3ff148[_0x5837('0x72')];}else if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')][_0x5837('0x77')])){this[_0x5837('0x1b')][_0x3ff148[_0x5837('0x36')]][_0x5837('0x11')]=_0x3ff148[_0x5837('0x72')][_0x5837('0x43')](',')[0x0];}else if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')]['xmd-originatecalleridnum'])){this[_0x5837('0x1b')][_0x3ff148[_0x5837('0x36')]][_0x5837('0x78')]=_0x3ff148[_0x5837('0x72')];}else if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')][_0x5837('0x79')])){this['channels'][_0x3ff148[_0x5837('0x36')]][_0x5837('0x7a')]=_0x3ff148[_0x5837('0x72')];}else if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')][_0x5837('0x7b')])){this[_0x5837('0x1b')][_0x3ff148[_0x5837('0x36')]][_0x5837('0x7c')]=_0x3ff148['value'];}else if(this['isNotNull'](_0x3ff148[_0x5837('0x70')]['xmcs-queue'])){this['channels'][_0x3ff148[_0x5837('0x36')]][_0x5837('0x11')]=_0x3ff148[_0x5837('0x72')];}else if(this[_0x5837('0x33')](_0x3ff148['variable']['sipcallid'])){this[_0x5837('0x1b')][_0x3ff148[_0x5837('0x36')]][_0x5837('0x7d')]=_0x3ff148[_0x5837('0x72')];}}}else if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')][_0x5837('0x71')])){if(_0x3ff148[_0x5837('0x72')]){var _0xab6c07=path[_0x5837('0x7e')](_0x3ff148['value'])[_0x5837('0x47')];this['syncMixMonitorFilename'](_0xab6c07,_0x3ff148['value']);}}else if(this[_0x5837('0x1b')][_0x3ff148[_0x5837('0x37')]]){if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')])){if(this[_0x5837('0x33')](_0x3ff148[_0x5837('0x70')][_0x5837('0x7f')])){this['channels'][_0x3ff148[_0x5837('0x37')]][_0x5837('0x80')]=_0x3ff148[_0x5837('0x72')];}}}}}catch(_0x126a77){logger[_0x5837('0x3a')](_0x5837('0x81'),util[_0x5837('0x4a')](_0x126a77,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')]['syncHangup']=function(_0x2e93ce){try{if(this[_0x5837('0x33')](_0x2e93ce)){if(this['channels'][_0x2e93ce[_0x5837('0x36')]]){var _0x4d52f3=moment();this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]]['endtime']=_0x4d52f3[_0x5837('0x53')]('YYYY-MM-DD\x20HH:mm:ss');this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]][_0x5837('0x50')]=_0x4d52f3[_0x5837('0x5e')](this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]][_0x5837('0x4f')],'seconds');if(this['channels'][_0x2e93ce['uniqueid']][_0x5837('0x5c')]){this['channels'][_0x2e93ce['uniqueid']][_0x5837('0x82')]=_0x4d52f3[_0x5837('0x5e')](this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]]['answertime'],_0x5837('0x52'));this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]]['holdtime']=this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]]['duration']-this['channels'][_0x2e93ce[_0x5837('0x36')]][_0x5837('0x82')];}if(_0x2e93ce[_0x5837('0x83')]==='from-sip'){if(this[_0x5837('0x1c')][_0x2e93ce['channel'][_0x5837('0x43')]('-')[0x0]]){this[_0x5837('0x1c')][_0x2e93ce[_0x5837('0x42')]['split']('-')[0x0]]=_[_0x5837('0x84')](this[_0x5837('0x1c')][_0x2e93ce['channel'][_0x5837('0x43')]('-')[0x0]],[_0x5837('0x44')]);this[_0x5837('0x35')](util['format'](_0x5837('0x46'),this[_0x5837('0x1c')][_0x2e93ce[_0x5837('0x42')]['split']('-')[0x0]][_0x5837('0x47')]),_0x5837('0x85'),{'destaccountcode':this[_0x5837('0x1c')][_0x2e93ce[_0x5837('0x42')][_0x5837('0x43')]('-')[0x0]][_0x5837('0x48')]});}}ami['emit'](_0x5837('0x86'),this['channels'][_0x2e93ce[_0x5837('0x36')]]);delete this[_0x5837('0x1b')][_0x2e93ce[_0x5837('0x36')]];}}}catch(_0x1859bc){logger[_0x5837('0x3a')](_0x5837('0x87'),util[_0x5837('0x4a')](_0x1859bc,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x88')]=function(_0x49ced8){try{if(this['isNotNull'](_0x49ced8)){if(this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x89')]]){this[_0x5837('0x1b')][_0x49ced8['transfereeuniqueid']]['transfercalleridnum']=_0x49ced8[_0x5837('0x8a')];this[_0x5837('0x1b')][_0x49ced8['transfereeuniqueid']]['transferconnectedlinenum']=_0x49ced8['transfertargetcalleridnum'];if(this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x8b')]]){var _0x5d1718=this['channels'][_0x49ced8['secondtransfereruniqueid']];this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x8b')]]=this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x89')]];this[_0x5837('0x1b')][_0x49ced8['transfereeuniqueid']]=_0x5d1718;}}else if(this[_0x5837('0x1b')][_0x49ced8['transfertargetuniqueid']]){this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x8c')]][_0x5837('0x8d')]=_0x49ced8[_0x5837('0x8a')];this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x8c')]][_0x5837('0x8e')]=_0x49ced8[_0x5837('0x8f')];if(this['channels'][_0x49ced8[_0x5837('0x90')]]){var _0x5d1718=this['channels'][_0x49ced8[_0x5837('0x90')]];this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x90')]]=this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x8c')]];this[_0x5837('0x1b')][_0x49ced8[_0x5837('0x8c')]]=_0x5d1718;}}}}catch(_0x46c927){logger[_0x5837('0x3a')](_0x5837('0x91'),util[_0x5837('0x4a')](_0x46c927,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x92')]=function(_0x5efe1f){try{if(this[_0x5837('0x33')](_0x5efe1f)){if(this[_0x5837('0x1b')][_0x5efe1f[_0x5837('0x89')]]){this[_0x5837('0x1b')][_0x5efe1f[_0x5837('0x89')]]['transfercalleridnum']=_0x5efe1f[_0x5837('0x93')];this[_0x5837('0x1b')][_0x5efe1f['transfereeuniqueid']][_0x5837('0x8e')]=_0x5efe1f[_0x5837('0x94')];this[_0x5837('0x27')]({'event':_0x5837('0x95'),'uniqueid':_0x5efe1f['transfereeuniqueid'],'context':_0x5efe1f[_0x5837('0x83')],'channel':_0x5efe1f[_0x5837('0x96')]});}}}catch(_0x58ca10){logger['error']('[syncBlindTransfer][VoiceCallReport]',util['inspect'](_0x58ca10,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x97')]=function(_0x3e5e9d){try{if(this['isNotNull'](_0x3e5e9d)){if(this[_0x5837('0x1b')][_0x3e5e9d[_0x5837('0x36')]]){if(!_['isNil'](this[_0x5837('0x1b')][_0x3e5e9d[_0x5837('0x36')]][_0x5837('0x5d')])){this[_0x5837('0x1b')][_0x3e5e9d[_0x5837('0x36')]]['mohstarttime']=moment()[_0x5837('0x53')](_0x5837('0x3d'));}}}}catch(_0xa9a8d8){logger['error']('[syncMusicOnHoldStart][VoiceCallReport]',util[_0x5837('0x4a')](_0xa9a8d8,{'showHidden':![],'depth':null}));}};VoiceCallReport[_0x5837('0x32')][_0x5837('0x2d')]=function(_0x3ef46f){try{if(this[_0x5837('0x33')](_0x3ef46f)){if(this['channels'][_0x3ef46f['uniqueid']]){if(!_[_0x5837('0x6f')](this[_0x5837('0x1b')][_0x3ef46f[_0x5837('0x36')]][_0x5837('0x98')])){this[_0x5837('0x1b')][_0x3ef46f[_0x5837('0x36')]]['mohtime']+=moment()[_0x5837('0x99')](0x0)[_0x5837('0x5e')](this[_0x5837('0x1b')][_0x3ef46f[_0x5837('0x36')]]['mohstarttime'],'seconds');delete this[_0x5837('0x1b')][_0x3ef46f[_0x5837('0x36')]]['mohstarttime'];}}}}catch(_0xdc6571){logger['error']('[syncMusicOnHoldStop][VoiceCallReport]',util[_0x5837('0x4a')](_0xdc6571,{'showHidden':![],'depth':null}));}};module[_0x5837('0x9a')]=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