Built motion from commit 953226e6.|2.6.32
[motion2.git] / server / services / ami / report / voiceDialReport.js
index ff2c524..70e8758 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xe0c9=['variables','dialbegin','syncDialBegin','bind','dialend','syncDialEnd','varset','syncVarSet','hangup','prototype','isNotNull','isUndefined','emit','debug','[%s][voiceDialReport][dialbegin]\x20event:','uniqueid','inspect','merge','channels','format','YYYY-MM-DD\x20HH:mm:ss','called','channel','substring','lastIndexOf','event','[%s][voiceDialReport][dialbegin]\x20agent:%s\x20interface:%s\x20lastevent:called','membername','voice:outbound','voice_outbound_channel:save','custom:dialbegin','error','[%s][voiceDialReport][dialend]\x20event:','dialstatus','ANSWER','connectedlinenum','connectedlinename','lastevent','connect','info','[%s][voiceDialReport][dialend]\x20agent:%s\x20lastevent:connect','custom:dialconnect','[%s][voiceDialReport][dialend]\x20sending\x20voice_outbound_channel:save\x20event:','[%s][voiceDialReport][dialend]','variable','value','outboundrouteid','voice','[%s][voiceDialReport][varset]\x20outboundrouteid:%s\x20variable:%s\x20value:%s','keys','[%s][voiceDialReport][varset]\x20sending\x20voice_outbound_channel:save\x20event:','[%s][voiceDialReport][varset]','addVariable','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','sipcallid','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberinterface','memberlastcall','memberpenalty','memberrealtime','isNil','includes','syncHangup','[%s][voiceDialReport][hangup]\x20event:','cause-txt','duration','diff','starttime','complete','total','answertime','holdtime','seconds','billableseconds','endtime','sumDuration','custom:voiceDialReport','[%s][voiceDialReport][hangup]\x20sending\x20dialend\x20event:','custom:dialend','[%s][voiceDialReport][hangup]\x20sending\x20voice_outbound:save\x20event:','[DEBUG]\x20Emit\x20voice_outbound_channel:remove\x20event','stringify','deleteChannelAfterTimeout','linkedid','destuniqueid','[%s][voiceDialReport][hangup]','syncNewExten','application','toLowerCase','set','applicationdata','cdr(','[%s][voiceDialReport][newexten]\x20application:%s\x20appdata:%s','split','match','[%s][voiceDialReport][newexten]','exports','moment','util','ioredis','../ami','redis','localhost','socket.io-emitter','outboundChannels','outbound','applications'];(function(_0x372515,_0xdd11f){var _0xa3bf4e=function(_0x212cc8){while(--_0x212cc8){_0x372515['push'](_0x372515['shift']());}};_0xa3bf4e(++_0xdd11f);}(_0xe0c9,0x1ba));var _0x9e0c=function(_0x2efd4b,_0x30fc7f){_0x2efd4b=_0x2efd4b-0x0;var _0x7e70b7=_0xe0c9[_0x2efd4b];return _0x7e70b7;};'use strict';var _=require('lodash');var moment=require(_0x9e0c('0x0'));var util=require(_0x9e0c('0x1'));var Redis=require(_0x9e0c('0x2'));var config=require('../../../config/environment');var logger=require('../../../config/logger')('ami');var ami=require(_0x9e0c('0x3'));config[_0x9e0c('0x4')]=_['defaults'](config['redis'],{'host':_0x9e0c('0x5'),'port':0x18eb});var io=require(_0x9e0c('0x6'))(new Redis(config['redis']));function VoiceDialReport(_0x5427f2){this['channels']=_0x5427f2[_0x9e0c('0x7')];this[_0x9e0c('0x8')]=_0x5427f2[_0x9e0c('0x8')];this[_0x9e0c('0x9')]={};this[_0x9e0c('0xa')]={};ami['on'](_0x9e0c('0xb'),this[_0x9e0c('0xc')][_0x9e0c('0xd')](this));ami['on'](_0x9e0c('0xe'),this[_0x9e0c('0xf')][_0x9e0c('0xd')](this));ami['on'](_0x9e0c('0x10'),this[_0x9e0c('0x11')][_0x9e0c('0xd')](this));ami['on'](_0x9e0c('0x12'),this['syncHangup'][_0x9e0c('0xd')](this));}VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0x14')]=function(_0x52fb8f){return _0x52fb8f!==null&&!_[_0x9e0c('0x15')](_0x52fb8f);};VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0x16')]=function(_0x5cd2a1,_0x28c790,_0x5d6f8a){io['to'](_0x5cd2a1)[_0x9e0c('0x16')](_0x28c790,_0x5d6f8a);};VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0xc')]=function(_0x337403){try{if(this[_0x9e0c('0x14')](_0x337403)){logger[_0x9e0c('0x17')](_0x9e0c('0x18'),_0x337403[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x337403,{'showHidden':![],'depth':null}));if(this['channels'][_0x337403[_0x9e0c('0x19')]]){_[_0x9e0c('0x1b')](this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]],{'starttime':moment()[_0x9e0c('0x1d')](_0x9e0c('0x1e')),'lastevent':_0x9e0c('0x1f'),'interface':_0x337403[_0x9e0c('0x20')][_0x9e0c('0x21')](0x0,_0x337403['channel'][_0x9e0c('0x22')]('-')),'membername':_0x337403[_0x9e0c('0x20')][_0x9e0c('0x21')](_0x337403[_0x9e0c('0x20')]['lastIndexOf']('/')+0x1,_0x337403[_0x9e0c('0x20')][_0x9e0c('0x22')]('-'))},_['omit'](_0x337403,[_0x9e0c('0x23'),'privilege']));logger['info'](_0x9e0c('0x24'),_0x337403[_0x9e0c('0x19')],this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]][_0x9e0c('0x25')],this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]]['interface']);logger['debug']('[%s][voiceDialReport][dialbegin]\x20sending\x20voice_outbound_channel:save\x20event:',_0x337403[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));if(this['applications'][_0x337403['uniqueid']])_['merge'](this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]],this['applications'][_0x337403[_0x9e0c('0x19')]]);this[_0x9e0c('0x16')](_0x9e0c('0x26'),_0x9e0c('0x27'),this['channels'][_0x337403['uniqueid']]);logger[_0x9e0c('0x17')]('[%s][voiceDialReport][dialbegin]\x20sending\x20dialbegin\x20event:',_0x337403['uniqueid'],util['inspect'](this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));ami[_0x9e0c('0x16')](_0x9e0c('0x28'),this[_0x9e0c('0x1c')][_0x337403[_0x9e0c('0x19')]]);}}}catch(_0xdad5f7){logger[_0x9e0c('0x29')]('[%s][voiceDialReport][dialbegin]',_0x337403['uniqueid'],util['inspect'](_0xdad5f7,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x9e0c('0x13')]['syncDialEnd']=function(_0x3ea479){try{if(this[_0x9e0c('0x14')](_0x3ea479)){logger[_0x9e0c('0x17')](_0x9e0c('0x2a'),_0x3ea479[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x3ea479,{'showHidden':![],'depth':null}));if(this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]]){this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]][_0x9e0c('0x2b')]=_0x3ea479['dialstatus'];if(_0x3ea479[_0x9e0c('0x2b')]===_0x9e0c('0x2c')){this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]][_0x9e0c('0x2d')]=_0x3ea479['connectedlinenum'];this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]][_0x9e0c('0x2e')]=_0x3ea479[_0x9e0c('0x2e')];this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]]['answertime']=moment()[_0x9e0c('0x1d')](_0x9e0c('0x1e'));this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]][_0x9e0c('0x2f')]=_0x9e0c('0x30');logger[_0x9e0c('0x31')](_0x9e0c('0x32'),_0x3ea479['uniqueid'],_0x3ea479[_0x9e0c('0x20')][_0x9e0c('0x21')](_0x3ea479[_0x9e0c('0x20')][_0x9e0c('0x22')]('/')+0x1,_0x3ea479[_0x9e0c('0x20')]['lastIndexOf']('-')));logger[_0x9e0c('0x17')]('[%s][voiceDialReport][dialend]\x20sending\x20dialconnect\x20event:',_0x3ea479[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));ami[_0x9e0c('0x16')](_0x9e0c('0x33'),this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]]);}logger['debug'](_0x9e0c('0x34'),_0x3ea479[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this['channels'][_0x3ea479['uniqueid']],{'showHidden':![],'depth':null}));this[_0x9e0c('0x16')](_0x9e0c('0x26'),_0x9e0c('0x27'),this[_0x9e0c('0x1c')][_0x3ea479[_0x9e0c('0x19')]]);}}}catch(_0x190480){logger[_0x9e0c('0x29')](_0x9e0c('0x35'),_0x3ea479[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x190480,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0x11')]=function(_0x5cdda6){try{if(this[_0x9e0c('0x14')](_0x5cdda6)){logger['debug']('[%s][voiceDialReport][varset]\x20event:',_0x5cdda6[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x5cdda6,{'showHidden':![],'depth':null}));this['addVariable'](_0x5cdda6['uniqueid'],_['keys'](_0x5cdda6[_0x9e0c('0x36')])[0x0],_0x5cdda6[_0x9e0c('0x37')]);if(this['isNotNull'](_0x5cdda6[_0x9e0c('0x36')])&&this['isNotNull'](_0x5cdda6['variable'][_0x9e0c('0x38')])){if(_['isUndefined'](this[_0x9e0c('0x1c')][_0x5cdda6[_0x9e0c('0x19')]])){this[_0x9e0c('0x1c')][_0x5cdda6['uniqueid']]={'routeId':_0x5cdda6[_0x9e0c('0x37')],'variables':this[_0x9e0c('0xa')][_0x5cdda6[_0x9e0c('0x19')]],'motionChannel':_0x9e0c('0x39')};logger[_0x9e0c('0x31')](_0x9e0c('0x3a'),_0x5cdda6[_0x9e0c('0x19')],_0x5cdda6[_0x9e0c('0x36')][_0x9e0c('0x38')],_[_0x9e0c('0x3b')](_0x5cdda6[_0x9e0c('0x36')])[0x0],_0x5cdda6[_0x9e0c('0x37')]);logger[_0x9e0c('0x17')](_0x9e0c('0x3c'),_0x5cdda6[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this['channels'][_0x5cdda6['uniqueid']],{'showHidden':![],'depth':null}));this['emit'](_0x9e0c('0x26'),_0x9e0c('0x27'),this[_0x9e0c('0x1c')][_0x5cdda6[_0x9e0c('0x19')]]);}}}}catch(_0x162162){logger[_0x9e0c('0x29')](_0x9e0c('0x3d'),_0x5cdda6[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x162162,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0x3e')]=function(_0x5dbf5a,_0x566c11,_0x3fec63){var _0x31ab34=['rtpaudioqos','rtpaudioqosbridged',_0x9e0c('0x3f'),_0x9e0c('0x40'),'rtpaudioqosloss','rtpaudioqoslossbridged',_0x9e0c('0x41'),_0x9e0c('0x42'),_0x9e0c('0x43'),_0x9e0c('0x44'),_0x9e0c('0x45'),_0x9e0c('0x46'),_0x9e0c('0x47'),'memberdynamic',_0x9e0c('0x48'),_0x9e0c('0x49'),_0x9e0c('0x25'),_0x9e0c('0x4a'),_0x9e0c('0x4b')];if(!_[_0x9e0c('0x4c')](_0x566c11)&&!_[_0x9e0c('0x4d')](_0x31ab34,_0x566c11)){if(_[_0x9e0c('0x15')](this[_0x9e0c('0xa')][_0x5dbf5a])){this[_0x9e0c('0xa')][_0x5dbf5a]={};}this[_0x9e0c('0xa')][_0x5dbf5a][_0x566c11]=_0x3fec63;}};VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0x4e')]=function(_0x166dbb){try{if(this[_0x9e0c('0x14')](_0x166dbb)){logger['debug'](_0x9e0c('0x4f'),_0x166dbb[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x166dbb,{'showHidden':![],'depth':null}));if(this['channels'][_0x166dbb[_0x9e0c('0x19')]]){logger[_0x9e0c('0x31')]('[%s][voiceDialReport][hangup]\x20reason:%s\x20lasteevent:complete',_0x166dbb[_0x9e0c('0x19')],_0x166dbb[_0x9e0c('0x50')]);this[_0x9e0c('0x1c')][_0x166dbb['uniqueid']]['endtime']=moment()[_0x9e0c('0x1d')](_0x9e0c('0x1e'));this[_0x9e0c('0x1c')][_0x166dbb['uniqueid']][_0x9e0c('0x51')]=moment(this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]]['endtime'])[_0x9e0c('0x52')](this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x53')],'seconds');this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x2f')]=_0x9e0c('0x54');this[_0x9e0c('0x8')][_0x9e0c('0x55')]+=0x1;if(this['channels'][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x56')]){this[_0x9e0c('0x8')]['answered']+=0x1;this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x57')]=moment(this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x56')])[_0x9e0c('0x52')](this['channels'][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x53')],_0x9e0c('0x58'));this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x59')]=moment(this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x5a')])[_0x9e0c('0x52')](this['channels'][_0x166dbb['uniqueid']][_0x9e0c('0x56')],_0x9e0c('0x58'));this[_0x9e0c('0x8')]['sumHoldTime']+=this['channels'][_0x166dbb['uniqueid']][_0x9e0c('0x57')]||0x0;this[_0x9e0c('0x8')]['sumBillable']+=this['channels'][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x59')];}this['outbound'][_0x9e0c('0x5b')]+=this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]][_0x9e0c('0x51')];logger['debug']('[%s][voiceDialReport][hangup]\x20sending\x20voiceDialReport\x20event:',_0x166dbb[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));ami[_0x9e0c('0x16')](_0x9e0c('0x5c'),this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]]);logger[_0x9e0c('0x17')](_0x9e0c('0x5d'),_0x166dbb[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));ami[_0x9e0c('0x16')](_0x9e0c('0x5e'),this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]]);logger[_0x9e0c('0x17')](_0x9e0c('0x5f'),_0x166dbb[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));this[_0x9e0c('0x16')](_0x9e0c('0x26'),'voice_outbound:save',this[_0x9e0c('0x8')]);logger[_0x9e0c('0x31')](_0x9e0c('0x60'),JSON[_0x9e0c('0x61')](this['channels'][_0x166dbb['uniqueid']]));logger[_0x9e0c('0x17')]('[%s][voiceDialReport][hangup]\x20sending\x20voice_outbound_channel:remove\x20event:',_0x166dbb['uniqueid'],util[_0x9e0c('0x1a')](this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x19')]],{'showHidden':![],'depth':null}));this['emit']('voice:outbound','voice_outbound_channel:remove',this[_0x9e0c('0x1c')][_0x166dbb['uniqueid']]);this[_0x9e0c('0x62')](_0x166dbb[_0x9e0c('0x19')]);}else if(this[_0x9e0c('0x1c')][_0x166dbb['linkedid']]){this[_0x9e0c('0x1c')][_0x166dbb['linkedid']][_0x9e0c('0x19')]=this[_0x9e0c('0x1c')][_0x166dbb[_0x9e0c('0x63')]][_0x9e0c('0x64')];}if(this[_0x9e0c('0xa')][_0x166dbb[_0x9e0c('0x19')]]){delete this[_0x9e0c('0xa')][_0x166dbb['uniqueid']];}}}catch(_0x3514d3){logger[_0x9e0c('0x29')](_0x9e0c('0x65'),_0x166dbb[_0x9e0c('0x19')],util[_0x9e0c('0x1a')](_0x3514d3,{'showHidden':![],'depth':null}));}};VoiceDialReport['prototype'][_0x9e0c('0x66')]=function(_0x190b56){try{if(this[_0x9e0c('0x14')](_0x190b56)){logger[_0x9e0c('0x17')]('[%s][voiceDialReport][newexten]\x20event:',_0x190b56['uniqueid'],util[_0x9e0c('0x1a')](_0x190b56,{'showHidden':![],'depth':null}));if(_0x190b56[_0x9e0c('0x67')][_0x9e0c('0x68')]()===_0x9e0c('0x69')){_0x190b56['applicationdata']=(_0x190b56['appdata']||_0x190b56['applicationdata'])[_0x9e0c('0x68')]();if(_['startsWith'](_0x190b56[_0x9e0c('0x6a')],_0x9e0c('0x6b'))){if(_[_0x9e0c('0x15')](this[_0x9e0c('0x9')][_0x190b56['uniqueid']]))this[_0x9e0c('0x9')][_0x190b56['uniqueid']]={};logger[_0x9e0c('0x31')](_0x9e0c('0x6c'),_0x190b56[_0x9e0c('0x19')],_0x190b56['application'],_0x190b56[_0x9e0c('0x6a')]);var _0x107270=_0x190b56[_0x9e0c('0x6a')][_0x9e0c('0x6d')]('=');var _0x3aa50c=_0x107270[0x0][_0x9e0c('0x6e')](/cdr\((.*)\)/);if(_0x3aa50c)this[_0x9e0c('0x9')][_0x190b56[_0x9e0c('0x19')]][_0x3aa50c[0x1]]=_0x107270[0x1];}}}}catch(_0x26bab8){logger['error'](_0x9e0c('0x6f'),_0x190b56[_0x9e0c('0x19')],util['inspect'](_0x26bab8,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0x9e0c('0x13')][_0x9e0c('0x62')]=function(_0x50d978,_0x1e0ea6=0x2710){if(this[_0x9e0c('0x1c')][_0x50d978]){setTimeout(()=>{delete this[_0x9e0c('0x1c')][_0x50d978];},_0x1e0ea6);}};module[_0x9e0c('0x70')]=VoiceDialReport;
\ No newline at end of file
+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