Built motion from commit b0a9a629.|2.6.33
[motion2.git] / server / services / ami / report / voiceDialReport.js
index 70e8758..3aa2a69 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x2f1b=['interface','applications','voice:outbound','voice_outbound_channel:save','[%s][voiceDialReport][dialbegin]\x20sending\x20dialbegin\x20event:','inspect','custom:dialbegin','error','[%s][voiceDialReport][dialbegin]','syncDialEnd','dialstatus','ANSWER','connectedlinenum','connectedlinename','answertime','YYYY-MM-DD\x20HH:mm:ss','lastevent','connect','info','[%s][voiceDialReport][dialend]\x20agent:%s\x20lastevent:connect','[%s][voiceDialReport][dialend]\x20sending\x20dialconnect\x20event:','custom:dialconnect','[%s][voiceDialReport][dialend]\x20sending\x20voice_outbound_channel:save\x20event:','[%s][voiceDialReport][dialend]','addVariable','keys','variable','value','outboundrouteid','[%s][voiceDialReport][varset]\x20sending\x20voice_outbound_channel:save\x20event:','[%s][voiceDialReport][varset]','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrttbridged','sipcallid','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberpenalty','memberrealtime','isNil','includes','[%s][voiceDialReport][hangup]\x20event:','[%s][voiceDialReport][hangup]\x20reason:%s\x20lasteevent:complete','cause-txt','format','endtime','diff','starttime','seconds','complete','answered','holdtime','billableseconds','sumHoldTime','sumBillable','sumDuration','duration','[%s][voiceDialReport][hangup]\x20sending\x20voiceDialReport\x20event:','custom:voiceDialReport','custom:dialend','[%s][voiceDialReport][hangup]\x20sending\x20voice_outbound:save\x20event:','voice_outbound:save','[DEBUG]\x20Emit\x20voice_outbound_channel:remove\x20event','stringify','[%s][voiceDialReport][hangup]\x20sending\x20voice_outbound_channel:remove\x20event:','voice_outbound_channel:remove','linkedid','destuniqueid','[%s][voiceDialReport][hangup]','syncNewExten','application','set','appdata','applicationdata','toLowerCase','startsWith','cdr(','split','match','[%s][voiceDialReport][newexten]','exports','lodash','moment','util','ioredis','../../../config/environment','../../../config/logger','../ami','redis','defaults','localhost','socket.io-emitter','channels','outbound','variables','bind','dialend','varset','syncVarSet','hangup','syncHangup','prototype','isUndefined','emit','isNotNull','debug','[%s][voiceDialReport][dialbegin]\x20event:','uniqueid','merge','substring','channel','lastIndexOf','omit','event','privilege','[%s][voiceDialReport][dialbegin]\x20agent:%s\x20interface:%s\x20lastevent:called','membername'];(function(_0x4bd254,_0x347d7a){var _0x3dcead=function(_0x4b5594){while(--_0x4b5594){_0x4bd254['push'](_0x4bd254['shift']());}};_0x3dcead(++_0x347d7a);}(_0x2f1b,0xd2));var _0xb2f1=function(_0x421184,_0x2a0388){_0x421184=_0x421184-0x0;var _0x3623b1=_0x2f1b[_0x421184];return _0x3623b1;};'use strict';var _=require(_0xb2f1('0x0'));var moment=require(_0xb2f1('0x1'));var util=require(_0xb2f1('0x2'));var Redis=require(_0xb2f1('0x3'));var config=require(_0xb2f1('0x4'));var logger=require(_0xb2f1('0x5'))('ami');var ami=require(_0xb2f1('0x6'));config[_0xb2f1('0x7')]=_[_0xb2f1('0x8')](config['redis'],{'host':_0xb2f1('0x9'),'port':0x18eb});var io=require(_0xb2f1('0xa'))(new Redis(config[_0xb2f1('0x7')]));function VoiceDialReport(_0x51acca){this[_0xb2f1('0xb')]=_0x51acca['outboundChannels'];this['outbound']=_0x51acca[_0xb2f1('0xc')];this['applications']={};this[_0xb2f1('0xd')]={};ami['on']('dialbegin',this['syncDialBegin'][_0xb2f1('0xe')](this));ami['on'](_0xb2f1('0xf'),this['syncDialEnd'][_0xb2f1('0xe')](this));ami['on'](_0xb2f1('0x10'),this[_0xb2f1('0x11')][_0xb2f1('0xe')](this));ami['on'](_0xb2f1('0x12'),this[_0xb2f1('0x13')][_0xb2f1('0xe')](this));}VoiceDialReport[_0xb2f1('0x14')]['isNotNull']=function(_0x20ec3e){return _0x20ec3e!==null&&!_[_0xb2f1('0x15')](_0x20ec3e);};VoiceDialReport['prototype'][_0xb2f1('0x16')]=function(_0x5cff89,_0x108f6b,_0x444323){io['to'](_0x5cff89)[_0xb2f1('0x16')](_0x108f6b,_0x444323);};VoiceDialReport['prototype']['syncDialBegin']=function(_0x330288){try{if(this[_0xb2f1('0x17')](_0x330288)){logger[_0xb2f1('0x18')](_0xb2f1('0x19'),_0x330288[_0xb2f1('0x1a')],util['inspect'](_0x330288,{'showHidden':![],'depth':null}));if(this[_0xb2f1('0xb')][_0x330288[_0xb2f1('0x1a')]]){_[_0xb2f1('0x1b')](this['channels'][_0x330288['uniqueid']],{'starttime':moment()['format']('YYYY-MM-DD\x20HH:mm:ss'),'lastevent':'called','interface':_0x330288['channel'][_0xb2f1('0x1c')](0x0,_0x330288[_0xb2f1('0x1d')][_0xb2f1('0x1e')]('-')),'membername':_0x330288[_0xb2f1('0x1d')]['substring'](_0x330288[_0xb2f1('0x1d')][_0xb2f1('0x1e')]('/')+0x1,_0x330288['channel']['lastIndexOf']('-'))},_[_0xb2f1('0x1f')](_0x330288,[_0xb2f1('0x20'),_0xb2f1('0x21')]));logger['info'](_0xb2f1('0x22'),_0x330288[_0xb2f1('0x1a')],this['channels'][_0x330288[_0xb2f1('0x1a')]][_0xb2f1('0x23')],this['channels'][_0x330288[_0xb2f1('0x1a')]][_0xb2f1('0x24')]);logger['debug']('[%s][voiceDialReport][dialbegin]\x20sending\x20voice_outbound_channel:save\x20event:',_0x330288[_0xb2f1('0x1a')],util['inspect'](this[_0xb2f1('0xb')][_0x330288[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));if(this[_0xb2f1('0x25')][_0x330288['uniqueid']])_[_0xb2f1('0x1b')](this[_0xb2f1('0xb')][_0x330288[_0xb2f1('0x1a')]],this[_0xb2f1('0x25')][_0x330288[_0xb2f1('0x1a')]]);this['emit'](_0xb2f1('0x26'),_0xb2f1('0x27'),this['channels'][_0x330288[_0xb2f1('0x1a')]]);logger[_0xb2f1('0x18')](_0xb2f1('0x28'),_0x330288[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](this[_0xb2f1('0xb')][_0x330288[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));ami[_0xb2f1('0x16')](_0xb2f1('0x2a'),this[_0xb2f1('0xb')][_0x330288[_0xb2f1('0x1a')]]);}}}catch(_0x402f96){logger[_0xb2f1('0x2b')](_0xb2f1('0x2c'),_0x330288['uniqueid'],util[_0xb2f1('0x29')](_0x402f96,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb2f1('0x14')][_0xb2f1('0x2d')]=function(_0x52596e){try{if(this[_0xb2f1('0x17')](_0x52596e)){logger['debug']('[%s][voiceDialReport][dialend]\x20event:',_0x52596e[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](_0x52596e,{'showHidden':![],'depth':null}));if(this[_0xb2f1('0xb')][_0x52596e['uniqueid']]){this[_0xb2f1('0xb')][_0x52596e[_0xb2f1('0x1a')]]['dialstatus']=_0x52596e[_0xb2f1('0x2e')];if(_0x52596e[_0xb2f1('0x2e')]===_0xb2f1('0x2f')){this['channels'][_0x52596e[_0xb2f1('0x1a')]][_0xb2f1('0x30')]=_0x52596e[_0xb2f1('0x30')];this['channels'][_0x52596e[_0xb2f1('0x1a')]][_0xb2f1('0x31')]=_0x52596e[_0xb2f1('0x31')];this[_0xb2f1('0xb')][_0x52596e[_0xb2f1('0x1a')]][_0xb2f1('0x32')]=moment()['format'](_0xb2f1('0x33'));this[_0xb2f1('0xb')][_0x52596e[_0xb2f1('0x1a')]][_0xb2f1('0x34')]=_0xb2f1('0x35');logger[_0xb2f1('0x36')](_0xb2f1('0x37'),_0x52596e['uniqueid'],_0x52596e[_0xb2f1('0x1d')][_0xb2f1('0x1c')](_0x52596e['channel'][_0xb2f1('0x1e')]('/')+0x1,_0x52596e[_0xb2f1('0x1d')][_0xb2f1('0x1e')]('-')));logger[_0xb2f1('0x18')](_0xb2f1('0x38'),_0x52596e[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](this[_0xb2f1('0xb')][_0x52596e[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));ami[_0xb2f1('0x16')](_0xb2f1('0x39'),this['channels'][_0x52596e['uniqueid']]);}logger[_0xb2f1('0x18')](_0xb2f1('0x3a'),_0x52596e[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](this['channels'][_0x52596e[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));this[_0xb2f1('0x16')](_0xb2f1('0x26'),_0xb2f1('0x27'),this['channels'][_0x52596e[_0xb2f1('0x1a')]]);}}}catch(_0x5cf1aa){logger[_0xb2f1('0x2b')](_0xb2f1('0x3b'),_0x52596e[_0xb2f1('0x1a')],util['inspect'](_0x5cf1aa,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb2f1('0x14')][_0xb2f1('0x11')]=function(_0x49ecc2){try{if(this[_0xb2f1('0x17')](_0x49ecc2)){logger[_0xb2f1('0x18')]('[%s][voiceDialReport][varset]\x20event:',_0x49ecc2[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](_0x49ecc2,{'showHidden':![],'depth':null}));this[_0xb2f1('0x3c')](_0x49ecc2['uniqueid'],_[_0xb2f1('0x3d')](_0x49ecc2[_0xb2f1('0x3e')])[0x0],_0x49ecc2[_0xb2f1('0x3f')]);if(this[_0xb2f1('0x17')](_0x49ecc2[_0xb2f1('0x3e')])&&this['isNotNull'](_0x49ecc2[_0xb2f1('0x3e')][_0xb2f1('0x40')])){if(_[_0xb2f1('0x15')](this['channels'][_0x49ecc2[_0xb2f1('0x1a')]])){this[_0xb2f1('0xb')][_0x49ecc2[_0xb2f1('0x1a')]]={'routeId':_0x49ecc2[_0xb2f1('0x3f')],'variables':this['variables'][_0x49ecc2[_0xb2f1('0x1a')]],'motionChannel':'voice'};logger[_0xb2f1('0x36')]('[%s][voiceDialReport][varset]\x20outboundrouteid:%s\x20variable:%s\x20value:%s',_0x49ecc2[_0xb2f1('0x1a')],_0x49ecc2['variable']['outboundrouteid'],_['keys'](_0x49ecc2['variable'])[0x0],_0x49ecc2['value']);logger[_0xb2f1('0x18')](_0xb2f1('0x41'),_0x49ecc2[_0xb2f1('0x1a')],util['inspect'](this['channels'][_0x49ecc2[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));this['emit']('voice:outbound',_0xb2f1('0x27'),this[_0xb2f1('0xb')][_0x49ecc2[_0xb2f1('0x1a')]]);}}}}catch(_0x3a4414){logger[_0xb2f1('0x2b')](_0xb2f1('0x42'),_0x49ecc2[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](_0x3a4414,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb2f1('0x14')][_0xb2f1('0x3c')]=function(_0x3acb0f,_0x1f8cf8,_0x1ccc4b){var _0x53d52a=['rtpaudioqos','rtpaudioqosbridged',_0xb2f1('0x43'),_0xb2f1('0x44'),_0xb2f1('0x45'),_0xb2f1('0x46'),'rtpaudioqosrtt',_0xb2f1('0x47'),_0xb2f1('0x48'),_0xb2f1('0x49'),_0xb2f1('0x4a'),_0xb2f1('0x4b'),_0xb2f1('0x4c'),_0xb2f1('0x4d'),_0xb2f1('0x4e'),'memberlastcall','membername',_0xb2f1('0x4f'),_0xb2f1('0x50')];if(!_[_0xb2f1('0x51')](_0x1f8cf8)&&!_[_0xb2f1('0x52')](_0x53d52a,_0x1f8cf8)){if(_[_0xb2f1('0x15')](this['variables'][_0x3acb0f])){this[_0xb2f1('0xd')][_0x3acb0f]={};}this[_0xb2f1('0xd')][_0x3acb0f][_0x1f8cf8]=_0x1ccc4b;}};VoiceDialReport[_0xb2f1('0x14')][_0xb2f1('0x13')]=function(_0x38c0a3){try{if(this[_0xb2f1('0x17')](_0x38c0a3)){logger[_0xb2f1('0x18')](_0xb2f1('0x53'),_0x38c0a3[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](_0x38c0a3,{'showHidden':![],'depth':null}));if(this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]]){logger['info'](_0xb2f1('0x54'),_0x38c0a3[_0xb2f1('0x1a')],_0x38c0a3[_0xb2f1('0x55')]);this['channels'][_0x38c0a3[_0xb2f1('0x1a')]]['endtime']=moment()[_0xb2f1('0x56')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]]['duration']=moment(this[_0xb2f1('0xb')][_0x38c0a3['uniqueid']][_0xb2f1('0x57')])[_0xb2f1('0x58')](this['channels'][_0x38c0a3[_0xb2f1('0x1a')]][_0xb2f1('0x59')],_0xb2f1('0x5a'));this[_0xb2f1('0xb')][_0x38c0a3['uniqueid']][_0xb2f1('0x34')]=_0xb2f1('0x5b');this[_0xb2f1('0xc')]['total']+=0x1;if(this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]]['answertime']){this[_0xb2f1('0xc')][_0xb2f1('0x5c')]+=0x1;this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]][_0xb2f1('0x5d')]=moment(this['channels'][_0x38c0a3[_0xb2f1('0x1a')]]['answertime'])[_0xb2f1('0x58')](this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]][_0xb2f1('0x59')],_0xb2f1('0x5a'));this[_0xb2f1('0xb')][_0x38c0a3['uniqueid']][_0xb2f1('0x5e')]=moment(this['channels'][_0x38c0a3[_0xb2f1('0x1a')]]['endtime'])[_0xb2f1('0x58')](this['channels'][_0x38c0a3[_0xb2f1('0x1a')]]['answertime'],_0xb2f1('0x5a'));this[_0xb2f1('0xc')][_0xb2f1('0x5f')]+=this['channels'][_0x38c0a3[_0xb2f1('0x1a')]][_0xb2f1('0x5d')]||0x0;this[_0xb2f1('0xc')][_0xb2f1('0x60')]+=this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]][_0xb2f1('0x5e')];}this[_0xb2f1('0xc')][_0xb2f1('0x61')]+=this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]][_0xb2f1('0x62')];logger[_0xb2f1('0x18')](_0xb2f1('0x63'),_0x38c0a3['uniqueid'],util[_0xb2f1('0x29')](this[_0xb2f1('0xb')][_0x38c0a3['uniqueid']],{'showHidden':![],'depth':null}));ami['emit'](_0xb2f1('0x64'),this['channels'][_0x38c0a3[_0xb2f1('0x1a')]]);logger[_0xb2f1('0x18')]('[%s][voiceDialReport][hangup]\x20sending\x20dialend\x20event:',_0x38c0a3[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));ami[_0xb2f1('0x16')](_0xb2f1('0x65'),this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]]);logger[_0xb2f1('0x18')](_0xb2f1('0x66'),_0x38c0a3[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));this[_0xb2f1('0x16')]('voice:outbound',_0xb2f1('0x67'),this['outbound']);logger[_0xb2f1('0x36')](_0xb2f1('0x68'),JSON[_0xb2f1('0x69')](this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x1a')]]));logger[_0xb2f1('0x18')](_0xb2f1('0x6a'),_0x38c0a3[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](this['channels'][_0x38c0a3[_0xb2f1('0x1a')]],{'showHidden':![],'depth':null}));this[_0xb2f1('0x16')](_0xb2f1('0x26'),_0xb2f1('0x6b'),this['channels'][_0x38c0a3[_0xb2f1('0x1a')]]);this['deleteChannelAfterTimeout'](_0x38c0a3[_0xb2f1('0x1a')]);}else if(this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x6c')]]){this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x6c')]][_0xb2f1('0x1a')]=this[_0xb2f1('0xb')][_0x38c0a3[_0xb2f1('0x6c')]][_0xb2f1('0x6d')];}if(this[_0xb2f1('0xd')][_0x38c0a3[_0xb2f1('0x1a')]]){delete this[_0xb2f1('0xd')][_0x38c0a3[_0xb2f1('0x1a')]];}}}catch(_0x309e69){logger['error'](_0xb2f1('0x6e'),_0x38c0a3[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](_0x309e69,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb2f1('0x14')][_0xb2f1('0x6f')]=function(_0x537129){try{if(this['isNotNull'](_0x537129)){logger[_0xb2f1('0x18')]('[%s][voiceDialReport][newexten]\x20event:',_0x537129['uniqueid'],util[_0xb2f1('0x29')](_0x537129,{'showHidden':![],'depth':null}));if(_0x537129[_0xb2f1('0x70')]['toLowerCase']()===_0xb2f1('0x71')){_0x537129['applicationdata']=(_0x537129[_0xb2f1('0x72')]||_0x537129[_0xb2f1('0x73')])[_0xb2f1('0x74')]();if(_[_0xb2f1('0x75')](_0x537129[_0xb2f1('0x73')],_0xb2f1('0x76'))){if(_[_0xb2f1('0x15')](this[_0xb2f1('0x25')][_0x537129[_0xb2f1('0x1a')]]))this['applications'][_0x537129[_0xb2f1('0x1a')]]={};logger['info']('[%s][voiceDialReport][newexten]\x20application:%s\x20appdata:%s',_0x537129[_0xb2f1('0x1a')],_0x537129[_0xb2f1('0x70')],_0x537129['applicationdata']);var _0x4ff9d1=_0x537129['applicationdata'][_0xb2f1('0x77')]('=');var _0x4ce68a=_0x4ff9d1[0x0][_0xb2f1('0x78')](/cdr\((.*)\)/);if(_0x4ce68a)this[_0xb2f1('0x25')][_0x537129[_0xb2f1('0x1a')]][_0x4ce68a[0x1]]=_0x4ff9d1[0x1];}}}}catch(_0x3b9b7b){logger[_0xb2f1('0x2b')](_0xb2f1('0x79'),_0x537129[_0xb2f1('0x1a')],util[_0xb2f1('0x29')](_0x3b9b7b,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb2f1('0x14')]['deleteChannelAfterTimeout']=function(_0x138bb3,_0x41ae2d=0x2710){if(this[_0xb2f1('0xb')][_0x138bb3]){setTimeout(()=>{delete this[_0xb2f1('0xb')][_0x138bb3];},_0x41ae2d);}};module[_0xb2f1('0x7a')]=VoiceDialReport;
\ No newline at end of file
+var _0x8054=['[%s][voiceDialReport][dialend]\x20sending\x20dialconnect\x20event:','custom:dialconnect','[%s][voiceDialReport][dialend]\x20sending\x20voice_outbound_channel:save\x20event:','[%s][voiceDialReport][dialend]','[%s][voiceDialReport][varset]\x20event:','keys','variable','value','voice','[%s][voiceDialReport][varset]\x20outboundrouteid:%s\x20variable:%s\x20value:%s','outboundrouteid','[%s][voiceDialReport][varset]','rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqosrtt','rtpaudioqosrttbridged','sipcallid','bridgepeer','bridgepvtcallid','memberdynamic','memberinterface','memberlastcall','memberpenalty','memberrealtime','includes','[%s][voiceDialReport][hangup]\x20event:','cause-txt','duration','starttime','seconds','complete','total','answered','holdtime','diff','billableseconds','endtime','sumHoldTime','sumBillable','sumDuration','[%s][voiceDialReport][hangup]\x20sending\x20voiceDialReport\x20event:','custom:voiceDialReport','[%s][voiceDialReport][hangup]\x20sending\x20dialend\x20event:','custom:dialend','[%s][voiceDialReport][hangup]\x20sending\x20voice_outbound:save\x20event:','voice_outbound:save','[DEBUG]\x20Emit\x20voice_outbound_channel:remove\x20event','[%s][voiceDialReport][hangup]\x20sending\x20voice_outbound_channel:remove\x20event:','deleteChannelAfterTimeout','linkedid','[%s][voiceDialReport][newexten]\x20event:','toLowerCase','applicationdata','appdata','startsWith','[%s][voiceDialReport][newexten]\x20application:%s\x20appdata:%s','application','split','match','exports','lodash','moment','../../../config/environment','../../../config/logger','ami','defaults','localhost','redis','channels','outboundChannels','outbound','applications','variables','syncDialBegin','bind','dialend','syncDialEnd','varset','syncVarSet','hangup','syncHangup','prototype','isUndefined','emit','isNotNull','debug','uniqueid','inspect','merge','format','YYYY-MM-DD\x20HH:mm:ss','called','channel','lastIndexOf','substring','omit','event','privilege','[%s][voiceDialReport][dialbegin]\x20agent:%s\x20interface:%s\x20lastevent:called','membername','interface','[%s][voiceDialReport][dialbegin]\x20sending\x20voice_outbound_channel:save\x20event:','voice:outbound','voice_outbound_channel:save','[%s][voiceDialReport][dialbegin]\x20sending\x20dialbegin\x20event:','custom:dialbegin','error','[%s][voiceDialReport][dialend]\x20event:','dialstatus','connectedlinenum','connectedlinename','answertime','lastevent','connect','info','[%s][voiceDialReport][dialend]\x20agent:%s\x20lastevent:connect'];(function(_0x330f55,_0x529d82){var _0x5ddf3c=function(_0x9e1745){while(--_0x9e1745){_0x330f55['push'](_0x330f55['shift']());}};_0x5ddf3c(++_0x529d82);}(_0x8054,0xb6));var _0x4805=function(_0x37025e,_0x47f3e5){_0x37025e=_0x37025e-0x0;var _0x3239d7=_0x8054[_0x37025e];return _0x3239d7;};'use strict';var _=require(_0x4805('0x0'));var moment=require(_0x4805('0x1'));var util=require('util');var Redis=require('ioredis');var config=require(_0x4805('0x2'));var logger=require(_0x4805('0x3'))(_0x4805('0x4'));var ami=require('../ami');config['redis']=_[_0x4805('0x5')](config['redis'],{'host':_0x4805('0x6'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0x4805('0x7')]));function VoiceDialReport(_0x1c82b4){this[_0x4805('0x8')]=_0x1c82b4[_0x4805('0x9')];this['outbound']=_0x1c82b4[_0x4805('0xa')];this[_0x4805('0xb')]={};this[_0x4805('0xc')]={};ami['on']('dialbegin',this[_0x4805('0xd')][_0x4805('0xe')](this));ami['on'](_0x4805('0xf'),this[_0x4805('0x10')]['bind'](this));ami['on'](_0x4805('0x11'),this[_0x4805('0x12')][_0x4805('0xe')](this));ami['on'](_0x4805('0x13'),this[_0x4805('0x14')]['bind'](this));}VoiceDialReport[_0x4805('0x15')]['isNotNull']=function(_0x5d4a79){return _0x5d4a79!==null&&!_[_0x4805('0x16')](_0x5d4a79);};VoiceDialReport[_0x4805('0x15')][_0x4805('0x17')]=function(_0x573454,_0x489e3b,_0x18c753){io['to'](_0x573454)['emit'](_0x489e3b,_0x18c753);};VoiceDialReport[_0x4805('0x15')]['syncDialBegin']=function(_0x1cd20a){try{if(this[_0x4805('0x18')](_0x1cd20a)){logger[_0x4805('0x19')]('[%s][voiceDialReport][dialbegin]\x20event:',_0x1cd20a[_0x4805('0x1a')],util[_0x4805('0x1b')](_0x1cd20a,{'showHidden':![],'depth':null}));if(this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]]){_[_0x4805('0x1c')](this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]],{'starttime':moment()[_0x4805('0x1d')](_0x4805('0x1e')),'lastevent':_0x4805('0x1f'),'interface':_0x1cd20a[_0x4805('0x20')]['substring'](0x0,_0x1cd20a[_0x4805('0x20')][_0x4805('0x21')]('-')),'membername':_0x1cd20a[_0x4805('0x20')][_0x4805('0x22')](_0x1cd20a[_0x4805('0x20')]['lastIndexOf']('/')+0x1,_0x1cd20a['channel'][_0x4805('0x21')]('-'))},_[_0x4805('0x23')](_0x1cd20a,[_0x4805('0x24'),_0x4805('0x25')]));logger['info'](_0x4805('0x26'),_0x1cd20a[_0x4805('0x1a')],this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]][_0x4805('0x27')],this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]][_0x4805('0x28')]);logger[_0x4805('0x19')](_0x4805('0x29'),_0x1cd20a['uniqueid'],util[_0x4805('0x1b')](this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]],{'showHidden':![],'depth':null}));if(this[_0x4805('0xb')][_0x1cd20a[_0x4805('0x1a')]])_[_0x4805('0x1c')](this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]],this['applications'][_0x1cd20a['uniqueid']]);this[_0x4805('0x17')](_0x4805('0x2a'),_0x4805('0x2b'),this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]]);logger['debug'](_0x4805('0x2c'),_0x1cd20a[_0x4805('0x1a')],util[_0x4805('0x1b')](this[_0x4805('0x8')][_0x1cd20a['uniqueid']],{'showHidden':![],'depth':null}));ami[_0x4805('0x17')](_0x4805('0x2d'),this[_0x4805('0x8')][_0x1cd20a[_0x4805('0x1a')]]);}}}catch(_0x45f3cb){logger[_0x4805('0x2e')]('[%s][voiceDialReport][dialbegin]',_0x1cd20a['uniqueid'],util[_0x4805('0x1b')](_0x45f3cb,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x4805('0x15')][_0x4805('0x10')]=function(_0x310191){try{if(this[_0x4805('0x18')](_0x310191)){logger['debug'](_0x4805('0x2f'),_0x310191['uniqueid'],util[_0x4805('0x1b')](_0x310191,{'showHidden':![],'depth':null}));if(this[_0x4805('0x8')][_0x310191[_0x4805('0x1a')]]){this['channels'][_0x310191['uniqueid']][_0x4805('0x30')]=_0x310191[_0x4805('0x30')];if(_0x310191[_0x4805('0x30')]==='ANSWER'){this['channels'][_0x310191[_0x4805('0x1a')]][_0x4805('0x31')]=_0x310191[_0x4805('0x31')];this[_0x4805('0x8')][_0x310191[_0x4805('0x1a')]][_0x4805('0x32')]=_0x310191[_0x4805('0x32')];this['channels'][_0x310191['uniqueid']][_0x4805('0x33')]=moment()[_0x4805('0x1d')](_0x4805('0x1e'));this['channels'][_0x310191[_0x4805('0x1a')]][_0x4805('0x34')]=_0x4805('0x35');logger[_0x4805('0x36')](_0x4805('0x37'),_0x310191['uniqueid'],_0x310191[_0x4805('0x20')][_0x4805('0x22')](_0x310191['channel'][_0x4805('0x21')]('/')+0x1,_0x310191['channel'][_0x4805('0x21')]('-')));logger['debug'](_0x4805('0x38'),_0x310191[_0x4805('0x1a')],util[_0x4805('0x1b')](this['channels'][_0x310191[_0x4805('0x1a')]],{'showHidden':![],'depth':null}));ami[_0x4805('0x17')](_0x4805('0x39'),this[_0x4805('0x8')][_0x310191['uniqueid']]);}logger['debug'](_0x4805('0x3a'),_0x310191['uniqueid'],util[_0x4805('0x1b')](this[_0x4805('0x8')][_0x310191[_0x4805('0x1a')]],{'showHidden':![],'depth':null}));this[_0x4805('0x17')]('voice:outbound',_0x4805('0x2b'),this[_0x4805('0x8')][_0x310191[_0x4805('0x1a')]]);}}}catch(_0x338e1d){logger[_0x4805('0x2e')](_0x4805('0x3b'),_0x310191['uniqueid'],util[_0x4805('0x1b')](_0x338e1d,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x4805('0x15')]['syncVarSet']=function(_0x9f6cce){try{if(this[_0x4805('0x18')](_0x9f6cce)){logger[_0x4805('0x19')](_0x4805('0x3c'),_0x9f6cce['uniqueid'],util[_0x4805('0x1b')](_0x9f6cce,{'showHidden':![],'depth':null}));this['addVariable'](_0x9f6cce[_0x4805('0x1a')],_[_0x4805('0x3d')](_0x9f6cce[_0x4805('0x3e')])[0x0],_0x9f6cce[_0x4805('0x3f')]);if(this[_0x4805('0x18')](_0x9f6cce[_0x4805('0x3e')])&&this[_0x4805('0x18')](_0x9f6cce[_0x4805('0x3e')]['outboundrouteid'])){if(_[_0x4805('0x16')](this[_0x4805('0x8')][_0x9f6cce['uniqueid']])){this[_0x4805('0x8')][_0x9f6cce['uniqueid']]={'routeId':_0x9f6cce['value'],'variables':this[_0x4805('0xc')][_0x9f6cce[_0x4805('0x1a')]],'motionChannel':_0x4805('0x40')};logger['info'](_0x4805('0x41'),_0x9f6cce[_0x4805('0x1a')],_0x9f6cce[_0x4805('0x3e')][_0x4805('0x42')],_[_0x4805('0x3d')](_0x9f6cce['variable'])[0x0],_0x9f6cce['value']);logger[_0x4805('0x19')]('[%s][voiceDialReport][varset]\x20sending\x20voice_outbound_channel:save\x20event:',_0x9f6cce['uniqueid'],util[_0x4805('0x1b')](this['channels'][_0x9f6cce[_0x4805('0x1a')]],{'showHidden':![],'depth':null}));this['emit'](_0x4805('0x2a'),_0x4805('0x2b'),this[_0x4805('0x8')][_0x9f6cce[_0x4805('0x1a')]]);}}}}catch(_0x21d7dc){logger[_0x4805('0x2e')](_0x4805('0x43'),_0x9f6cce['uniqueid'],util['inspect'](_0x21d7dc,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x4805('0x15')]['addVariable']=function(_0x1e3888,_0x5403ed,_0x3305f0){var _0x5f599f=[_0x4805('0x44'),_0x4805('0x45'),_0x4805('0x46'),_0x4805('0x47'),_0x4805('0x48'),'rtpaudioqoslossbridged',_0x4805('0x49'),_0x4805('0x4a'),_0x4805('0x4b'),'sipuri',_0x4805('0x4c'),_0x4805('0x4d'),'membercalls',_0x4805('0x4e'),_0x4805('0x4f'),_0x4805('0x50'),_0x4805('0x27'),_0x4805('0x51'),_0x4805('0x52')];if(!_['isNil'](_0x5403ed)&&!_[_0x4805('0x53')](_0x5f599f,_0x5403ed)){if(_[_0x4805('0x16')](this['variables'][_0x1e3888])){this[_0x4805('0xc')][_0x1e3888]={};}this[_0x4805('0xc')][_0x1e3888][_0x5403ed]=_0x3305f0;}};VoiceDialReport[_0x4805('0x15')][_0x4805('0x14')]=function(_0x1e7477){try{if(this[_0x4805('0x18')](_0x1e7477)){logger[_0x4805('0x19')](_0x4805('0x54'),_0x1e7477[_0x4805('0x1a')],util[_0x4805('0x1b')](_0x1e7477,{'showHidden':![],'depth':null}));if(this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]]){logger[_0x4805('0x36')]('[%s][voiceDialReport][hangup]\x20reason:%s\x20lasteevent:complete',_0x1e7477[_0x4805('0x1a')],_0x1e7477[_0x4805('0x55')]);this['channels'][_0x1e7477[_0x4805('0x1a')]]['endtime']=moment()[_0x4805('0x1d')]('YYYY-MM-DD\x20HH:mm:ss');this['channels'][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x56')]=moment(this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]]['endtime'])['diff'](this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x57')],_0x4805('0x58'));this['channels'][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x34')]=_0x4805('0x59');this[_0x4805('0xa')][_0x4805('0x5a')]+=0x1;if(this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x33')]){this[_0x4805('0xa')][_0x4805('0x5b')]+=0x1;this['channels'][_0x1e7477['uniqueid']][_0x4805('0x5c')]=moment(this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]]['answertime'])[_0x4805('0x5d')](this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x57')],_0x4805('0x58'));this[_0x4805('0x8')][_0x1e7477['uniqueid']][_0x4805('0x5e')]=moment(this['channels'][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x5f')])[_0x4805('0x5d')](this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x33')],'seconds');this['outbound'][_0x4805('0x60')]+=this['channels'][_0x1e7477[_0x4805('0x1a')]][_0x4805('0x5c')]||0x0;this[_0x4805('0xa')][_0x4805('0x61')]+=this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]]['billableseconds'];}this[_0x4805('0xa')][_0x4805('0x62')]+=this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]]['duration'];logger[_0x4805('0x19')](_0x4805('0x63'),_0x1e7477['uniqueid'],util[_0x4805('0x1b')](this['channels'][_0x1e7477[_0x4805('0x1a')]],{'showHidden':![],'depth':null}));ami[_0x4805('0x17')](_0x4805('0x64'),this['channels'][_0x1e7477['uniqueid']]);logger['debug'](_0x4805('0x65'),_0x1e7477['uniqueid'],util[_0x4805('0x1b')](this[_0x4805('0x8')][_0x1e7477['uniqueid']],{'showHidden':![],'depth':null}));ami['emit'](_0x4805('0x66'),this[_0x4805('0x8')][_0x1e7477['uniqueid']]);logger['debug'](_0x4805('0x67'),_0x1e7477['uniqueid'],util['inspect'](this[_0x4805('0x8')][_0x1e7477['uniqueid']],{'showHidden':![],'depth':null}));this[_0x4805('0x17')]('voice:outbound',_0x4805('0x68'),this[_0x4805('0xa')]);logger['info'](_0x4805('0x69'),JSON['stringify'](this[_0x4805('0x8')][_0x1e7477[_0x4805('0x1a')]]));logger[_0x4805('0x19')](_0x4805('0x6a'),_0x1e7477[_0x4805('0x1a')],util[_0x4805('0x1b')](this['channels'][_0x1e7477[_0x4805('0x1a')]],{'showHidden':![],'depth':null}));this['emit'](_0x4805('0x2a'),'voice_outbound_channel:remove',this[_0x4805('0x8')][_0x1e7477['uniqueid']]);this[_0x4805('0x6b')](_0x1e7477[_0x4805('0x1a')]);}else if(this['channels'][_0x1e7477[_0x4805('0x6c')]]){this[_0x4805('0x8')][_0x1e7477[_0x4805('0x6c')]][_0x4805('0x1a')]=this[_0x4805('0x8')][_0x1e7477[_0x4805('0x6c')]]['destuniqueid'];}if(this[_0x4805('0xc')][_0x1e7477['uniqueid']]){delete this[_0x4805('0xc')][_0x1e7477['uniqueid']];}}}catch(_0x583222){logger[_0x4805('0x2e')]('[%s][voiceDialReport][hangup]',_0x1e7477['uniqueid'],util[_0x4805('0x1b')](_0x583222,{'showHidden':![],'depth':null}));}};VoiceDialReport['prototype']['syncNewExten']=function(_0x449b82){try{if(this[_0x4805('0x18')](_0x449b82)){logger[_0x4805('0x19')](_0x4805('0x6d'),_0x449b82[_0x4805('0x1a')],util[_0x4805('0x1b')](_0x449b82,{'showHidden':![],'depth':null}));if(_0x449b82['application'][_0x4805('0x6e')]()==='set'){_0x449b82[_0x4805('0x6f')]=(_0x449b82[_0x4805('0x70')]||_0x449b82[_0x4805('0x6f')])['toLowerCase']();if(_[_0x4805('0x71')](_0x449b82[_0x4805('0x6f')],'cdr(')){if(_[_0x4805('0x16')](this[_0x4805('0xb')][_0x449b82[_0x4805('0x1a')]]))this[_0x4805('0xb')][_0x449b82[_0x4805('0x1a')]]={};logger[_0x4805('0x36')](_0x4805('0x72'),_0x449b82[_0x4805('0x1a')],_0x449b82[_0x4805('0x73')],_0x449b82[_0x4805('0x6f')]);var _0x492b84=_0x449b82['applicationdata'][_0x4805('0x74')]('=');var _0x58fafe=_0x492b84[0x0][_0x4805('0x75')](/cdr\((.*)\)/);if(_0x58fafe)this['applications'][_0x449b82[_0x4805('0x1a')]][_0x58fafe[0x1]]=_0x492b84[0x1];}}}}catch(_0x5ad346){logger[_0x4805('0x2e')]('[%s][voiceDialReport][newexten]',_0x449b82[_0x4805('0x1a')],util[_0x4805('0x1b')](_0x5ad346,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x4805('0x15')]['deleteChannelAfterTimeout']=function(_0x748e6a,_0x539f98=0x2710){if(this[_0x4805('0x8')][_0x748e6a]){setTimeout(()=>{delete this[_0x4805('0x8')][_0x748e6a];},_0x539f98);}};module[_0x4805('0x76')]=VoiceDialReport;
\ No newline at end of file