Built motion from commit (unavailable).|2.4.20
[motion2.git] / server / services / ami / report / voiceDialReport.js
index ceb655c..a4c3340 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x074b=['syncVarSet','hangup','syncHangup','prototype','isNotNull','isUndefined','emit','merge','uniqueid','format','YYYY-MM-DD\x20HH:mm:ss','channel','substring','lastIndexOf','omit','event','privilege','error','dialstatus','ANSWER','connectedlinenum','connectedlinename','lastevent','custom:dialconnect','voice:outbound','voice_outbound_channel:save','inspect','addVariable','keys','variable','value','outboundrouteid','variables','[syncVarSet][VoiceDialReport]','rtpaudioqos','rtpaudioqosloss','rtpaudioqosrtt','rtpaudioqosrttbridged','bridgepeer','bridgepvtcallid','memberdynamic','memberinterface','memberlastcall','membername','memberpenalty','isNil','endtime','duration','diff','starttime','complete','total','answertime','holdtime','seconds','sumHoldTime','billableseconds','custom:dialend','voice_outbound:save','info','[DEBUG]\x20Emit\x20voice_outbound_channel:remove\x20event','stringify','voice_outbound_channel:remove','[syncHangup][VoiceDialReport]','exports','lodash','moment','util','ioredis','../../../config/environment','../../../config/logger','ami','../ami','redis','defaults','localhost','socket.io-emitter','channels','outboundChannels','outbound','dialbegin','syncDialBegin','bind','dialend','syncDialEnd'];(function(_0x39b2be,_0x56fbee){var _0x510508=function(_0x4a0eb1){while(--_0x4a0eb1){_0x39b2be['push'](_0x39b2be['shift']());}};_0x510508(++_0x56fbee);}(_0x074b,0x195));var _0xb074=function(_0xfe0c27,_0x529ae9){_0xfe0c27=_0xfe0c27-0x0;var _0x493f0d=_0x074b[_0xfe0c27];return _0x493f0d;};'use strict';var _=require(_0xb074('0x0'));var moment=require(_0xb074('0x1'));var util=require(_0xb074('0x2'));var Redis=require(_0xb074('0x3'));var config=require(_0xb074('0x4'));var logger=require(_0xb074('0x5'))(_0xb074('0x6'));var ami=require(_0xb074('0x7'));config[_0xb074('0x8')]=_[_0xb074('0x9')](config['redis'],{'host':_0xb074('0xa'),'port':0x18eb});var io=require(_0xb074('0xb'))(new Redis(config['redis']));function VoiceDialReport(_0x1f8d92){this[_0xb074('0xc')]=_0x1f8d92[_0xb074('0xd')];this[_0xb074('0xe')]=_0x1f8d92[_0xb074('0xe')];this['variables']={};ami['on'](_0xb074('0xf'),this[_0xb074('0x10')][_0xb074('0x11')](this));ami['on'](_0xb074('0x12'),this[_0xb074('0x13')][_0xb074('0x11')](this));ami['on']('varset',this[_0xb074('0x14')]['bind'](this));ami['on'](_0xb074('0x15'),this[_0xb074('0x16')][_0xb074('0x11')](this));}VoiceDialReport[_0xb074('0x17')][_0xb074('0x18')]=function(_0x6e556e){return _0x6e556e!==null&&!_[_0xb074('0x19')](_0x6e556e);};VoiceDialReport[_0xb074('0x17')][_0xb074('0x1a')]=function(_0x1fd889,_0x4aab4d,_0x626bd0){io['to'](_0x1fd889)[_0xb074('0x1a')](_0x4aab4d,_0x626bd0);};VoiceDialReport['prototype'][_0xb074('0x10')]=function(_0x4ea6da){try{if(this['isNotNull'](_0x4ea6da)){if(this[_0xb074('0xc')][_0x4ea6da['uniqueid']]){_[_0xb074('0x1b')](this[_0xb074('0xc')][_0x4ea6da[_0xb074('0x1c')]],{'starttime':moment()[_0xb074('0x1d')](_0xb074('0x1e')),'lastevent':'called','interface':_0x4ea6da[_0xb074('0x1f')][_0xb074('0x20')](0x0,_0x4ea6da[_0xb074('0x1f')]['lastIndexOf']('-')),'membername':_0x4ea6da[_0xb074('0x1f')][_0xb074('0x20')](_0x4ea6da[_0xb074('0x1f')]['lastIndexOf']('/')+0x1,_0x4ea6da[_0xb074('0x1f')][_0xb074('0x21')]('-'))},_[_0xb074('0x22')](_0x4ea6da,[_0xb074('0x23'),_0xb074('0x24')]));this['emit']('voice:outbound','voice_outbound_channel:save',this['channels'][_0x4ea6da['uniqueid']]);ami[_0xb074('0x1a')]('custom:dialbegin',this[_0xb074('0xc')][_0x4ea6da['uniqueid']]);}}}catch(_0x50840d){logger[_0xb074('0x25')]('[syncDialBegin][VoiceDialReport]',util['inspect'](_0x50840d,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb074('0x17')][_0xb074('0x13')]=function(_0x293133){try{if(this[_0xb074('0x18')](_0x293133)){if(this[_0xb074('0xc')][_0x293133[_0xb074('0x1c')]]){this['channels'][_0x293133[_0xb074('0x1c')]][_0xb074('0x26')]=_0x293133[_0xb074('0x26')];if(_0x293133[_0xb074('0x26')]===_0xb074('0x27')){this['channels'][_0x293133[_0xb074('0x1c')]][_0xb074('0x28')]=_0x293133[_0xb074('0x28')];this['channels'][_0x293133['uniqueid']][_0xb074('0x29')]=_0x293133[_0xb074('0x29')];this[_0xb074('0xc')][_0x293133[_0xb074('0x1c')]]['answertime']=moment()[_0xb074('0x1d')](_0xb074('0x1e'));this[_0xb074('0xc')][_0x293133[_0xb074('0x1c')]][_0xb074('0x2a')]='connect';ami['emit'](_0xb074('0x2b'),this[_0xb074('0xc')][_0x293133[_0xb074('0x1c')]]);}this[_0xb074('0x1a')](_0xb074('0x2c'),_0xb074('0x2d'),this[_0xb074('0xc')][_0x293133[_0xb074('0x1c')]]);}}}catch(_0x27bb3b){logger[_0xb074('0x25')]('[syncDialEnd][VoiceDialReport]',util[_0xb074('0x2e')](_0x27bb3b,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb074('0x17')][_0xb074('0x14')]=function(_0x5b6e95){try{if(this['isNotNull'](_0x5b6e95)){this[_0xb074('0x2f')](_0x5b6e95[_0xb074('0x1c')],_[_0xb074('0x30')](_0x5b6e95[_0xb074('0x31')])[0x0],_0x5b6e95[_0xb074('0x32')]);if(this[_0xb074('0x18')](_0x5b6e95[_0xb074('0x31')])&&this[_0xb074('0x18')](_0x5b6e95['variable'][_0xb074('0x33')])){if(_[_0xb074('0x19')](this[_0xb074('0xc')][_0x5b6e95[_0xb074('0x1c')]])){this[_0xb074('0xc')][_0x5b6e95[_0xb074('0x1c')]]={'routeId':_0x5b6e95['value'],'variables':this[_0xb074('0x34')][_0x5b6e95['uniqueid']]};this['emit'](_0xb074('0x2c'),'voice_outbound_channel:save',this[_0xb074('0xc')][_0x5b6e95[_0xb074('0x1c')]]);}}}}catch(_0x475700){logger[_0xb074('0x25')](_0xb074('0x35'),util[_0xb074('0x2e')](_0x475700,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xb074('0x17')][_0xb074('0x2f')]=function(_0x1f1a69,_0x110d00,_0x1bb458){var _0x4751d5=[_0xb074('0x36'),'rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged',_0xb074('0x37'),'rtpaudioqoslossbridged',_0xb074('0x38'),_0xb074('0x39'),'sipcallid','sipuri',_0xb074('0x3a'),_0xb074('0x3b'),'membercalls',_0xb074('0x3c'),_0xb074('0x3d'),_0xb074('0x3e'),_0xb074('0x3f'),_0xb074('0x40'),'memberrealtime'];if(!_[_0xb074('0x41')](_0x110d00)&&!_['includes'](_0x4751d5,_0x110d00)){if(_[_0xb074('0x19')](this['variables'][_0x1f1a69])){this[_0xb074('0x34')][_0x1f1a69]={};}this[_0xb074('0x34')][_0x1f1a69][_0x110d00]=_0x1bb458;}};VoiceDialReport[_0xb074('0x17')][_0xb074('0x16')]=function(_0x4621be){try{if(this['isNotNull'](_0x4621be)){if(this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]){this['channels'][_0x4621be[_0xb074('0x1c')]][_0xb074('0x42')]=moment()['format'](_0xb074('0x1e'));this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x43')]=moment(this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x42')])[_0xb074('0x44')](this[_0xb074('0xc')][_0x4621be['uniqueid']][_0xb074('0x45')],'seconds');this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x2a')]=_0xb074('0x46');this[_0xb074('0xe')][_0xb074('0x47')]+=0x1;if(this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x48')]){this[_0xb074('0xe')]['answered']+=0x1;this['channels'][_0x4621be[_0xb074('0x1c')]][_0xb074('0x49')]=moment(this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x48')])['diff'](this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]['starttime'],'seconds');this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]['billableseconds']=moment(this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]['endtime'])[_0xb074('0x44')](this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]['answertime'],_0xb074('0x4a'));this[_0xb074('0xe')][_0xb074('0x4b')]+=this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x49')]||0x0;this[_0xb074('0xe')]['sumBillable']+=this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x4c')];}this[_0xb074('0xe')]['sumDuration']+=this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]][_0xb074('0x43')];ami[_0xb074('0x1a')]('custom:voiceDialReport',this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]);ami[_0xb074('0x1a')](_0xb074('0x4d'),this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]);this[_0xb074('0x1a')](_0xb074('0x2c'),_0xb074('0x4e'),this['outbound']);logger[_0xb074('0x4f')](_0xb074('0x50'),JSON[_0xb074('0x51')](this[_0xb074('0xc')][_0x4621be['uniqueid']]));this['emit']('voice:outbound',_0xb074('0x52'),this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]]);delete this[_0xb074('0xc')][_0x4621be[_0xb074('0x1c')]];}if(this[_0xb074('0x34')][_0x4621be[_0xb074('0x1c')]]){delete this[_0xb074('0x34')][_0x4621be['uniqueid']];}}}catch(_0x20bc21){logger[_0xb074('0x25')](_0xb074('0x53'),util[_0xb074('0x2e')](_0x20bc21,{'showHidden':![],'depth':null}));}};module[_0xb074('0x54')]=VoiceDialReport;
\ No newline at end of file
+var _0x285f=['rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrttbridged','sipcallid','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberlastcall','membername','memberpenalty','isNil','endtime','duration','diff','starttime','seconds','complete','total','answered','holdtime','billableseconds','sumHoldTime','sumBillable','sumDuration','voice_outbound:save','info','[DEBUG]\x20Emit\x20voice_outbound_channel:remove\x20event','stringify','voice_outbound_channel:remove','exports','lodash','moment','util','../../../config/environment','../../../config/logger','ami','../ami','redis','defaults','socket.io-emitter','channels','outboundChannels','outbound','dialbegin','syncDialBegin','bind','dialend','syncDialEnd','varset','syncHangup','isUndefined','emit','prototype','uniqueid','merge','format','YYYY-MM-DD\x20HH:mm:ss','called','channel','substring','lastIndexOf','omit','event','voice:outbound','voice_outbound_channel:save','custom:dialbegin','error','[syncDialBegin][VoiceDialReport]','inspect','isNotNull','dialstatus','ANSWER','connectedlinenum','connectedlinename','answertime','lastevent','connect','syncVarSet','addVariable','keys','variable','value','outboundrouteid','variables','rtpaudioqos','rtpaudioqosbridged','rtpaudioqosjitter','rtpaudioqosjitterbridged'];(function(_0xdb951d,_0x1dc42b){var _0x5e789e=function(_0x1056cd){while(--_0x1056cd){_0xdb951d['push'](_0xdb951d['shift']());}};_0x5e789e(++_0x1dc42b);}(_0x285f,0x18d));var _0xf285=function(_0x204bf5,_0xc18559){_0x204bf5=_0x204bf5-0x0;var _0x30081e=_0x285f[_0x204bf5];return _0x30081e;};'use strict';var _=require(_0xf285('0x0'));var moment=require(_0xf285('0x1'));var util=require(_0xf285('0x2'));var Redis=require('ioredis');var config=require(_0xf285('0x3'));var logger=require(_0xf285('0x4'))(_0xf285('0x5'));var ami=require(_0xf285('0x6'));config[_0xf285('0x7')]=_[_0xf285('0x8')](config['redis'],{'host':'localhost','port':0x18eb});var io=require(_0xf285('0x9'))(new Redis(config[_0xf285('0x7')]));function VoiceDialReport(_0x4b586f){this[_0xf285('0xa')]=_0x4b586f[_0xf285('0xb')];this[_0xf285('0xc')]=_0x4b586f[_0xf285('0xc')];this['variables']={};ami['on'](_0xf285('0xd'),this[_0xf285('0xe')][_0xf285('0xf')](this));ami['on'](_0xf285('0x10'),this[_0xf285('0x11')][_0xf285('0xf')](this));ami['on'](_0xf285('0x12'),this['syncVarSet'][_0xf285('0xf')](this));ami['on']('hangup',this[_0xf285('0x13')][_0xf285('0xf')](this));}VoiceDialReport['prototype']['isNotNull']=function(_0x50f625){return _0x50f625!==null&&!_[_0xf285('0x14')](_0x50f625);};VoiceDialReport['prototype'][_0xf285('0x15')]=function(_0x556f58,_0x43e201,_0xcfea45){io['to'](_0x556f58)[_0xf285('0x15')](_0x43e201,_0xcfea45);};VoiceDialReport[_0xf285('0x16')][_0xf285('0xe')]=function(_0x1d1342){try{if(this['isNotNull'](_0x1d1342)){if(this[_0xf285('0xa')][_0x1d1342[_0xf285('0x17')]]){_[_0xf285('0x18')](this[_0xf285('0xa')][_0x1d1342[_0xf285('0x17')]],{'starttime':moment()[_0xf285('0x19')](_0xf285('0x1a')),'lastevent':_0xf285('0x1b'),'interface':_0x1d1342[_0xf285('0x1c')][_0xf285('0x1d')](0x0,_0x1d1342[_0xf285('0x1c')][_0xf285('0x1e')]('-')),'membername':_0x1d1342[_0xf285('0x1c')][_0xf285('0x1d')](_0x1d1342[_0xf285('0x1c')][_0xf285('0x1e')]('/')+0x1,_0x1d1342['channel'][_0xf285('0x1e')]('-'))},_[_0xf285('0x1f')](_0x1d1342,[_0xf285('0x20'),'privilege']));this[_0xf285('0x15')](_0xf285('0x21'),_0xf285('0x22'),this['channels'][_0x1d1342['uniqueid']]);ami['emit'](_0xf285('0x23'),this[_0xf285('0xa')][_0x1d1342[_0xf285('0x17')]]);}}}catch(_0x5d38ec){logger[_0xf285('0x24')](_0xf285('0x25'),util[_0xf285('0x26')](_0x5d38ec,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xf285('0x16')][_0xf285('0x11')]=function(_0x4196a8){try{if(this[_0xf285('0x27')](_0x4196a8)){if(this['channels'][_0x4196a8[_0xf285('0x17')]]){this[_0xf285('0xa')][_0x4196a8[_0xf285('0x17')]][_0xf285('0x28')]=_0x4196a8[_0xf285('0x28')];if(_0x4196a8['dialstatus']===_0xf285('0x29')){this[_0xf285('0xa')][_0x4196a8['uniqueid']][_0xf285('0x2a')]=_0x4196a8[_0xf285('0x2a')];this[_0xf285('0xa')][_0x4196a8[_0xf285('0x17')]][_0xf285('0x2b')]=_0x4196a8[_0xf285('0x2b')];this[_0xf285('0xa')][_0x4196a8[_0xf285('0x17')]][_0xf285('0x2c')]=moment()[_0xf285('0x19')](_0xf285('0x1a'));this['channels'][_0x4196a8[_0xf285('0x17')]][_0xf285('0x2d')]=_0xf285('0x2e');ami[_0xf285('0x15')]('custom:dialconnect',this[_0xf285('0xa')][_0x4196a8[_0xf285('0x17')]]);}this['emit'](_0xf285('0x21'),_0xf285('0x22'),this[_0xf285('0xa')][_0x4196a8[_0xf285('0x17')]]);}}}catch(_0x48327c){logger[_0xf285('0x24')]('[syncDialEnd][VoiceDialReport]',util[_0xf285('0x26')](_0x48327c,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xf285('0x16')][_0xf285('0x2f')]=function(_0x4651e0){try{if(this[_0xf285('0x27')](_0x4651e0)){this[_0xf285('0x30')](_0x4651e0[_0xf285('0x17')],_[_0xf285('0x31')](_0x4651e0[_0xf285('0x32')])[0x0],_0x4651e0[_0xf285('0x33')]);if(this['isNotNull'](_0x4651e0[_0xf285('0x32')])&&this[_0xf285('0x27')](_0x4651e0['variable'][_0xf285('0x34')])){if(_[_0xf285('0x14')](this['channels'][_0x4651e0[_0xf285('0x17')]])){this[_0xf285('0xa')][_0x4651e0[_0xf285('0x17')]]={'routeId':_0x4651e0[_0xf285('0x33')],'variables':this[_0xf285('0x35')][_0x4651e0['uniqueid']]};this[_0xf285('0x15')](_0xf285('0x21'),_0xf285('0x22'),this[_0xf285('0xa')][_0x4651e0[_0xf285('0x17')]]);}}}}catch(_0x5943ea){logger['error']('[syncVarSet][VoiceDialReport]',util[_0xf285('0x26')](_0x5943ea,{'showHidden':![],'depth':null}));}};VoiceDialReport[_0xf285('0x16')][_0xf285('0x30')]=function(_0x9d0678,_0x35d357,_0x4a32bc){var _0x1089a6=[_0xf285('0x36'),_0xf285('0x37'),_0xf285('0x38'),_0xf285('0x39'),_0xf285('0x3a'),_0xf285('0x3b'),'rtpaudioqosrtt',_0xf285('0x3c'),_0xf285('0x3d'),_0xf285('0x3e'),_0xf285('0x3f'),_0xf285('0x40'),_0xf285('0x41'),_0xf285('0x42'),_0xf285('0x43'),_0xf285('0x44'),_0xf285('0x45'),_0xf285('0x46'),'memberrealtime'];if(!_[_0xf285('0x47')](_0x35d357)&&!_['includes'](_0x1089a6,_0x35d357)){if(_[_0xf285('0x14')](this[_0xf285('0x35')][_0x9d0678])){this[_0xf285('0x35')][_0x9d0678]={};}this[_0xf285('0x35')][_0x9d0678][_0x35d357]=_0x4a32bc;}};VoiceDialReport[_0xf285('0x16')][_0xf285('0x13')]=function(_0x2abc5d){try{if(this[_0xf285('0x27')](_0x2abc5d)){if(this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]]){this['channels'][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x48')]=moment()[_0xf285('0x19')]('YYYY-MM-DD\x20HH:mm:ss');this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x49')]=moment(this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]]['endtime'])[_0xf285('0x4a')](this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x4b')],_0xf285('0x4c'));this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x2d')]=_0xf285('0x4d');this[_0xf285('0xc')][_0xf285('0x4e')]+=0x1;if(this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x2c')]){this[_0xf285('0xc')][_0xf285('0x4f')]+=0x1;this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x50')]=moment(this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x2c')])[_0xf285('0x4a')](this[_0xf285('0xa')][_0x2abc5d['uniqueid']]['starttime'],_0xf285('0x4c'));this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x51')]=moment(this['channels'][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x48')])[_0xf285('0x4a')](this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x2c')],_0xf285('0x4c'));this[_0xf285('0xc')][_0xf285('0x52')]+=this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x50')]||0x0;this['outbound'][_0xf285('0x53')]+=this['channels'][_0x2abc5d['uniqueid']][_0xf285('0x51')];}this[_0xf285('0xc')][_0xf285('0x54')]+=this['channels'][_0x2abc5d[_0xf285('0x17')]][_0xf285('0x49')];ami[_0xf285('0x15')]('custom:voiceDialReport',this['channels'][_0x2abc5d['uniqueid']]);ami[_0xf285('0x15')]('custom:dialend',this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]]);this['emit'](_0xf285('0x21'),_0xf285('0x55'),this[_0xf285('0xc')]);logger[_0xf285('0x56')](_0xf285('0x57'),JSON[_0xf285('0x58')](this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]]));this[_0xf285('0x15')](_0xf285('0x21'),_0xf285('0x59'),this[_0xf285('0xa')][_0x2abc5d['uniqueid']]);delete this[_0xf285('0xa')][_0x2abc5d[_0xf285('0x17')]];}if(this[_0xf285('0x35')][_0x2abc5d['uniqueid']]){delete this[_0xf285('0x35')][_0x2abc5d['uniqueid']];}}}catch(_0x9420c3){logger[_0xf285('0x24')]('[syncHangup][VoiceDialReport]',util[_0xf285('0x26')](_0x9420c3,{'showHidden':![],'depth':null}));}};module[_0xf285('0x5a')]=VoiceDialReport;
\ No newline at end of file