Built motion from commit e1760111.|2.6.18
[motion2.git] / server / services / xdr / recordings.controller.js
index 5406f81..203f6d1 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xd7f5=['[%s][recordings][varset]\x20variable:%s\x20value:%s','value','endsWith','.wav49','replace','.WAV','find','[%s][recordings][hangup]','[%s][recordings][hangup]\x20calleridnum:%s\x20calleridname:%s\x20reason:%s','calleridnum','calleridname','cause-txt','connectedlinenum','connectedlinename','type','monitors','forEach','clone','[%s][recordings][newexten]','application','appdata','toLowerCase','set','startsWith','cdr','split','substring','lastIndexOf','queuecallerjoin','[%s][recordings][queuecallerjoin]','queue','blindtransfer','[%s][recordings][blindtransfer]','[%s][recordings][blindtransfer]\x20transferercalleridnum:%s\x20transferercalleridname:%s\x20transfereecalleridnum:%s\x20transfereecalleridname:%s','transferercalleridname','transfereecalleridnum','transfereruniqueid','recording','lodash','util','./transfers.controller','format','[%s][recordings][writeDB]','uniqueid','transfereeuniqueid','accountcode','getUserByInternal','then','membername','name','UserId','request','CreateVoiceRecording','blinds','newchannel','debug','[%s][recordings][newchannel]','info','exten','context','error','newstate','[%s][recordings][newstate]','isNil','channelstate','[%s][recordings][newstate]\x20context:%s\x20channel:%s','linkedid','transfer','[%s][recordings][newstate]\x20linkedid:%s\x20context:%s\x20channel:%s','channel','varset','variable','mixmonitor_filename','[%s][recordings][varset]'];(function(_0x50fa87,_0x27927b){var _0x5b1434=function(_0x49d712){while(--_0x49d712){_0x50fa87['push'](_0x50fa87['shift']());}};_0x5b1434(++_0x27927b);}(_0xd7f5,0x70));var _0x5d7f=function(_0x9e575,_0x5894d4){_0x9e575=_0x9e575-0x0;var _0x522277=_0xd7f5[_0x9e575];return _0x522277;};'use strict';var _=require(_0x5d7f('0x0'));var util=require(_0x5d7f('0x1'));var utils=require('./utils');var transfers=require(_0x5d7f('0x2'));var recordings={};function writeDB(_0x202d35){var _0x521e2b;utils['info'](util[_0x5d7f('0x3')](_0x5d7f('0x4'),_0x202d35[_0x5d7f('0x5')]));if(transfers['blinds'][_0x202d35[_0x5d7f('0x5')]]){_0x521e2b=_0x202d35[_0x5d7f('0x5')];_0x202d35['uniqueid']=transfers['blinds'][_0x202d35[_0x5d7f('0x5')]][_0x5d7f('0x6')];}if(_0x202d35[_0x5d7f('0x7')]){utils[_0x5d7f('0x8')](_0x202d35[_0x5d7f('0x7')])[_0x5d7f('0x9')](function(_0x7fbeb4){if(_0x7fbeb4){_0x202d35[_0x5d7f('0xa')]=_0x7fbeb4[_0x5d7f('0xb')];_0x202d35[_0x5d7f('0xc')]=_0x7fbeb4['id'];}utils[_0x5d7f('0xd')](_0x5d7f('0xe'),_0x202d35);});}else{utils[_0x5d7f('0xd')](_0x5d7f('0xe'),_0x202d35);}if(_0x521e2b)delete transfers[_0x5d7f('0xf')][_0x521e2b];}exports[_0x5d7f('0x10')]=function(_0x11d9a7){try{utils[_0x5d7f('0x11')](util[_0x5d7f('0x3')](_0x5d7f('0x12'),_0x11d9a7['uniqueid']),_0x11d9a7);if(_0x11d9a7['uniqueid']==_0x11d9a7['linkedid']){utils[_0x5d7f('0x13')](util['format']('[%s][recordings][newchannel]\x20context:%s\x20exten:%s',_0x11d9a7[_0x5d7f('0x5')],_0x11d9a7['context'],_0x11d9a7[_0x5d7f('0x14')]));recordings[_0x11d9a7[_0x5d7f('0x5')]]={'uniqueid':_0x11d9a7['uniqueid'],'accountcode':_0x11d9a7[_0x5d7f('0x7')],'exten':_0x11d9a7[_0x5d7f('0x14')],'context':_0x11d9a7[_0x5d7f('0x15')],'channel':_0x11d9a7['channel'],'monitors':[]};}}catch(_0x5f20e4){utils[_0x5d7f('0x16')](util[_0x5d7f('0x3')](_0x5d7f('0x12'),_0x11d9a7['uniqueid']),_0x5f20e4);}};exports[_0x5d7f('0x17')]=function(_0x193887){try{utils[_0x5d7f('0x11')](util['format'](_0x5d7f('0x18'),_0x193887[_0x5d7f('0x5')]),_0x193887);if(!_[_0x5d7f('0x19')](recordings[_0x193887[_0x5d7f('0x5')]])&&_0x193887[_0x5d7f('0x1a')]==0x6){utils[_0x5d7f('0x13')](util[_0x5d7f('0x3')](_0x5d7f('0x1b'),_0x193887[_0x5d7f('0x5')],_0x193887[_0x5d7f('0x15')],_0x193887['channel']));}else if(!_[_0x5d7f('0x19')](recordings[_0x193887[_0x5d7f('0x1c')]])&&_0x193887['channelstate']==0x6&&_0x193887[_0x5d7f('0x15')]!=_0x5d7f('0x1d')){utils[_0x5d7f('0x13')](util[_0x5d7f('0x3')](_0x5d7f('0x1e'),_0x193887[_0x5d7f('0x5')],_0x193887['linkedid'],_0x193887['context'],_0x193887[_0x5d7f('0x1f')]));recordings[_0x193887[_0x5d7f('0x1c')]]['accountcode']=_0x193887['accountcode'];}}catch(_0x4b4123){utils[_0x5d7f('0x16')](util[_0x5d7f('0x3')]('[%s][recordings][newstate]',_0x193887[_0x5d7f('0x5')]),_0x4b4123);}};exports[_0x5d7f('0x20')]=function(_0x124db3){try{if(!_[_0x5d7f('0x19')](_0x124db3[_0x5d7f('0x21')])&&!_['isNil'](_0x124db3['variable'][_0x5d7f('0x22')])){utils[_0x5d7f('0x11')](util[_0x5d7f('0x3')](_0x5d7f('0x23'),_0x124db3[_0x5d7f('0x5')]),_0x124db3);utils['info'](util[_0x5d7f('0x3')](_0x5d7f('0x24'),_0x124db3[_0x5d7f('0x5')],_0x124db3[_0x5d7f('0x21')],_0x124db3[_0x5d7f('0x25')]));if(_[_0x5d7f('0x26')](_0x124db3['value'],_0x5d7f('0x27'))){_0x124db3['value']=_0x124db3[_0x5d7f('0x25')][_0x5d7f('0x28')](_0x5d7f('0x27'),_0x5d7f('0x29'));}if(recordings[_0x124db3['linkedid']]){var _0x5bfa6e=_[_0x5d7f('0x2a')](recordings[_0x124db3['linkedid']]['monitors'],{'value':_0x124db3[_0x5d7f('0x25')]});if(_[_0x5d7f('0x19')](_0x5bfa6e)){recordings[_0x124db3[_0x5d7f('0x1c')]]['monitors']['push']({'value':_0x124db3[_0x5d7f('0x25')]});}}}}catch(_0x3aa0c7){utils[_0x5d7f('0x16')](util['format'](_0x5d7f('0x23'),_0x124db3[_0x5d7f('0x5')]),_0x3aa0c7);}};exports['hangup']=function(_0x4c8e59){try{if(!_[_0x5d7f('0x19')](recordings[_0x4c8e59[_0x5d7f('0x5')]])){utils[_0x5d7f('0x11')](util['format'](_0x5d7f('0x2b'),_0x4c8e59['uniqueid']),_0x4c8e59);utils[_0x5d7f('0x13')](util[_0x5d7f('0x3')](_0x5d7f('0x2c'),_0x4c8e59[_0x5d7f('0x5')],_0x4c8e59[_0x5d7f('0x2d')],_0x4c8e59[_0x5d7f('0x2e')],_0x4c8e59[_0x5d7f('0x2f')]));recordings[_0x4c8e59[_0x5d7f('0x5')]]['calleridnum']=_0x4c8e59[_0x5d7f('0x2d')];recordings[_0x4c8e59['uniqueid']][_0x5d7f('0x2e')]=_0x4c8e59[_0x5d7f('0x2e')];recordings[_0x4c8e59[_0x5d7f('0x5')]][_0x5d7f('0x30')]=_0x4c8e59[_0x5d7f('0x30')];recordings[_0x4c8e59[_0x5d7f('0x5')]]['connectedlinename']=_0x4c8e59[_0x5d7f('0x31')];if(recordings[_0x4c8e59[_0x5d7f('0x5')]][_0x5d7f('0x32')]=='outbound'&&recordings[_0x4c8e59[_0x5d7f('0x5')]][_0x5d7f('0x7')]){recordings[_0x4c8e59['uniqueid']][_0x5d7f('0x30')]=recordings[_0x4c8e59[_0x5d7f('0x5')]][_0x5d7f('0x7')];recordings[_0x4c8e59[_0x5d7f('0x5')]]['connectedlinename']='';}recordings[_0x4c8e59[_0x5d7f('0x5')]][_0x5d7f('0x33')][_0x5d7f('0x34')](function(_0x3ef7ad){var _0x3ae99b=_[_0x5d7f('0x35')](recordings[_0x4c8e59[_0x5d7f('0x5')]]);_0x3ae99b[_0x5d7f('0x25')]=_0x3ef7ad[_0x5d7f('0x25')];writeDB(_0x3ae99b);});delete recordings[_0x4c8e59[_0x5d7f('0x5')]];}}catch(_0x248c80){utils[_0x5d7f('0x16')](util[_0x5d7f('0x3')](_0x5d7f('0x2b'),_0x4c8e59['uniqueid']),_0x248c80);}};exports['newexten']=function(_0x5c640d){try{if(!_[_0x5d7f('0x19')](recordings[_0x5c640d[_0x5d7f('0x5')]])){utils[_0x5d7f('0x11')](util[_0x5d7f('0x3')](_0x5d7f('0x36'),_0x5c640d['uniqueid']),_0x5c640d);utils[_0x5d7f('0x13')](util[_0x5d7f('0x3')]('[%s][recordings][newexten]\x20application:%s\x20appdata:%s',_0x5c640d[_0x5d7f('0x5')],_0x5c640d[_0x5d7f('0x37')],_0x5c640d[_0x5d7f('0x38')]));if(_0x5c640d['application'][_0x5d7f('0x39')]()==_0x5d7f('0x3a')&&_[_0x5d7f('0x3b')](_0x5c640d['appdata'][_0x5d7f('0x39')](),_0x5d7f('0x3c'))){var _0x510ab0=_0x5c640d[_0x5d7f('0x38')][_0x5d7f('0x3d')]('=');var _0x237bfe=_0x510ab0[0x0][_0x5d7f('0x3e')](_0x510ab0[0x0][_0x5d7f('0x3f')]('(')+0x1,_0x510ab0[0x0][_0x5d7f('0x3f')](')'));var _0x140a41=_0x510ab0[0x1];recordings[_0x5c640d['uniqueid']][_0x237bfe]=_0x140a41;}}}catch(_0xe5c9cc){utils[_0x5d7f('0x16')](util[_0x5d7f('0x3')]('[%s][recordings][newexten]',_0x5c640d[_0x5d7f('0x5')]),_0xe5c9cc);}};exports[_0x5d7f('0x40')]=function(_0x35f144){try{if(!_[_0x5d7f('0x19')](recordings[_0x35f144['uniqueid']])){utils['debug'](util[_0x5d7f('0x3')](_0x5d7f('0x41'),_0x35f144[_0x5d7f('0x5')]),_0x35f144);utils['info'](util['format']('[%s][recordings][queuecallerjoin]\x20queue:%s',_0x35f144[_0x5d7f('0x5')],_0x35f144[_0x5d7f('0x42')]));recordings[_0x35f144[_0x5d7f('0x5')]][_0x5d7f('0x42')]=_0x35f144[_0x5d7f('0x42')];}}catch(_0x384252){utils[_0x5d7f('0x16')](util['format'](_0x5d7f('0x41'),_0x35f144[_0x5d7f('0x5')]),_0x384252);}};exports[_0x5d7f('0x43')]=function(_0x3df48a){try{utils[_0x5d7f('0x11')](util[_0x5d7f('0x3')](_0x5d7f('0x44'),_0x3df48a[_0x5d7f('0x5')]),_0x3df48a);utils[_0x5d7f('0x13')](util[_0x5d7f('0x3')](_0x5d7f('0x45'),_0x3df48a[_0x5d7f('0x5')],_0x3df48a['transferercalleridnum'],_0x3df48a[_0x5d7f('0x46')],_0x3df48a[_0x5d7f('0x47')],_0x3df48a['transfereecalleridname']));if(recordings[_0x3df48a[_0x5d7f('0x48')]]&&transfers[_0x5d7f('0xf')][_0x3df48a[_0x5d7f('0x48')]]){transfers[_0x5d7f('0xf')][_0x3df48a[_0x5d7f('0x48')]][_0x5d7f('0x49')]=!![];}}catch(_0x32aaaf){utils[_0x5d7f('0x16')](util[_0x5d7f('0x3')](_0x5d7f('0x44'),_0x3df48a[_0x5d7f('0x5')]),_0x32aaaf);}};
\ No newline at end of file
+var _0xf11a=['forEach','clone','newexten','[%s][recordings][newexten]\x20application:%s\x20appdata:%s','application','appdata','toLowerCase','set','cdr','substring','lastIndexOf','[%s][recordings][newexten]','[%s][recordings][queuecallerjoin]\x20queue:%s','queue','[%s][recordings][queuecallerjoin]','lodash','util','./utils','info','format','[%s][recordings][writeDB]','uniqueid','accountcode','membername','name','UserId','CreateVoiceRecording','request','newchannel','debug','[%s][recordings][newchannel]','linkedid','[%s][recordings][newchannel]\x20context:%s\x20exten:%s','exten','context','newstate','[%s][recordings][newstate]','channelstate','channel','isNil','[%s][recordings][newstate]\x20linkedid:%s\x20context:%s\x20channel:%s','error','varset','variable','mixmonitor_filename','[%s][recordings][varset]\x20variable:%s\x20value:%s','value','.wav49','replace','.WAV','find','monitors','push','[%s][recordings][varset]','hangup','[%s][recordings][hangup]','[%s][recordings][hangup]\x20calleridnum:%s\x20calleridname:%s\x20reason:%s','calleridname','cause-txt','calleridnum','connectedlinenum','connectedlinename','type'];(function(_0x1bb927,_0x3f1975){var _0x3df796=function(_0x57eacf){while(--_0x57eacf){_0x1bb927['push'](_0x1bb927['shift']());}};_0x3df796(++_0x3f1975);}(_0xf11a,0x189));var _0xaf11=function(_0x307086,_0x3bfe4e){_0x307086=_0x307086-0x0;var _0x699043=_0xf11a[_0x307086];return _0x699043;};'use strict';var _=require(_0xaf11('0x0'));var util=require(_0xaf11('0x1'));var utils=require(_0xaf11('0x2'));var recordings={};function writeDB(_0x512fc3){utils[_0xaf11('0x3')](util[_0xaf11('0x4')](_0xaf11('0x5'),_0x512fc3[_0xaf11('0x6')]));if(_0x512fc3['accountcode']){utils['getUserByInternal'](_0x512fc3[_0xaf11('0x7')])['then'](function(_0x4a4620){if(_0x4a4620){_0x512fc3[_0xaf11('0x8')]=_0x4a4620[_0xaf11('0x9')];_0x512fc3[_0xaf11('0xa')]=_0x4a4620['id'];}utils['request'](_0xaf11('0xb'),_0x512fc3);});}else{utils[_0xaf11('0xc')](_0xaf11('0xb'),_0x512fc3);}}exports[_0xaf11('0xd')]=function(_0x32fa11){try{utils[_0xaf11('0xe')](util[_0xaf11('0x4')](_0xaf11('0xf'),_0x32fa11['uniqueid']),_0x32fa11);if(_0x32fa11[_0xaf11('0x6')]==_0x32fa11[_0xaf11('0x10')]){utils[_0xaf11('0x3')](util[_0xaf11('0x4')](_0xaf11('0x11'),_0x32fa11[_0xaf11('0x6')],_0x32fa11['context'],_0x32fa11[_0xaf11('0x12')]));recordings[_0x32fa11[_0xaf11('0x6')]]={'uniqueid':_0x32fa11[_0xaf11('0x6')],'accountcode':_0x32fa11[_0xaf11('0x7')],'exten':_0x32fa11[_0xaf11('0x12')],'context':_0x32fa11[_0xaf11('0x13')],'channel':_0x32fa11['channel'],'monitors':[]};}}catch(_0x4140a3){utils['error'](util[_0xaf11('0x4')](_0xaf11('0xf'),_0x32fa11[_0xaf11('0x6')]),_0x4140a3);}};exports[_0xaf11('0x14')]=function(_0x32fda6){try{utils['debug'](util['format'](_0xaf11('0x15'),_0x32fda6['uniqueid']),_0x32fda6);if(!_['isNil'](recordings[_0x32fda6[_0xaf11('0x6')]])&&_0x32fda6[_0xaf11('0x16')]==0x6){utils[_0xaf11('0x3')](util[_0xaf11('0x4')]('[%s][recordings][newstate]\x20context:%s\x20channel:%s',_0x32fda6['uniqueid'],_0x32fda6[_0xaf11('0x13')],_0x32fda6[_0xaf11('0x17')]));}else if(!_[_0xaf11('0x18')](recordings[_0x32fda6['linkedid']])&&_0x32fda6['channelstate']==0x6&&_0x32fda6[_0xaf11('0x13')]!='transfer'){utils['info'](util[_0xaf11('0x4')](_0xaf11('0x19'),_0x32fda6[_0xaf11('0x6')],_0x32fda6[_0xaf11('0x10')],_0x32fda6[_0xaf11('0x13')],_0x32fda6[_0xaf11('0x17')]));recordings[_0x32fda6[_0xaf11('0x10')]]['accountcode']=_0x32fda6[_0xaf11('0x7')];}}catch(_0x448626){utils[_0xaf11('0x1a')](util[_0xaf11('0x4')](_0xaf11('0x15'),_0x32fda6[_0xaf11('0x6')]),_0x448626);}};exports[_0xaf11('0x1b')]=function(_0x81bda7){try{if(!_['isNil'](_0x81bda7['variable'])&&!_[_0xaf11('0x18')](_0x81bda7[_0xaf11('0x1c')][_0xaf11('0x1d')])){utils[_0xaf11('0xe')](util[_0xaf11('0x4')]('[%s][recordings][varset]',_0x81bda7[_0xaf11('0x6')]),_0x81bda7);utils[_0xaf11('0x3')](util[_0xaf11('0x4')](_0xaf11('0x1e'),_0x81bda7[_0xaf11('0x6')],_0x81bda7[_0xaf11('0x1c')],_0x81bda7[_0xaf11('0x1f')]));if(_['endsWith'](_0x81bda7['value'],_0xaf11('0x20'))){_0x81bda7['value']=_0x81bda7['value'][_0xaf11('0x21')](_0xaf11('0x20'),_0xaf11('0x22'));}if(recordings[_0x81bda7[_0xaf11('0x10')]]){var _0x25c148=_[_0xaf11('0x23')](recordings[_0x81bda7[_0xaf11('0x10')]]['monitors'],{'value':_0x81bda7[_0xaf11('0x1f')]});if(_[_0xaf11('0x18')](_0x25c148)){recordings[_0x81bda7[_0xaf11('0x10')]][_0xaf11('0x24')][_0xaf11('0x25')]({'value':_0x81bda7[_0xaf11('0x1f')]});}}}}catch(_0x40bd78){utils[_0xaf11('0x1a')](util[_0xaf11('0x4')](_0xaf11('0x26'),_0x81bda7['uniqueid']),_0x40bd78);}};exports[_0xaf11('0x27')]=function(_0x4fe389){try{if(!_[_0xaf11('0x18')](recordings[_0x4fe389['uniqueid']])){utils[_0xaf11('0xe')](util[_0xaf11('0x4')](_0xaf11('0x28'),_0x4fe389[_0xaf11('0x6')]),_0x4fe389);utils[_0xaf11('0x3')](util[_0xaf11('0x4')](_0xaf11('0x29'),_0x4fe389['uniqueid'],_0x4fe389['calleridnum'],_0x4fe389[_0xaf11('0x2a')],_0x4fe389[_0xaf11('0x2b')]));recordings[_0x4fe389[_0xaf11('0x6')]][_0xaf11('0x2c')]=_0x4fe389[_0xaf11('0x2c')];recordings[_0x4fe389[_0xaf11('0x6')]][_0xaf11('0x2a')]=_0x4fe389[_0xaf11('0x2a')];recordings[_0x4fe389[_0xaf11('0x6')]][_0xaf11('0x2d')]=_0x4fe389[_0xaf11('0x2d')];recordings[_0x4fe389['uniqueid']][_0xaf11('0x2e')]=_0x4fe389[_0xaf11('0x2e')];if(recordings[_0x4fe389[_0xaf11('0x6')]][_0xaf11('0x2f')]=='outbound'&&recordings[_0x4fe389[_0xaf11('0x6')]]['accountcode']){recordings[_0x4fe389[_0xaf11('0x6')]]['connectedlinenum']=recordings[_0x4fe389[_0xaf11('0x6')]][_0xaf11('0x7')];recordings[_0x4fe389[_0xaf11('0x6')]]['connectedlinename']='';}recordings[_0x4fe389[_0xaf11('0x6')]][_0xaf11('0x24')][_0xaf11('0x30')](function(_0x39033c){var _0x1289bf=_[_0xaf11('0x31')](recordings[_0x4fe389[_0xaf11('0x6')]]);_0x1289bf['value']=_0x39033c[_0xaf11('0x1f')];writeDB(_0x1289bf);});delete recordings[_0x4fe389[_0xaf11('0x6')]];}}catch(_0x405c97){utils[_0xaf11('0x1a')](util[_0xaf11('0x4')]('[%s][recordings][hangup]',_0x4fe389['uniqueid']),_0x405c97);}};exports[_0xaf11('0x32')]=function(_0x441d95){try{if(!_[_0xaf11('0x18')](recordings[_0x441d95['uniqueid']])){utils[_0xaf11('0xe')](util[_0xaf11('0x4')]('[%s][recordings][newexten]',_0x441d95[_0xaf11('0x6')]),_0x441d95);utils[_0xaf11('0x3')](util[_0xaf11('0x4')](_0xaf11('0x33'),_0x441d95[_0xaf11('0x6')],_0x441d95[_0xaf11('0x34')],_0x441d95[_0xaf11('0x35')]));if(_0x441d95[_0xaf11('0x34')][_0xaf11('0x36')]()==_0xaf11('0x37')&&_['startsWith'](_0x441d95[_0xaf11('0x35')][_0xaf11('0x36')](),_0xaf11('0x38'))){var _0x124d36=_0x441d95[_0xaf11('0x35')]['split']('=');var _0x202b64=_0x124d36[0x0][_0xaf11('0x39')](_0x124d36[0x0]['lastIndexOf']('(')+0x1,_0x124d36[0x0][_0xaf11('0x3a')](')'));var _0x29ceda=_0x124d36[0x1];recordings[_0x441d95[_0xaf11('0x6')]][_0x202b64]=_0x29ceda;}}}catch(_0x38ab60){utils['error'](util['format'](_0xaf11('0x3b'),_0x441d95[_0xaf11('0x6')]),_0x38ab60);}};exports['queuecallerjoin']=function(_0x5a893e){try{if(!_[_0xaf11('0x18')](recordings[_0x5a893e[_0xaf11('0x6')]])){utils[_0xaf11('0xe')](util['format']('[%s][recordings][queuecallerjoin]',_0x5a893e[_0xaf11('0x6')]),_0x5a893e);utils[_0xaf11('0x3')](util[_0xaf11('0x4')](_0xaf11('0x3c'),_0x5a893e[_0xaf11('0x6')],_0x5a893e[_0xaf11('0x3d')]));recordings[_0x5a893e[_0xaf11('0x6')]]['queue']=_0x5a893e[_0xaf11('0x3d')];}}catch(_0xfde867){utils['error'](util[_0xaf11('0x4')](_0xaf11('0x3e'),_0x5a893e['uniqueid']),_0xfde867);}};
\ No newline at end of file