Built motion from commit 953226e6.|2.6.32
[motion2.git] / server / services / xdr / calls.controller.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 _0x47a6=['request','CreateVoiceCallReport','newchannel','debug','[%s][calls][newchannel]','linkedid','OutgoingSpoolFailed','[%s][calls][newchannel]\x20context:%s\x20exten:%s','context','exten','DOCUMENTATION','error','newstate','isNil','channelstate','systemanswertime','transfer','[%s][calls][newstate]\x20linkedid:%s\x20context:%s\x20channel:%s','destinationchannel','answertime','now','disposition','toNumber','[%s][calls][newstate]','[%s][calls][hangup]','callerid','calleridname','cause-txt','duration','diffTime','endtime','billableseconds','attendedtransfer','[%s][calls][attendedtransfer]','origtransfereruniqueid','localtwolinkedid','transfereechannel','[%s][calls][attendedtransfer]\x20localtwolinkedid:%s\x20destinationchannel:%s','secondtransfererchannel','userfield','_attended','transfertargetchannel','origtransfererchannel','musiconholdstart','[%s][calls][musiconholdstart]','[%s][calls][musiconholdstart]\x20musiconholdstartAt:%s','[%s][calls][musiconholdstop]','musiconholdstartAt','mohtime','[%s][calls][musiconholdstop]\x20mohtime:%s','varset','[%s][calls][varset]','variable','[%s][calls][varset]\x20variable:xmd-originatecalleridnum\x20value:%s','value','xmd-phone','[%s][calls][varset]\x20variable:xmd-phone\x20value:%s','destination','xmd-callerid-preview','[%s][calls][varset]\x20variable:%s\x20value:%s','xmd-callerid','xmcs-queue','xmd-queue','lastapplication','Queue','lastdata','ContactId','xmd-cdrtype','[%s][calls][varset]\x20variable:xmd-cdrtype\x20value:%s','type','outboundrouteid','[%s][calls][varset]\x20variable:outboundrouteid\x20value:%s','routeid','sipcallid','[%s][calls][varset]\x20variable:sipcallid\x20value:%s','newexten','[%s][calls][newexten]','[%s][calls][newexten]\x20application:%s\x20appdata:%s','set','startsWith','appdata','cdr','split','substring','lastIndexOf','hangup','execif','gotoif','application','lodash','util','FAILED','NO\x20ANSWER','ANSWERED','info','format','[%s][calls][writeDB]\x20channel:%s\x20queue:%s\x20agent:%s\x20interface:%s\x20calleridnum:%s\x20connectedlinenum:%s\x20lastevent:%s','uniqueid','channel','queue','membername','interface','calleridnum','lastevent','accountcode','then','UserId'];(function(_0x36e52b,_0x3a87a0){var _0x160101=function(_0xf6a18c){while(--_0xf6a18c){_0x36e52b['push'](_0x36e52b['shift']());}};_0x160101(++_0x3a87a0);}(_0x47a6,0x19a));var _0x647a=function(_0x30c066,_0x24c3ce){_0x30c066=_0x30c066-0x0;var _0x3035fc=_0x47a6[_0x30c066];return _0x3035fc;};'use strict';var _=require(_0x647a('0x0'));var util=require(_0x647a('0x1'));var utils=require('./utils');var dispositions=['NO\x20ANSWER',_0x647a('0x2'),_0x647a('0x2'),'NO\x20ANSWER',_0x647a('0x3'),_0x647a('0x3'),_0x647a('0x4'),'BUSY',_0x647a('0x2'),_0x647a('0x2'),'FAILED'];var channels={};function writeDB(_0x34cb95){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x7'),_0x34cb95[_0x647a('0x8')],_0x34cb95[_0x647a('0x9')],_0x34cb95[_0x647a('0xa')],_0x34cb95[_0x647a('0xb')],_0x34cb95[_0x647a('0xc')],_0x34cb95[_0x647a('0xd')],_0x34cb95['connectedlinenum'],_0x34cb95[_0x647a('0xe')]));if(_0x34cb95[_0x647a('0xf')]){utils['getUserByInternal'](_0x34cb95[_0x647a('0xf')])[_0x647a('0x10')](function(_0x281d22){if(_0x281d22){_0x34cb95[_0x647a('0x11')]=_0x281d22['id'];}utils[_0x647a('0x12')](_0x647a('0x13'),_0x34cb95);});}else{utils[_0x647a('0x12')](_0x647a('0x13'),_0x34cb95);}if(channels[_0x34cb95[_0x647a('0x8')]]){delete channels[_0x34cb95[_0x647a('0x8')]];}}exports[_0x647a('0x14')]=function(_0x17eb19){try{utils[_0x647a('0x15')](util[_0x647a('0x6')](_0x647a('0x16'),_0x17eb19[_0x647a('0x8')]),_0x17eb19);if(_0x17eb19[_0x647a('0x8')]==_0x17eb19[_0x647a('0x17')]&&_0x17eb19[_0x647a('0x9')]!=_0x647a('0x18')){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x19'),_0x17eb19[_0x647a('0x8')],_0x17eb19[_0x647a('0x1a')],_0x17eb19[_0x647a('0x1b')]));channels[_0x17eb19[_0x647a('0x8')]]={'uniqueid':_0x17eb19[_0x647a('0x8')],'accountcode':_0x17eb19[_0x647a('0xf')],'source':_0x17eb19['calleridnum'],'destination':_0x17eb19['exten'],'destinationcontext':_0x17eb19['context'],'channel':_0x17eb19[_0x647a('0x9')],'starttime':utils['now'](),'answertime':null,'systemanswertime':null,'mohtime':0x0,'disposition':_0x647a('0x3'),'amaflags':_0x647a('0x1c')};}}catch(_0x1330f5){utils[_0x647a('0x1d')](util[_0x647a('0x6')](_0x647a('0x16'),_0x17eb19[_0x647a('0x8')]),_0x1330f5);}};exports[_0x647a('0x1e')]=function(_0x23ef53){try{utils['debug'](util['format']('[%s][calls][newstate]',_0x23ef53[_0x647a('0x8')]),_0x23ef53);if(!_[_0x647a('0x1f')](channels[_0x23ef53[_0x647a('0x8')]])&&_0x23ef53[_0x647a('0x20')]==0x6){utils[_0x647a('0x5')](util[_0x647a('0x6')]('[%s][calls][newstate]\x20context:%s\x20channel:%s',_0x23ef53[_0x647a('0x8')],_0x23ef53[_0x647a('0x1a')],_0x23ef53[_0x647a('0x9')]));if(_['isNil'](channels[_0x23ef53['uniqueid']][_0x647a('0x21')])){channels[_0x23ef53['uniqueid']][_0x647a('0x21')]=utils['now']();}}else if(!_[_0x647a('0x1f')](channels[_0x23ef53[_0x647a('0x17')]])&&_0x23ef53[_0x647a('0x20')]==0x6&&_0x23ef53[_0x647a('0x1a')]!=_0x647a('0x22')){utils[_0x647a('0x5')](util['format'](_0x647a('0x23'),_0x23ef53[_0x647a('0x8')],_0x23ef53[_0x647a('0x17')],_0x23ef53[_0x647a('0x1a')],_0x23ef53['channel']));channels[_0x23ef53[_0x647a('0x17')]]['accountcode']=_0x23ef53[_0x647a('0xf')];channels[_0x23ef53[_0x647a('0x17')]][_0x647a('0x24')]=_0x23ef53['channel'];if(_[_0x647a('0x1f')](channels[_0x23ef53['linkedid']][_0x647a('0x25')])){channels[_0x23ef53['linkedid']][_0x647a('0x25')]=utils[_0x647a('0x26')]();}channels[_0x23ef53[_0x647a('0x17')]][_0x647a('0x27')]=dispositions[_[_0x647a('0x28')](_0x23ef53['channelstate'])]||_0x647a('0x4');}}catch(_0x595047){utils[_0x647a('0x1d')](util[_0x647a('0x6')](_0x647a('0x29'),_0x23ef53[_0x647a('0x8')]),_0x595047);}};exports['hangup']=function(_0x25eae7){try{if(!_['isNil'](channels[_0x25eae7[_0x647a('0x8')]])){utils[_0x647a('0x15')](util[_0x647a('0x6')](_0x647a('0x2a'),_0x25eae7[_0x647a('0x8')]),_0x25eae7);if(_[_0x647a('0x1f')](channels[_0x25eae7[_0x647a('0x8')]][_0x647a('0x2b')])){channels[_0x25eae7['uniqueid']][_0x647a('0x2b')]=_0x25eae7[_0x647a('0x2c')]+'\x20<'+_0x25eae7[_0x647a('0xd')]+'>';}utils[_0x647a('0x5')](util['format']('[%s][calls][hangup]\x20callerid:%s\x20reason:%s',_0x25eae7[_0x647a('0x8')],channels[_0x25eae7[_0x647a('0x8')]][_0x647a('0x2b')],_0x25eae7[_0x647a('0x2d')]));channels[_0x25eae7[_0x647a('0x8')]]['endtime']=utils[_0x647a('0x26')]();channels[_0x25eae7[_0x647a('0x8')]][_0x647a('0x2e')]=utils[_0x647a('0x2f')](channels[_0x25eae7['uniqueid']][_0x647a('0x30')],channels[_0x25eae7['uniqueid']]['starttime']);channels[_0x25eae7['uniqueid']][_0x647a('0x31')]=channels[_0x25eae7[_0x647a('0x8')]][_0x647a('0x25')]?utils['diffTime'](channels[_0x25eae7[_0x647a('0x8')]][_0x647a('0x30')],channels[_0x25eae7['uniqueid']]['answertime']):0x0;writeDB(channels[_0x25eae7[_0x647a('0x8')]]);}}catch(_0x37593f){utils[_0x647a('0x1d')](util[_0x647a('0x6')](_0x647a('0x2a'),_0x25eae7[_0x647a('0x8')]),_0x37593f);}};exports[_0x647a('0x32')]=function(_0x3276a3){try{if(!_[_0x647a('0x1f')](channels[_0x3276a3['localtwolinkedid']])){utils[_0x647a('0x15')](util['format'](_0x647a('0x33'),_0x3276a3[_0x647a('0x34')]),_0x3276a3);if(channels[_0x3276a3[_0x647a('0x35')]][_0x647a('0x9')]==_0x3276a3[_0x647a('0x36')]){utils[_0x647a('0x5')](util['format'](_0x647a('0x37'),_0x3276a3['origtransfereruniqueid'],_0x3276a3[_0x647a('0x35')],_0x3276a3[_0x647a('0x38')]));channels[_0x3276a3[_0x647a('0x35')]][_0x647a('0x24')]=_0x3276a3['secondtransfererchannel'];channels[_0x3276a3[_0x647a('0x35')]][_0x647a('0x39')]=_0x647a('0x3a');}else if(channels[_0x3276a3[_0x647a('0x35')]][_0x647a('0x9')]=_0x3276a3[_0x647a('0x3b')]){utils['info'](util['format'](_0x647a('0x37'),_0x3276a3[_0x647a('0x34')],_0x3276a3[_0x647a('0x35')],_0x3276a3[_0x647a('0x3c')]));channels[_0x3276a3[_0x647a('0x35')]][_0x647a('0x24')]=_0x3276a3[_0x647a('0x3c')];channels[_0x3276a3[_0x647a('0x35')]]['userfield']=_0x647a('0x3a');}}}catch(_0x1e667c){utils[_0x647a('0x1d')](util[_0x647a('0x6')](_0x647a('0x33'),_0x3276a3[_0x647a('0x34')]),_0x1e667c);}};exports[_0x647a('0x3d')]=function(_0x898b7a){try{if(!_[_0x647a('0x1f')](channels[_0x898b7a[_0x647a('0x8')]])){utils['debug'](util[_0x647a('0x6')](_0x647a('0x3e'),_0x898b7a['uniqueid']),_0x898b7a);channels[_0x898b7a[_0x647a('0x8')]]['musiconholdstartAt']=utils[_0x647a('0x26')]();utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x3f'),_0x898b7a['uniqueid'],channels[_0x898b7a['uniqueid']]['musiconholdstartAt']));}}catch(_0x3de2a1){utils[_0x647a('0x1d')](util[_0x647a('0x6')]('[%s][calls][musiconholdstart]',_0x898b7a[_0x647a('0x8')]),_0x3de2a1);}};exports['musiconholdstop']=function(_0x368cb6){try{if(!_['isNil'](channels[_0x368cb6[_0x647a('0x8')]])){utils[_0x647a('0x15')](util['format'](_0x647a('0x40'),_0x368cb6[_0x647a('0x8')]),_0x368cb6);if(!_[_0x647a('0x1f')](channels[_0x368cb6[_0x647a('0x8')]][_0x647a('0x41')])){channels[_0x368cb6[_0x647a('0x8')]][_0x647a('0x42')]+=utils['diffTime'](utils['now'](),channels[_0x368cb6['uniqueid']]['musiconholdstartAt']);utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x43'),_0x368cb6[_0x647a('0x8')],channels[_0x368cb6[_0x647a('0x8')]][_0x647a('0x42')]));delete channels[_0x368cb6[_0x647a('0x8')]]['musiconholdstartAt'];}}}catch(_0x322c83){utils[_0x647a('0x1d')](util[_0x647a('0x6')](_0x647a('0x40'),_0x368cb6[_0x647a('0x8')]),_0x322c83);}};exports[_0x647a('0x44')]=function(_0x10bc00){try{if(!_['isNil'](channels[_0x10bc00[_0x647a('0x8')]])){utils[_0x647a('0x15')](util[_0x647a('0x6')](_0x647a('0x45'),_0x10bc00[_0x647a('0x8')]),_0x10bc00);if(!_['isNil'](_0x10bc00[_0x647a('0x46')]['xmd-originatecalleridnum'])){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x47'),_0x10bc00[_0x647a('0x8')],_0x10bc00['value']));channels[_0x10bc00['uniqueid']]['source']=_0x10bc00[_0x647a('0x48')];}if(!_[_0x647a('0x1f')](_0x10bc00[_0x647a('0x46')][_0x647a('0x49')])){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x4a'),_0x10bc00['uniqueid'],_0x10bc00[_0x647a('0x48')]));channels[_0x10bc00['uniqueid']][_0x647a('0x4b')]=_0x10bc00[_0x647a('0x48')];channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x2b')]='\x22'+_0x10bc00[_0x647a('0x48')]+'\x22\x20<'+_0x10bc00[_0x647a('0x48')]+'>';}if(!_['isNil'](_0x10bc00['variable'][_0x647a('0x4c')])||!_[_0x647a('0x1f')](_0x10bc00[_0x647a('0x46')]['xmd-callerid'])){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x4d'),_0x10bc00[_0x647a('0x8')],!_[_0x647a('0x1f')](_0x10bc00['variable'][_0x647a('0x4c')])?_0x647a('0x4c'):_0x647a('0x4e'),_0x10bc00[_0x647a('0x48')]));channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x2b')]=_0x10bc00[_0x647a('0x48')];}if(!_[_0x647a('0x1f')](_0x10bc00[_0x647a('0x46')]['xmd-queue'])||!_[_0x647a('0x1f')](_0x10bc00[_0x647a('0x46')][_0x647a('0x4f')])){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x4d'),_0x10bc00[_0x647a('0x8')],!_[_0x647a('0x1f')](_0x10bc00[_0x647a('0x46')][_0x647a('0x50')])?_0x647a('0x50'):_0x647a('0x4f'),_0x10bc00['value']));channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x51')]=_0x647a('0x52');channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x53')]=_0x10bc00[_0x647a('0x48')];channels[_0x10bc00[_0x647a('0x8')]]['queue']=!![];}if(!_['isNil'](_0x10bc00['variable']['xmd-contactid'])){utils[_0x647a('0x5')](util[_0x647a('0x6')]('[%s][calls][varset]\x20variable:xmd-contactid\x20value:%s',_0x10bc00[_0x647a('0x8')],_0x10bc00['value']));channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x54')]=_0x10bc00[_0x647a('0x48')];}if(!_[_0x647a('0x1f')](_0x10bc00['variable'][_0x647a('0x55')])){utils['info'](util[_0x647a('0x6')](_0x647a('0x56'),_0x10bc00['uniqueid'],_0x10bc00['value']));channels[_0x10bc00['uniqueid']][_0x647a('0x57')]=_0x10bc00[_0x647a('0x48')];}if(!_['isNil'](_0x10bc00[_0x647a('0x46')][_0x647a('0x58')])){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x59'),_0x10bc00[_0x647a('0x8')],_0x10bc00[_0x647a('0x48')]));channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x5a')]=_0x10bc00[_0x647a('0x48')];}if(!_[_0x647a('0x1f')](_0x10bc00[_0x647a('0x46')][_0x647a('0x5b')])){utils[_0x647a('0x5')](util[_0x647a('0x6')](_0x647a('0x5c'),_0x10bc00[_0x647a('0x8')],_0x10bc00[_0x647a('0x48')]));channels[_0x10bc00[_0x647a('0x8')]][_0x647a('0x5b')]=_0x10bc00[_0x647a('0x48')];}}}catch(_0x535003){utils[_0x647a('0x1d')](util[_0x647a('0x6')](_0x647a('0x45'),_0x10bc00[_0x647a('0x8')]),_0x535003);}};exports[_0x647a('0x5d')]=function(_0x375cb7){try{if(!_['isNil'](channels[_0x375cb7[_0x647a('0x8')]])){utils[_0x647a('0x15')](util[_0x647a('0x6')](_0x647a('0x5e'),_0x375cb7['uniqueid']),_0x375cb7);utils['info'](util[_0x647a('0x6')](_0x647a('0x5f'),_0x375cb7[_0x647a('0x8')],_0x375cb7['application'],_0x375cb7['appdata']));if(_0x375cb7['application']['toLowerCase']()==_0x647a('0x60')&&_[_0x647a('0x61')](_0x375cb7[_0x647a('0x62')]['toLowerCase'](),_0x647a('0x63'))){var _0x1861ad=_0x375cb7['appdata'][_0x647a('0x64')]('=');var _0xf34c38=_0x1861ad[0x0][_0x647a('0x65')](_0x1861ad[0x0][_0x647a('0x66')]('(')+0x1,_0x1861ad[0x0][_0x647a('0x66')](')'));var _0x211cf0=_0x1861ad[0x1];channels[_0x375cb7['uniqueid']][_0xf34c38]=_0x211cf0;}if(!_['includes']([_0x647a('0x67'),'noop',_0x647a('0x68'),_0x647a('0x60'),_0x647a('0x69')],_0x375cb7[_0x647a('0x6a')]['toLowerCase']())){channels[_0x375cb7['uniqueid']]['lastapplication']=_0x375cb7[_0x647a('0x6a')];channels[_0x375cb7['uniqueid']][_0x647a('0x53')]=_0x375cb7[_0x647a('0x62')];}}}catch(_0x298451){utils[_0x647a('0x1d')](util['format'](_0x647a('0x5e'),_0x375cb7[_0x647a('0x8')]),_0x298451);}};