Built motion from commit (unavailable).|2.0.80
[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 _0x035a=['agentringnoanswerAt','custom:agentringnoanswer','RINGNOANSWER','syncQueueCallerAbandon','position','originalposition','abandoned','custom:agentqueuecallerabandon','CALLERABANDON','syncAgentComplete','talktime','reason','complete','acw','acwTimeout','agentcompleteAt','clear','cause','answered_elsewhere','custom:agentansweredelsewhere','custom:voiceAgentReport','syncHangup','recalculate','origtransfererchannel','ATTENDED','secondtransfereruniqueid','secondtransfererexten','transfer','transfertargetchannel','transfererchannel','BLIND','transfereeuniqueid','extension','syncVarSet','rtpaudioqos','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqoslossbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberlastcall','memberpenalty','keys','variable','includes','value','lodash','moment','util','../../../config/logger','../ami','voiceQueues','agents','variables','agentcalled','bind','agentconnect','syncAgentConnect','agentringnoanswer','queuecallerabandon','agentcomplete','hangup','attendedtransfer','syncAttendedTransfer','syncBlindTransfer','prototype','info','format','%s|%s','membername','queue','exten','calleridnum','join','addTime','add','seconds','YYYY-MM-DD\x20HH:mm:ss','diffTime','syncAgentCalled','interface','isNil','assign','emit','user:save','channels','destchannel','destcalleridnum','destcalleridname','accountcode','channel','uniqueid','destuniqueid','context','priority','type','inbound','agent','called','custom:agentcalled','user:called','log','stack','holdtime','agentconnectAt','agentcalledAt','ringtime','user:%s','user:agentconnect','CONNECT','error','syncAgentRingNoAnswer','rejected'];(function(_0x1d58e7,_0x2c1ae0){var _0x334db1=function(_0x3e8f76){while(--_0x3e8f76){_0x1d58e7['push'](_0x1d58e7['shift']());}};_0x334db1(++_0x2c1ae0);}(_0x035a,0x191));var _0xa035=function(_0x3537d9,_0xf5625d){_0x3537d9=_0x3537d9-0x0;var _0x1afbe8=_0x035a[_0x3537d9];return _0x1afbe8;};'use strict';var _=require(_0xa035('0x0'));var moment=require(_0xa035('0x1'));var util=require(_0xa035('0x2'));var logger=require(_0xa035('0x3'))('ami');var ami=require(_0xa035('0x4'));var io=require('socket.io-emitter')({'host':'localhost','port':0x18eb});function VoiceAgentReport(_0x88905b){this[_0xa035('0x5')]=_0x88905b[_0xa035('0x5')];this[_0xa035('0x6')]=_0x88905b[_0xa035('0x6')];this['channels']={};this[_0xa035('0x7')]={};ami['on'](_0xa035('0x8'),this['syncAgentCalled'][_0xa035('0x9')](this));ami['on'](_0xa035('0xa'),this[_0xa035('0xb')][_0xa035('0x9')](this));ami['on'](_0xa035('0xc'),this['syncAgentRingNoAnswer']['bind'](this));ami['on'](_0xa035('0xd'),this['syncQueueCallerAbandon'][_0xa035('0x9')](this));ami['on'](_0xa035('0xe'),this['syncAgentComplete']['bind'](this));ami['on']('varset',this['syncVarSet'][_0xa035('0x9')](this));ami['on'](_0xa035('0xf'),this['syncHangup']['bind'](this));ami['on'](_0xa035('0x10'),this[_0xa035('0x11')][_0xa035('0x9')](this));ami['on']('blindtransfer',this[_0xa035('0x12')]['bind'](this));}VoiceAgentReport[_0xa035('0x13')]['log']=function(_0xb76be6,_0x531c88){logger[_0xa035('0x14')](util[_0xa035('0x15')](_0xa035('0x16'),_0xb76be6,[_0x531c88['uniqueid'],_0x531c88[_0xa035('0x17')],_0x531c88[_0xa035('0x18')],_0x531c88[_0xa035('0x19')],_0x531c88[_0xa035('0x1a')]][_0xa035('0x1b')]('|')));};VoiceAgentReport['prototype'][_0xa035('0x1c')]=function(_0x1a25c4,_0x696fd0){return moment(_0x1a25c4)[_0xa035('0x1d')](_0x696fd0,_0xa035('0x1e'))[_0xa035('0x15')](_0xa035('0x1f'));};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x20')]=function(_0x88b275,_0x57598c){return moment(_0x88b275)['diff'](moment(_0x57598c),_0xa035('0x1e'));};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x21')]=function(_0x1ea3f2){try{var _0x556a3f=this[_0xa035('0x6')][_0x1ea3f2[_0xa035('0x22')]];if(!_[_0xa035('0x23')](_0x556a3f)){_0x556a3f=_[_0xa035('0x24')](_0x556a3f,{'queue':_0x1ea3f2[_0xa035('0x18')],'destconnectedlinenum':_0x1ea3f2[_0xa035('0x1a')]});io[_0xa035('0x25')](_0xa035('0x26'),_0x556a3f);}var _0x154cdf=this[_0xa035('0x27')][_0x1ea3f2[_0xa035('0x28')]]={'agentcalledAt':moment()[_0xa035('0x15')](_0xa035('0x1f')),'calleridnum':_0x1ea3f2['calleridnum'],'calleridname':_0x1ea3f2['calleridname'],'connectedlinenum':_0x1ea3f2[_0xa035('0x29')],'connectedlinename':_0x1ea3f2[_0xa035('0x2a')],'accountcode':_0x1ea3f2[_0xa035('0x2b')],'destaccountcode':_0x1ea3f2['destaccountcode'],'channel':_0x1ea3f2[_0xa035('0x2c')],'destchannel':_0x1ea3f2[_0xa035('0x28')],'uniqueid':_0x1ea3f2[_0xa035('0x2d')],'destuniqueid':_0x1ea3f2[_0xa035('0x2e')],'context':_0x1ea3f2[_0xa035('0x2f')],'exten':_0x1ea3f2[_0xa035('0x19')],'priority':_0x1ea3f2[_0xa035('0x30')],'queue':_0x1ea3f2[_0xa035('0x18')],'type':this[_0xa035('0x5')][_0x1ea3f2[_0xa035('0x18')]]?this[_0xa035('0x5')][_0x1ea3f2[_0xa035('0x18')]][_0xa035('0x31')]||_0xa035('0x32'):_0xa035('0x32'),'interface':_0x1ea3f2[_0xa035('0x22')],'membername':_0x1ea3f2[_0xa035('0x17')],'agentconnect':![],'agentconnectAt':null,'holdtime':0x0,'ringtime':0x0,'agentcomplete':![],'agentcompleteAt':null,'talktime':0x0,'agentringnoanswer':![],'agentringnoanswerAt':null,'reason':_0xa035('0x33'),'transfer':![],'transferAt':null,'transfertype':null,'transferuniqueid':null,'transfercontext':null,'transferextension':null,'position':null,'originalposition':null,'cause':'','cause-txt':'','UserId':this[_0xa035('0x6')][_0x1ea3f2[_0xa035('0x22')]]?this[_0xa035('0x6')][_0x1ea3f2[_0xa035('0x22')]]['id']:null,'lastevent':_0xa035('0x34'),'agentacw':![],'acwtime':0x0,'variables':this[_0xa035('0x7')][_0x1ea3f2['channel']]?this[_0xa035('0x7')][_0x1ea3f2[_0xa035('0x2c')]]:{}};ami[_0xa035('0x25')](_0xa035('0x35'),_0x154cdf);io['to'](util['format']('user:%s',_0x154cdf[_0xa035('0x17')]))['emit'](_0xa035('0x36'),_0x154cdf);this[_0xa035('0x37')]('CALLED',this[_0xa035('0x27')][_0x1ea3f2[_0xa035('0x28')]]);}catch(_0x472cfd){logger['error'](_0x472cfd[_0xa035('0x38')]);}};VoiceAgentReport['prototype'][_0xa035('0xb')]=function(_0x28cda){try{var _0x19b108=this[_0xa035('0x27')][_0x28cda['destchannel']];if(!_[_0xa035('0x23')](_0x19b108)){_0x19b108=_[_0xa035('0x24')](_0x19b108,{'holdtime':parseInt(_0x28cda[_0xa035('0x39')],0xa),'ringtime':parseInt(_0x28cda['ringtime'],0xa),'agentconnect':!![],'lastevent':'connect'});_0x19b108[_0xa035('0x3a')]=this[_0xa035('0x1c')](_0x19b108[_0xa035('0x3b')],_0x19b108[_0xa035('0x3c')]);ami['emit']('custom:agentconnect',_0x19b108);io['to'](util[_0xa035('0x15')](_0xa035('0x3d'),_0x19b108[_0xa035('0x17')]))[_0xa035('0x25')](_0xa035('0x3e'),_0x19b108);this[_0xa035('0x37')](_0xa035('0x3f'),_0x19b108);}}catch(_0x3675e1){logger[_0xa035('0x40')](_0x3675e1[_0xa035('0x38')]);}};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x41')]=function(_0x276313){try{var _0x36696b=this[_0xa035('0x27')][_0x276313[_0xa035('0x28')]];if(!_['isNil'](_0x36696b)){_0x36696b=_[_0xa035('0x24')](_0x36696b,{'ringtime':parseInt(_0x276313[_0xa035('0x3c')],0xa)/0x3e8,'agentringnoanswer':!![],'reason':_0xa035('0x42'),'lastevent':_0xa035('0x42')});_0x36696b[_0xa035('0x43')]=this[_0xa035('0x1c')](_0x36696b[_0xa035('0x3b')],_0x36696b[_0xa035('0x3c')]);ami[_0xa035('0x25')](_0xa035('0x44'),_0x36696b);this[_0xa035('0x37')](_0xa035('0x45'),_0x36696b);}}catch(_0x454b3b){logger['error'](_0x454b3b['stack']);}};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x46')]=function(_0x450874){try{for(var _0x4ee772 in this[_0xa035('0x27')]){var _0x169013=this[_0xa035('0x27')][_0x4ee772];if(!_[_0xa035('0x23')](_0x169013)&&_0x169013[_0xa035('0x2c')]==_0x450874[_0xa035('0x2c')]){_0x169013=_['assign'](_0x169013,{'holdtime':parseInt(_0x450874['holdtime'],0xa),'position':parseInt(_0x450874[_0xa035('0x47')],0xa),'originalposition':parseInt(_0x450874[_0xa035('0x48')],0xa),'agentringnoanswer':!![],'agentringnoanswerAt':moment()[_0xa035('0x15')](_0xa035('0x1f')),'reason':_0xa035('0x49'),'lastevent':_0xa035('0x49')});ami[_0xa035('0x25')](_0xa035('0x4a'),_0x169013);this['log'](_0xa035('0x4b'),_0x169013);}}}catch(_0x42d8e3){logger[_0xa035('0x40')](_0x42d8e3['stack']);}};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x4c')]=function(_0xca727a){try{var _0x4d4ba5=this[_0xa035('0x27')][_0xca727a['destchannel']];if(!_[_0xa035('0x23')](_0x4d4ba5)){_0x4d4ba5=_[_0xa035('0x24')](_0x4d4ba5,{'talktime':parseInt(_0xca727a[_0xa035('0x4d')],0xa),'reason':_0xca727a['reason']=='transfer'?_0xa035('0x33'):_0xca727a[_0xa035('0x4e')],'agentcomplete':!![],'lastevent':_0xa035('0x4f'),'agentacw':this[_0xa035('0x5')][_0x4d4ba5[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x4d4ba5[_0xa035('0x18')]]['acw']?!![]:![],'acwtime':this[_0xa035('0x5')][_0x4d4ba5[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x4d4ba5[_0xa035('0x18')]][_0xa035('0x50')]?this[_0xa035('0x5')][_0x4d4ba5[_0xa035('0x18')]][_0xa035('0x51')]:0x0});_0x4d4ba5[_0xa035('0x52')]=this[_0xa035('0x1c')](_0x4d4ba5[_0xa035('0x3a')],_0x4d4ba5[_0xa035('0x4d')]);this[_0xa035('0x37')]('COMPLETE',_0x4d4ba5);}}catch(_0x312b0a){logger['error'](_0x312b0a[_0xa035('0x38')]);}};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x53')]=function(_0x220e74){try{switch(_0x220e74[_0xa035('0x54')]){case 0x1a:_0x220e74=_['assign'](_0x220e74,{'agentringnoanswer':!![],'reason':_0xa035('0x55'),'lastevent':_0xa035('0x55')});var _0x5220e7=_['find'](this['channels'],{'channel':_0x220e74[_0xa035('0x2c')],'agentconnect':!![]});if(!_[_0xa035('0x23')](_0x5220e7)){_0x220e74=_[_0xa035('0x24')](_0x220e74,{'agentringnoanswerAt':_0x5220e7['agentconnectAt'],'answeredelsewheremembername':_0x5220e7['membername'],'answeredelsewheredestinationuniqueid':_0x5220e7['destuniqueid']});}ami[_0xa035('0x25')](_0xa035('0x56'),_0x220e74);break;}if(_0x220e74[_0xa035('0xe')]){ami[_0xa035('0x25')]('custom:agentcomplete',_0x220e74);io['to'](util[_0xa035('0x15')](_0xa035('0x3d'),_0x220e74['membername']))[_0xa035('0x25')]('user:agentcomplete',_0x220e74);}this[_0xa035('0x37')]('HANGUP',_0x220e74);ami[_0xa035('0x25')](_0xa035('0x57'),_0x220e74);if(this['channels'][_0x220e74[_0xa035('0x28')]]){delete this[_0xa035('0x27')][_0x220e74['destchannel']];}}catch(_0x28b65f){logger[_0xa035('0x40')](_0x28b65f);}};VoiceAgentReport['prototype'][_0xa035('0x58')]=function(_0x1a73d1){try{var _0x2993b2=this[_0xa035('0x27')][_0x1a73d1['channel']];if(!_['isNil'](_0x2993b2)){_0x2993b2=_[_0xa035('0x24')](_0x2993b2,{'cause':parseInt(_0x1a73d1[_0xa035('0x54')],0xa),'cause-txt':_0x1a73d1['cause-txt']});if(_0x2993b2[_0xa035('0x59')]){_0x2993b2=_['assign'](_0x2993b2,{'agentcomplete':!![],'agentcompleteAt':moment()[_0xa035('0x15')](_0xa035('0x1f')),'lastevent':_0xa035('0x4f'),'agentacw':this[_0xa035('0x5')][_0x2993b2[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x2993b2[_0xa035('0x18')]][_0xa035('0x50')]?!![]:![],'acwtime':this[_0xa035('0x5')][_0x2993b2[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x2993b2['queue']][_0xa035('0x50')]?this[_0xa035('0x5')][_0x2993b2['queue']]['acwTimeout']:0x0});_0x2993b2[_0xa035('0x4d')]=this[_0xa035('0x20')](_0x2993b2[_0xa035('0x52')],_0x2993b2[_0xa035('0x3a')]);}var _0x2b0889=this[_0xa035('0x6')][_0x2993b2[_0xa035('0x22')]];if(!_[_0xa035('0x23')](_0x2b0889)){_0x2b0889=_[_0xa035('0x24')](_0x2b0889,{'queue':null,'destconnectedlinenum':null});io[_0xa035('0x25')]('user:save',_0x2b0889);}setTimeout(this[_0xa035('0x53')][_0xa035('0x9')](this,_0x2993b2),0x3e8);}if(this[_0xa035('0x7')][_0x1a73d1['channel']]){delete this[_0xa035('0x7')][_0x1a73d1[_0xa035('0x2c')]];}}catch(_0x1fff0e){logger['error'](_0x1fff0e[_0xa035('0x38')]);}};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x11')]=function(_0x32efe2){try{var _0x945663=this[_0xa035('0x27')][_0x32efe2[_0xa035('0x5a')]];if(!_[_0xa035('0x23')](_0x945663)){_0x945663=_[_0xa035('0x24')](_0x945663,{'transfer':!![],'transferAt':moment()[_0xa035('0x15')](_0xa035('0x1f')),'transfertype':_0xa035('0x5b'),'agentcomplete':!![],'agentcompleteAt':moment()[_0xa035('0x15')]('YYYY-MM-DD\x20HH:mm:ss'),'transferuniqueid':_0x32efe2[_0xa035('0x5c')],'transfercontext':_0x32efe2[_0xa035('0x5d')],'transferextension':_0x32efe2['secondtransferercontext'],'reason':_0xa035('0x5e'),'lastevent':'complete','agentacw':this[_0xa035('0x5')][_0x945663['queue']]&&this['voiceQueues'][_0x945663[_0xa035('0x18')]][_0xa035('0x50')]?!![]:![],'acwtime':this['voiceQueues'][_0x945663[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x945663[_0xa035('0x18')]][_0xa035('0x50')]?this[_0xa035('0x5')][_0x945663[_0xa035('0x18')]]['acwTimeout']:0x0});_0x945663[_0xa035('0x4d')]=this[_0xa035('0x20')](_0x945663[_0xa035('0x52')],_0x945663['agentconnectAt']);this[_0xa035('0x37')](_0xa035('0x5b'),_0x945663);}if(!_[_0xa035('0x23')](this['channels'][_0x32efe2[_0xa035('0x5f')]])){this['channels'][_0x32efe2[_0xa035('0x5f')]][_0xa035('0x59')]=!![];}}catch(_0xf61382){logger[_0xa035('0x40')](_0xf61382[_0xa035('0x38')]);}};VoiceAgentReport[_0xa035('0x13')][_0xa035('0x12')]=function(_0x5f4bf6){try{var _0x4aca11=this[_0xa035('0x27')][_0x5f4bf6[_0xa035('0x60')]];if(!_[_0xa035('0x23')](_0x4aca11)){_0x4aca11=_['assign'](_0x4aca11,{'transfer':!![],'transferAt':moment()[_0xa035('0x15')](_0xa035('0x1f')),'transfertype':_0xa035('0x61'),'transferuniqueid':_0x5f4bf6[_0xa035('0x62')],'transfercontext':_0x5f4bf6[_0xa035('0x2f')],'transferextension':_0x5f4bf6[_0xa035('0x63')],'agentcomplete':!![],'agentcompleteAt':moment()['format'](_0xa035('0x1f')),'reason':_0xa035('0x5e'),'lastevent':_0xa035('0x4f'),'agentacw':this['voiceQueues'][_0x4aca11[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x4aca11[_0xa035('0x18')]][_0xa035('0x50')]?!![]:![],'acwtime':this[_0xa035('0x5')][_0x4aca11[_0xa035('0x18')]]&&this[_0xa035('0x5')][_0x4aca11[_0xa035('0x18')]]['acw']?this[_0xa035('0x5')][_0x4aca11[_0xa035('0x18')]]['acwTimeout']:0x0});_0x4aca11[_0xa035('0x59')]=!![];this[_0xa035('0x37')](_0xa035('0x61'),_0x4aca11);}}catch(_0x3da5e4){logger[_0xa035('0x40')](_0x3da5e4[_0xa035('0x38')]);}};VoiceAgentReport['prototype'][_0xa035('0x64')]=function(_0x59fa7d){var _0x15cf4e=[_0xa035('0x65'),'rtpaudioqosbridged',_0xa035('0x66'),_0xa035('0x67'),'rtpaudioqosloss',_0xa035('0x68'),_0xa035('0x69'),_0xa035('0x6a'),'sipcallid','sipuri',_0xa035('0x6b'),_0xa035('0x6c'),_0xa035('0x6d'),_0xa035('0x6e'),'memberinterface',_0xa035('0x6f'),'membername',_0xa035('0x70'),'memberrealtime'];try{var _0x19911b=_[_0xa035('0x71')](_0x59fa7d[_0xa035('0x72')])[0x0];if(!_[_0xa035('0x23')](_0x19911b)&&!_[_0xa035('0x73')](_0x15cf4e,_0x19911b)){if(!this[_0xa035('0x7')][_0x59fa7d[_0xa035('0x2c')]]){this[_0xa035('0x7')][_0x59fa7d[_0xa035('0x2c')]]={};}this[_0xa035('0x7')][_0x59fa7d[_0xa035('0x2c')]][_0x19911b]=_0x59fa7d[_0xa035('0x74')];}}catch(_0x383f4b){logger[_0xa035('0x40')](_0x383f4b[_0xa035('0x38')]);}};module['exports']=VoiceAgentReport;