Built motion from commit b0a9a629.|2.6.33
[motion2.git] / server / services / ami / report / voiceDialReport.js
1 // *************************************************************************
2 // *                                                                       *
3 // * xCALLY Motion -  The Omnichannel Contact Center                       *
4 // * Copyright (c) Xenialab s.r.l. All Rights Reserved                     *
5 // *                                                                       *
6 // *************************************************************************
7 // *                                                                       *
8 // * Email: info@xcally.com                                                *
9 // * Website: https://www.xcally.com                                       *
10 // *                                                                       *
11 // *************************************************************************
12 // *                                                                       *
13 // * The SOFTWARE PRODUCT is protected by copyright laws and international *
14 // * copyright treaties, as well as other intellectual property laws and   *
15 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                         *
16 // *                                                                       *
17 // *************************************************************************
18 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;