Built motion from commit (unavailable).|2.0.82
[motion2.git] / server / services / ami / report / voiceAgentReport.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 _0x8b97=['originalposition','abandoned','custom:agentqueuecallerabandon','talktime','transfer','reason','complete','acw','agentcompleteAt','COMPLETE','clear','cause','answered_elsewhere','find','custom:agentansweredelsewhere','agentcomplete','custom:agentcomplete','HANGUP','custom:voiceAgentReport','syncHangup','cause-txt','recalculate','acwTimeout','ATTENDED','secondtransfereruniqueid','secondtransfererexten','transfererchannel','BLIND','transfereeuniqueid','extension','rtpaudioqos','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrttbridged','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberlastcall','memberpenalty','memberrealtime','variable','includes','exports','lodash','moment','util','../../../config/logger','ami','../ami','localhost','voiceQueues','agents','variables','syncAgentCalled','bind','syncAgentConnect','agentringnoanswer','queuecallerabandon','syncQueueCallerAbandon','syncAgentComplete','syncVarSet','hangup','attendedtransfer','syncAttendedTransfer','syncBlindTransfer','prototype','log','info','format','%s|%s','uniqueid','membername','queue','exten','calleridnum','addTime','add','seconds','YYYY-MM-DD\x20HH:mm:ss','diffTime','diff','interface','isNil','assign','user:save','destchannel','destcalleridnum','destcalleridname','accountcode','destaccountcode','channel','destuniqueid','context','priority','type','inbound','agent','called','emit','custom:agentcalled','user:%s','user:called','CALLED','stack','channels','connect','agentconnectAt','custom:agentconnect','CONNECT','error','syncAgentRingNoAnswer','ringtime','rejected','agentringnoanswerAt','agentcalledAt','custom:agentringnoanswer','RINGNOANSWER','holdtime','position'];(function(_0x214e10,_0x4b0dd8){var _0x26c859=function(_0x5d6b48){while(--_0x5d6b48){_0x214e10['push'](_0x214e10['shift']());}};_0x26c859(++_0x4b0dd8);}(_0x8b97,0x125));var _0x78b9=function(_0x4111b7,_0x4244f6){_0x4111b7=_0x4111b7-0x0;var _0x1eb5bb=_0x8b97[_0x4111b7];return _0x1eb5bb;};'use strict';var _=require(_0x78b9('0x0'));var moment=require(_0x78b9('0x1'));var util=require(_0x78b9('0x2'));var logger=require(_0x78b9('0x3'))(_0x78b9('0x4'));var ami=require(_0x78b9('0x5'));var io=require('socket.io-emitter')({'host':_0x78b9('0x6'),'port':0x18eb});function VoiceAgentReport(_0x65b696){this[_0x78b9('0x7')]=_0x65b696[_0x78b9('0x7')];this[_0x78b9('0x8')]=_0x65b696['agents'];this['channels']={};this[_0x78b9('0x9')]={};ami['on']('agentcalled',this[_0x78b9('0xa')][_0x78b9('0xb')](this));ami['on']('agentconnect',this[_0x78b9('0xc')][_0x78b9('0xb')](this));ami['on'](_0x78b9('0xd'),this['syncAgentRingNoAnswer'][_0x78b9('0xb')](this));ami['on'](_0x78b9('0xe'),this[_0x78b9('0xf')][_0x78b9('0xb')](this));ami['on']('agentcomplete',this[_0x78b9('0x10')][_0x78b9('0xb')](this));ami['on']('varset',this[_0x78b9('0x11')][_0x78b9('0xb')](this));ami['on'](_0x78b9('0x12'),this['syncHangup'][_0x78b9('0xb')](this));ami['on'](_0x78b9('0x13'),this[_0x78b9('0x14')][_0x78b9('0xb')](this));ami['on']('blindtransfer',this[_0x78b9('0x15')]['bind'](this));}VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0x17')]=function(_0x1d48a3,_0x4b5651){logger[_0x78b9('0x18')](util[_0x78b9('0x19')](_0x78b9('0x1a'),_0x1d48a3,[_0x4b5651[_0x78b9('0x1b')],_0x4b5651[_0x78b9('0x1c')],_0x4b5651[_0x78b9('0x1d')],_0x4b5651[_0x78b9('0x1e')],_0x4b5651[_0x78b9('0x1f')]]['join']('|')));};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0x20')]=function(_0x3c3276,_0x113c4f){return moment(_0x3c3276)[_0x78b9('0x21')](_0x113c4f,_0x78b9('0x22'))[_0x78b9('0x19')](_0x78b9('0x23'));};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0x24')]=function(_0x4f9920,_0x4a754e){return moment(_0x4f9920)[_0x78b9('0x25')](moment(_0x4a754e),'seconds');};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0xa')]=function(_0x1b676d){try{var _0x538b38=this[_0x78b9('0x8')][_0x1b676d[_0x78b9('0x26')]];if(!_[_0x78b9('0x27')](_0x538b38)){_0x538b38=_[_0x78b9('0x28')](_0x538b38,{'queue':_0x1b676d['queue'],'destconnectedlinenum':_0x1b676d[_0x78b9('0x1f')]});io['emit'](_0x78b9('0x29'),_0x538b38);}var _0x3f9e3a=this['channels'][_0x1b676d[_0x78b9('0x2a')]]={'agentcalledAt':moment()[_0x78b9('0x19')]('YYYY-MM-DD\x20HH:mm:ss'),'calleridnum':_0x1b676d[_0x78b9('0x1f')],'calleridname':_0x1b676d['calleridname'],'connectedlinenum':_0x1b676d[_0x78b9('0x2b')],'connectedlinename':_0x1b676d[_0x78b9('0x2c')],'accountcode':_0x1b676d[_0x78b9('0x2d')],'destaccountcode':_0x1b676d[_0x78b9('0x2e')],'channel':_0x1b676d[_0x78b9('0x2f')],'destchannel':_0x1b676d['destchannel'],'uniqueid':_0x1b676d[_0x78b9('0x1b')],'destuniqueid':_0x1b676d[_0x78b9('0x30')],'context':_0x1b676d[_0x78b9('0x31')],'exten':_0x1b676d[_0x78b9('0x1e')],'priority':_0x1b676d[_0x78b9('0x32')],'queue':_0x1b676d[_0x78b9('0x1d')],'type':this[_0x78b9('0x7')][_0x1b676d[_0x78b9('0x1d')]]?this['voiceQueues'][_0x1b676d[_0x78b9('0x1d')]][_0x78b9('0x33')]||_0x78b9('0x34'):_0x78b9('0x34'),'interface':_0x1b676d['interface'],'membername':_0x1b676d[_0x78b9('0x1c')],'agentconnect':![],'agentconnectAt':null,'holdtime':0x0,'ringtime':0x0,'agentcomplete':![],'agentcompleteAt':null,'talktime':0x0,'agentringnoanswer':![],'agentringnoanswerAt':null,'reason':_0x78b9('0x35'),'transfer':![],'transferAt':null,'transfertype':null,'transferuniqueid':null,'transfercontext':null,'transferextension':null,'position':null,'originalposition':null,'cause':'','cause-txt':'','UserId':this[_0x78b9('0x8')][_0x1b676d[_0x78b9('0x26')]]?this[_0x78b9('0x8')][_0x1b676d[_0x78b9('0x26')]]['id']:null,'lastevent':_0x78b9('0x36'),'agentacw':![],'acwtime':0x0,'variables':this[_0x78b9('0x9')][_0x1b676d[_0x78b9('0x2f')]]?this[_0x78b9('0x9')][_0x1b676d[_0x78b9('0x2f')]]:{}};ami[_0x78b9('0x37')](_0x78b9('0x38'),_0x3f9e3a);io['to'](util[_0x78b9('0x19')](_0x78b9('0x39'),_0x3f9e3a[_0x78b9('0x1c')]))['emit'](_0x78b9('0x3a'),_0x3f9e3a);this[_0x78b9('0x17')](_0x78b9('0x3b'),this['channels'][_0x1b676d['destchannel']]);}catch(_0x5b25fd){logger['error'](_0x5b25fd[_0x78b9('0x3c')]);}};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0xc')]=function(_0x2be9c2){try{var _0x4a52ca=this[_0x78b9('0x3d')][_0x2be9c2['destchannel']];if(!_['isNil'](_0x4a52ca)){_0x4a52ca=_[_0x78b9('0x28')](_0x4a52ca,{'holdtime':parseInt(_0x2be9c2['holdtime'],0xa),'ringtime':parseInt(_0x2be9c2['ringtime'],0xa),'agentconnect':!![],'lastevent':_0x78b9('0x3e')});_0x4a52ca[_0x78b9('0x3f')]=this['addTime'](_0x4a52ca['agentcalledAt'],_0x4a52ca['ringtime']);ami['emit'](_0x78b9('0x40'),_0x4a52ca);io['to'](util['format'](_0x78b9('0x39'),_0x4a52ca[_0x78b9('0x1c')]))[_0x78b9('0x37')]('user:agentconnect',_0x4a52ca);this[_0x78b9('0x17')](_0x78b9('0x41'),_0x4a52ca);}}catch(_0x91f720){logger[_0x78b9('0x42')](_0x91f720['stack']);}};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0x43')]=function(_0x2a0325){try{var _0x5cd115=this[_0x78b9('0x3d')][_0x2a0325[_0x78b9('0x2a')]];if(!_[_0x78b9('0x27')](_0x5cd115)){_0x5cd115=_[_0x78b9('0x28')](_0x5cd115,{'ringtime':parseInt(_0x2a0325[_0x78b9('0x44')],0xa)/0x3e8,'agentringnoanswer':!![],'reason':_0x78b9('0x45'),'lastevent':_0x78b9('0x45')});_0x5cd115[_0x78b9('0x46')]=this['addTime'](_0x5cd115[_0x78b9('0x47')],_0x5cd115[_0x78b9('0x44')]);ami[_0x78b9('0x37')](_0x78b9('0x48'),_0x5cd115);this['log'](_0x78b9('0x49'),_0x5cd115);}}catch(_0x5555f5){logger[_0x78b9('0x42')](_0x5555f5[_0x78b9('0x3c')]);}};VoiceAgentReport['prototype'][_0x78b9('0xf')]=function(_0x5d055c){try{for(var _0x22b9bc in this[_0x78b9('0x3d')]){var _0x28c297=this['channels'][_0x22b9bc];if(!_['isNil'](_0x28c297)&&_0x28c297[_0x78b9('0x2f')]==_0x5d055c['channel']){_0x28c297=_[_0x78b9('0x28')](_0x28c297,{'holdtime':parseInt(_0x5d055c[_0x78b9('0x4a')],0xa),'position':parseInt(_0x5d055c[_0x78b9('0x4b')],0xa),'originalposition':parseInt(_0x5d055c[_0x78b9('0x4c')],0xa),'agentringnoanswer':!![],'agentringnoanswerAt':moment()[_0x78b9('0x19')](_0x78b9('0x23')),'reason':_0x78b9('0x4d'),'lastevent':_0x78b9('0x4d')});ami['emit'](_0x78b9('0x4e'),_0x28c297);this[_0x78b9('0x17')]('CALLERABANDON',_0x28c297);}}}catch(_0x1a1bc1){logger[_0x78b9('0x42')](_0x1a1bc1[_0x78b9('0x3c')]);}};VoiceAgentReport['prototype'][_0x78b9('0x10')]=function(_0x16700c){try{var _0x39930d=this[_0x78b9('0x3d')][_0x16700c[_0x78b9('0x2a')]];if(!_[_0x78b9('0x27')](_0x39930d)){_0x39930d=_[_0x78b9('0x28')](_0x39930d,{'talktime':parseInt(_0x16700c[_0x78b9('0x4f')],0xa),'reason':_0x16700c['reason']==_0x78b9('0x50')?_0x78b9('0x35'):_0x16700c[_0x78b9('0x51')],'agentcomplete':!![],'lastevent':_0x78b9('0x52'),'agentacw':this[_0x78b9('0x7')][_0x39930d[_0x78b9('0x1d')]]&&this['voiceQueues'][_0x39930d[_0x78b9('0x1d')]]['acw']?!![]:![],'acwtime':this[_0x78b9('0x7')][_0x39930d['queue']]&&this['voiceQueues'][_0x39930d[_0x78b9('0x1d')]][_0x78b9('0x53')]?this[_0x78b9('0x7')][_0x39930d[_0x78b9('0x1d')]]['acwTimeout']:0x0});_0x39930d[_0x78b9('0x54')]=this[_0x78b9('0x20')](_0x39930d[_0x78b9('0x3f')],_0x39930d[_0x78b9('0x4f')]);this[_0x78b9('0x17')](_0x78b9('0x55'),_0x39930d);}}catch(_0x3c940c){logger[_0x78b9('0x42')](_0x3c940c[_0x78b9('0x3c')]);}};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0x56')]=function(_0xfce871){try{switch(_0xfce871[_0x78b9('0x57')]){case 0x1a:_0xfce871=_[_0x78b9('0x28')](_0xfce871,{'agentringnoanswer':!![],'reason':_0x78b9('0x58'),'lastevent':_0x78b9('0x58')});var _0x41c344=_[_0x78b9('0x59')](this[_0x78b9('0x3d')],{'channel':_0xfce871[_0x78b9('0x2f')],'agentconnect':!![]});if(!_['isNil'](_0x41c344)){_0xfce871=_[_0x78b9('0x28')](_0xfce871,{'agentringnoanswerAt':_0x41c344[_0x78b9('0x3f')],'answeredelsewheremembername':_0x41c344[_0x78b9('0x1c')],'answeredelsewheredestinationuniqueid':_0x41c344[_0x78b9('0x30')]});}ami[_0x78b9('0x37')](_0x78b9('0x5a'),_0xfce871);break;}if(_0xfce871[_0x78b9('0x5b')]){ami[_0x78b9('0x37')](_0x78b9('0x5c'),_0xfce871);io['to'](util[_0x78b9('0x19')](_0x78b9('0x39'),_0xfce871['membername']))['emit']('user:agentcomplete',_0xfce871);}this['log'](_0x78b9('0x5d'),_0xfce871);ami['emit'](_0x78b9('0x5e'),_0xfce871);if(this[_0x78b9('0x3d')][_0xfce871[_0x78b9('0x2a')]]){delete this[_0x78b9('0x3d')][_0xfce871[_0x78b9('0x2a')]];}}catch(_0x551d54){logger['error'](_0x551d54);}};VoiceAgentReport['prototype'][_0x78b9('0x5f')]=function(_0x2e3ab2){try{var _0x3e768f=this[_0x78b9('0x3d')][_0x2e3ab2[_0x78b9('0x2f')]];if(!_[_0x78b9('0x27')](_0x3e768f)){_0x3e768f=_['assign'](_0x3e768f,{'cause':parseInt(_0x2e3ab2[_0x78b9('0x57')],0xa),'cause-txt':_0x2e3ab2[_0x78b9('0x60')]});if(_0x3e768f[_0x78b9('0x61')]){_0x3e768f=_[_0x78b9('0x28')](_0x3e768f,{'agentcomplete':!![],'agentcompleteAt':moment()[_0x78b9('0x19')](_0x78b9('0x23')),'lastevent':_0x78b9('0x52'),'agentacw':this[_0x78b9('0x7')][_0x3e768f[_0x78b9('0x1d')]]&&this[_0x78b9('0x7')][_0x3e768f[_0x78b9('0x1d')]][_0x78b9('0x53')]?!![]:![],'acwtime':this[_0x78b9('0x7')][_0x3e768f[_0x78b9('0x1d')]]&&this[_0x78b9('0x7')][_0x3e768f[_0x78b9('0x1d')]][_0x78b9('0x53')]?this['voiceQueues'][_0x3e768f[_0x78b9('0x1d')]][_0x78b9('0x62')]:0x0});_0x3e768f[_0x78b9('0x4f')]=this[_0x78b9('0x24')](_0x3e768f[_0x78b9('0x54')],_0x3e768f[_0x78b9('0x3f')]);}var _0x112549=this['agents'][_0x3e768f[_0x78b9('0x26')]];if(!_[_0x78b9('0x27')](_0x112549)){_0x112549=_[_0x78b9('0x28')](_0x112549,{'queue':null,'destconnectedlinenum':null});io[_0x78b9('0x37')](_0x78b9('0x29'),_0x112549);}setTimeout(this[_0x78b9('0x56')][_0x78b9('0xb')](this,_0x3e768f),0x3e8);}if(this[_0x78b9('0x9')][_0x2e3ab2[_0x78b9('0x2f')]]){delete this[_0x78b9('0x9')][_0x2e3ab2[_0x78b9('0x2f')]];}}catch(_0x5b7a26){logger[_0x78b9('0x42')](_0x5b7a26[_0x78b9('0x3c')]);}};VoiceAgentReport['prototype']['syncAttendedTransfer']=function(_0x47478e){try{var _0x59c6e1=this[_0x78b9('0x3d')][_0x47478e['origtransfererchannel']];if(!_[_0x78b9('0x27')](_0x59c6e1)){_0x59c6e1=_[_0x78b9('0x28')](_0x59c6e1,{'transfer':!![],'transferAt':moment()[_0x78b9('0x19')](_0x78b9('0x23')),'transfertype':_0x78b9('0x63'),'agentcomplete':!![],'agentcompleteAt':moment()[_0x78b9('0x19')]('YYYY-MM-DD\x20HH:mm:ss'),'transferuniqueid':_0x47478e[_0x78b9('0x64')],'transfercontext':_0x47478e[_0x78b9('0x65')],'transferextension':_0x47478e['secondtransferercontext'],'reason':_0x78b9('0x50'),'lastevent':_0x78b9('0x52'),'agentacw':this[_0x78b9('0x7')][_0x59c6e1[_0x78b9('0x1d')]]&&this[_0x78b9('0x7')][_0x59c6e1[_0x78b9('0x1d')]]['acw']?!![]:![],'acwtime':this['voiceQueues'][_0x59c6e1[_0x78b9('0x1d')]]&&this['voiceQueues'][_0x59c6e1[_0x78b9('0x1d')]][_0x78b9('0x53')]?this['voiceQueues'][_0x59c6e1[_0x78b9('0x1d')]][_0x78b9('0x62')]:0x0});_0x59c6e1[_0x78b9('0x4f')]=this[_0x78b9('0x24')](_0x59c6e1[_0x78b9('0x54')],_0x59c6e1[_0x78b9('0x3f')]);this[_0x78b9('0x17')](_0x78b9('0x63'),_0x59c6e1);}if(!_[_0x78b9('0x27')](this[_0x78b9('0x3d')][_0x47478e['transfertargetchannel']])){this[_0x78b9('0x3d')][_0x47478e['transfertargetchannel']]['recalculate']=!![];}}catch(_0x4682cf){logger[_0x78b9('0x42')](_0x4682cf[_0x78b9('0x3c')]);}};VoiceAgentReport[_0x78b9('0x16')][_0x78b9('0x15')]=function(_0xd602f5){try{var _0x2189d1=this[_0x78b9('0x3d')][_0xd602f5[_0x78b9('0x66')]];if(!_[_0x78b9('0x27')](_0x2189d1)){_0x2189d1=_[_0x78b9('0x28')](_0x2189d1,{'transfer':!![],'transferAt':moment()[_0x78b9('0x19')](_0x78b9('0x23')),'transfertype':_0x78b9('0x67'),'transferuniqueid':_0xd602f5[_0x78b9('0x68')],'transfercontext':_0xd602f5['context'],'transferextension':_0xd602f5[_0x78b9('0x69')],'agentcomplete':!![],'agentcompleteAt':moment()[_0x78b9('0x19')](_0x78b9('0x23')),'reason':'transfer','lastevent':_0x78b9('0x52'),'agentacw':this[_0x78b9('0x7')][_0x2189d1[_0x78b9('0x1d')]]&&this['voiceQueues'][_0x2189d1[_0x78b9('0x1d')]][_0x78b9('0x53')]?!![]:![],'acwtime':this[_0x78b9('0x7')][_0x2189d1[_0x78b9('0x1d')]]&&this[_0x78b9('0x7')][_0x2189d1['queue']][_0x78b9('0x53')]?this['voiceQueues'][_0x2189d1[_0x78b9('0x1d')]][_0x78b9('0x62')]:0x0});_0x2189d1[_0x78b9('0x61')]=!![];this['log']('BLIND',_0x2189d1);}}catch(_0x473bdf){logger[_0x78b9('0x42')](_0x473bdf[_0x78b9('0x3c')]);}};VoiceAgentReport[_0x78b9('0x16')]['syncVarSet']=function(_0x5739be){var _0xcc56d=[_0x78b9('0x6a'),'rtpaudioqosbridged',_0x78b9('0x6b'),_0x78b9('0x6c'),_0x78b9('0x6d'),_0x78b9('0x6e'),'rtpaudioqosrtt',_0x78b9('0x6f'),'sipcallid',_0x78b9('0x70'),_0x78b9('0x71'),_0x78b9('0x72'),_0x78b9('0x73'),_0x78b9('0x74'),'memberinterface',_0x78b9('0x75'),_0x78b9('0x1c'),_0x78b9('0x76'),_0x78b9('0x77')];try{var _0x116bac=_['keys'](_0x5739be[_0x78b9('0x78')])[0x0];if(!_[_0x78b9('0x27')](_0x116bac)&&!_[_0x78b9('0x79')](_0xcc56d,_0x116bac)){if(!this[_0x78b9('0x9')][_0x5739be[_0x78b9('0x2f')]]){this[_0x78b9('0x9')][_0x5739be['channel']]={};}this[_0x78b9('0x9')][_0x5739be[_0x78b9('0x2f')]][_0x116bac]=_0x5739be['value'];}}catch(_0x185185){logger[_0x78b9('0x42')](_0x185185[_0x78b9('0x3c')]);}};module[_0x78b9('0x7a')]=VoiceAgentReport;