Built motion from commit 85328c08.|2.5.50
[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 _0x077e=['lodash','util','./utils','./transfers.controller','FAILED','NO\x20ANSWER','ANSWERED','BUSY','blinds','uniqueid','transfereeuniqueid','format','queue','membername','interface','calleridnum','connectedlinenum','lastevent','accountcode','getUserByInternal','then','request','CreateVoiceCallReport','recording','newchannel','debug','[%s][calls][newchannel]','linkedid','channel','OutgoingSpoolFailed','context','exten','now','DOCUMENTATION','error','newstate','[%s][calls][newstate]','isNil','channelstate','info','[%s][calls][newstate]\x20context:%s\x20channel:%s','systemanswertime','transfer','[%s][calls][newstate]\x20linkedid:%s\x20context:%s\x20channel:%s','destinationchannel','answertime','disposition','hangup','[%s][calls][hangup]','callerid','calleridname','cause-txt','endtime','billableseconds','diffTime','attendedtransfer','localtwolinkedid','[%s][calls][attendedtransfer]','origtransfereruniqueid','transfereechannel','userfield','_attended','transfertargetchannel','[%s][calls][attendedtransfer]\x20localtwolinkedid:%s\x20destinationchannel:%s','origtransfererchannel','musiconholdstart','[%s][calls][musiconholdstart]','musiconholdstartAt','[%s][calls][musiconholdstart]\x20musiconholdstartAt:%s','musiconholdstop','[%s][calls][musiconholdstop]','mohtime','[%s][calls][musiconholdstop]\x20mohtime:%s','[%s][calls][varset]','variable','value','source','xmd-phone','[%s][calls][varset]\x20variable:xmd-phone\x20value:%s','destination','\x22\x20<','xmd-callerid-preview','xmd-callerid','[%s][calls][varset]\x20variable:%s\x20value:%s','xmd-queue','xmcs-queue','lastapplication','Queue','lastdata','xmd-contactid','[%s][calls][varset]\x20variable:xmd-contactid\x20value:%s','[%s][calls][varset]\x20variable:xmd-cdrtype\x20value:%s','type','outboundrouteid','[%s][calls][varset]\x20variable:outboundrouteid\x20value:%s','[%s][calls][varset]\x20variable:sipcallid\x20value:%s','[%s][calls][newexten]','[%s][calls][newexten]\x20application:%s\x20appdata:%s','appdata','application','startsWith','toLowerCase','cdr','split','substring','lastIndexOf','includes','execif','set','gotoif'];(function(_0x10afad,_0x30da9d){var _0x588d7e=function(_0x25e897){while(--_0x25e897){_0x10afad['push'](_0x10afad['shift']());}};_0x588d7e(++_0x30da9d);}(_0x077e,0x14a));var _0xe077=function(_0x496b57,_0xf202a0){_0x496b57=_0x496b57-0x0;var _0x119177=_0x077e[_0x496b57];return _0x119177;};'use strict';var _=require(_0xe077('0x0'));var util=require(_0xe077('0x1'));var utils=require(_0xe077('0x2'));var transfers=require(_0xe077('0x3'));var dispositions=['NO\x20ANSWER',_0xe077('0x4'),_0xe077('0x4'),_0xe077('0x5'),'NO\x20ANSWER',_0xe077('0x5'),_0xe077('0x6'),_0xe077('0x7'),_0xe077('0x4'),_0xe077('0x4'),_0xe077('0x4')];var channels={};function writeDB(_0x2810b4){var _0x2e5a85;if(transfers[_0xe077('0x8')][_0x2810b4[_0xe077('0x9')]]){_0x2e5a85=_0x2810b4[_0xe077('0x9')];_0x2810b4[_0xe077('0x9')]=transfers['blinds'][_0x2810b4[_0xe077('0x9')]][_0xe077('0xa')];}utils['info'](util[_0xe077('0xb')]('[%s][calls][writeDB]\x20channel:%s\x20queue:%s\x20agent:%s\x20interface:%s\x20calleridnum:%s\x20connectedlinenum:%s\x20lastevent:%s',_0x2810b4[_0xe077('0x9')],_0x2810b4['channel'],_0x2810b4[_0xe077('0xc')],_0x2810b4[_0xe077('0xd')],_0x2810b4[_0xe077('0xe')],_0x2810b4[_0xe077('0xf')],_0x2810b4[_0xe077('0x10')],_0x2810b4[_0xe077('0x11')]));if(_0x2810b4[_0xe077('0x12')]){utils[_0xe077('0x13')](_0x2810b4[_0xe077('0x12')])[_0xe077('0x14')](function(_0x1d8673){if(_0x1d8673){_0x2810b4['UserId']=_0x1d8673['id'];}utils[_0xe077('0x15')](_0xe077('0x16'),_0x2810b4);});}else{utils['request']('CreateVoiceCallReport',_0x2810b4);}if(channels[_0x2810b4['uniqueid']]){delete channels[_0x2810b4[_0xe077('0x9')]];}else if(_0x2e5a85&&channels[_0x2e5a85]){if(!transfers[_0xe077('0x8')][_0x2e5a85][_0xe077('0x17')])delete transfers[_0xe077('0x8')][_0x2e5a85];delete channels[_0x2e5a85];}}exports[_0xe077('0x18')]=function(_0x1787fa){try{utils[_0xe077('0x19')](util[_0xe077('0xb')](_0xe077('0x1a'),_0x1787fa[_0xe077('0x9')]),_0x1787fa);if(_0x1787fa['uniqueid']==_0x1787fa[_0xe077('0x1b')]&&_0x1787fa[_0xe077('0x1c')]!=_0xe077('0x1d')){utils['info'](util[_0xe077('0xb')]('[%s][calls][newchannel]\x20context:%s\x20exten:%s',_0x1787fa[_0xe077('0x9')],_0x1787fa[_0xe077('0x1e')],_0x1787fa[_0xe077('0x1f')]));channels[_0x1787fa['uniqueid']]={'uniqueid':_0x1787fa[_0xe077('0x9')],'accountcode':_0x1787fa[_0xe077('0x12')],'source':_0x1787fa[_0xe077('0xf')],'destination':_0x1787fa[_0xe077('0x1f')],'destinationcontext':_0x1787fa[_0xe077('0x1e')],'channel':_0x1787fa[_0xe077('0x1c')],'starttime':utils[_0xe077('0x20')](),'answertime':null,'systemanswertime':null,'mohtime':0x0,'disposition':_0xe077('0x5'),'amaflags':_0xe077('0x21')};}}catch(_0x5d9a10){utils[_0xe077('0x22')](util[_0xe077('0xb')]('[%s][calls][newchannel]',_0x1787fa[_0xe077('0x9')]),_0x5d9a10);}};exports[_0xe077('0x23')]=function(_0x1db4f1){try{utils[_0xe077('0x19')](util[_0xe077('0xb')](_0xe077('0x24'),_0x1db4f1[_0xe077('0x9')]),_0x1db4f1);if(!_[_0xe077('0x25')](channels[_0x1db4f1['uniqueid']])&&_0x1db4f1[_0xe077('0x26')]==0x6){utils[_0xe077('0x27')](util[_0xe077('0xb')](_0xe077('0x28'),_0x1db4f1[_0xe077('0x9')],_0x1db4f1[_0xe077('0x1e')],_0x1db4f1[_0xe077('0x1c')]));if(_[_0xe077('0x25')](channels[_0x1db4f1[_0xe077('0x9')]][_0xe077('0x29')])){channels[_0x1db4f1[_0xe077('0x9')]][_0xe077('0x29')]=utils[_0xe077('0x20')]();}}else if(!_['isNil'](channels[_0x1db4f1[_0xe077('0x1b')]])&&_0x1db4f1['channelstate']==0x6&&_0x1db4f1[_0xe077('0x1e')]!=_0xe077('0x2a')){utils[_0xe077('0x27')](util['format'](_0xe077('0x2b'),_0x1db4f1[_0xe077('0x9')],_0x1db4f1[_0xe077('0x1b')],_0x1db4f1[_0xe077('0x1e')],_0x1db4f1[_0xe077('0x1c')]));channels[_0x1db4f1[_0xe077('0x1b')]][_0xe077('0x12')]=_0x1db4f1[_0xe077('0x12')];channels[_0x1db4f1[_0xe077('0x1b')]][_0xe077('0x2c')]=_0x1db4f1[_0xe077('0x1c')];if(_[_0xe077('0x25')](channels[_0x1db4f1[_0xe077('0x1b')]][_0xe077('0x2d')])){channels[_0x1db4f1[_0xe077('0x1b')]]['answertime']=utils['now']();}channels[_0x1db4f1[_0xe077('0x1b')]][_0xe077('0x2e')]=dispositions[_['toNumber'](_0x1db4f1['channelstate'])]||_0xe077('0x6');}}catch(_0x3870b1){utils[_0xe077('0x22')](util[_0xe077('0xb')]('[%s][calls][newstate]',_0x1db4f1['uniqueid']),_0x3870b1);}};exports[_0xe077('0x2f')]=function(_0x18ae9f){try{if(!_[_0xe077('0x25')](channels[_0x18ae9f[_0xe077('0x9')]])){utils[_0xe077('0x19')](util['format'](_0xe077('0x30'),_0x18ae9f['uniqueid']),_0x18ae9f);if(_['isNil'](channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x31')])){channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x31')]=_0x18ae9f[_0xe077('0x32')]+'\x20<'+_0x18ae9f['calleridnum']+'>';}utils[_0xe077('0x27')](util[_0xe077('0xb')]('[%s][calls][hangup]\x20callerid:%s\x20reason:%s',_0x18ae9f[_0xe077('0x9')],channels[_0x18ae9f['uniqueid']]['callerid'],_0x18ae9f[_0xe077('0x33')]));channels[_0x18ae9f['uniqueid']]['endtime']=utils[_0xe077('0x20')]();channels[_0x18ae9f[_0xe077('0x9')]]['duration']=utils['diffTime'](channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x34')],channels[_0x18ae9f['uniqueid']]['starttime']);channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x35')]=channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x2d')]?utils[_0xe077('0x36')](channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x34')],channels[_0x18ae9f[_0xe077('0x9')]][_0xe077('0x2d')]):0x0;writeDB(channels[_0x18ae9f[_0xe077('0x9')]]);}}catch(_0x2c4332){utils[_0xe077('0x22')](util[_0xe077('0xb')]('[%s][calls][hangup]',_0x18ae9f[_0xe077('0x9')]),_0x2c4332);}};exports[_0xe077('0x37')]=function(_0x5d0825){try{if(!_[_0xe077('0x25')](channels[_0x5d0825[_0xe077('0x38')]])){utils[_0xe077('0x19')](util['format'](_0xe077('0x39'),_0x5d0825[_0xe077('0x3a')]),_0x5d0825);if(channels[_0x5d0825[_0xe077('0x38')]]['channel']==_0x5d0825[_0xe077('0x3b')]){utils['info'](util[_0xe077('0xb')]('[%s][calls][attendedtransfer]\x20localtwolinkedid:%s\x20destinationchannel:%s',_0x5d0825['origtransfereruniqueid'],_0x5d0825[_0xe077('0x38')],_0x5d0825['secondtransfererchannel']));channels[_0x5d0825[_0xe077('0x38')]]['destinationchannel']=_0x5d0825['secondtransfererchannel'];channels[_0x5d0825[_0xe077('0x38')]][_0xe077('0x3c')]=_0xe077('0x3d');}else if(channels[_0x5d0825[_0xe077('0x38')]][_0xe077('0x1c')]=_0x5d0825[_0xe077('0x3e')]){utils['info'](util[_0xe077('0xb')](_0xe077('0x3f'),_0x5d0825[_0xe077('0x3a')],_0x5d0825[_0xe077('0x38')],_0x5d0825[_0xe077('0x40')]));channels[_0x5d0825['localtwolinkedid']]['destinationchannel']=_0x5d0825[_0xe077('0x40')];channels[_0x5d0825[_0xe077('0x38')]][_0xe077('0x3c')]='_attended';}}}catch(_0xa4c344){utils[_0xe077('0x22')](util[_0xe077('0xb')](_0xe077('0x39'),_0x5d0825[_0xe077('0x3a')]),_0xa4c344);}};exports[_0xe077('0x41')]=function(_0x112375){try{if(!_[_0xe077('0x25')](channels[_0x112375[_0xe077('0x9')]])){utils[_0xe077('0x19')](util[_0xe077('0xb')](_0xe077('0x42'),_0x112375['uniqueid']),_0x112375);channels[_0x112375[_0xe077('0x9')]][_0xe077('0x43')]=utils[_0xe077('0x20')]();utils['info'](util['format'](_0xe077('0x44'),_0x112375[_0xe077('0x9')],channels[_0x112375[_0xe077('0x9')]][_0xe077('0x43')]));}}catch(_0x4b9ff7){utils[_0xe077('0x22')](util[_0xe077('0xb')](_0xe077('0x42'),_0x112375['uniqueid']),_0x4b9ff7);}};exports[_0xe077('0x45')]=function(_0x513a6f){try{if(!_[_0xe077('0x25')](channels[_0x513a6f[_0xe077('0x9')]])){utils[_0xe077('0x19')](util[_0xe077('0xb')](_0xe077('0x46'),_0x513a6f['uniqueid']),_0x513a6f);if(!_[_0xe077('0x25')](channels[_0x513a6f['uniqueid']][_0xe077('0x43')])){channels[_0x513a6f['uniqueid']][_0xe077('0x47')]+=utils[_0xe077('0x36')](utils[_0xe077('0x20')](),channels[_0x513a6f[_0xe077('0x9')]]['musiconholdstartAt']);utils['info'](util['format'](_0xe077('0x48'),_0x513a6f['uniqueid'],channels[_0x513a6f['uniqueid']][_0xe077('0x47')]));delete channels[_0x513a6f[_0xe077('0x9')]][_0xe077('0x43')];}}}catch(_0x115409){utils[_0xe077('0x22')](util['format'](_0xe077('0x46'),_0x513a6f[_0xe077('0x9')]),_0x115409);}};exports['varset']=function(_0x53131){try{if(!_[_0xe077('0x25')](channels[_0x53131[_0xe077('0x9')]])){utils['debug'](util[_0xe077('0xb')](_0xe077('0x49'),_0x53131['uniqueid']),_0x53131);if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')]['xmd-originatecalleridnum'])){utils[_0xe077('0x27')](util['format']('[%s][calls][varset]\x20variable:xmd-originatecalleridnum\x20value:%s',_0x53131[_0xe077('0x9')],_0x53131[_0xe077('0x4b')]));channels[_0x53131[_0xe077('0x9')]][_0xe077('0x4c')]=_0x53131['value'];}if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')][_0xe077('0x4d')])){utils['info'](util[_0xe077('0xb')](_0xe077('0x4e'),_0x53131[_0xe077('0x9')],_0x53131[_0xe077('0x4b')]));channels[_0x53131[_0xe077('0x9')]][_0xe077('0x4f')]=_0x53131['value'];channels[_0x53131[_0xe077('0x9')]][_0xe077('0x31')]='\x22'+_0x53131[_0xe077('0x4b')]+_0xe077('0x50')+_0x53131[_0xe077('0x4b')]+'>';}if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')][_0xe077('0x51')])||!_[_0xe077('0x25')](_0x53131['variable'][_0xe077('0x52')])){utils['info'](util[_0xe077('0xb')](_0xe077('0x53'),_0x53131[_0xe077('0x9')],!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')]['xmd-callerid-preview'])?_0xe077('0x51'):'xmd-callerid',_0x53131[_0xe077('0x4b')]));channels[_0x53131[_0xe077('0x9')]]['callerid']=_0x53131[_0xe077('0x4b')];}if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')][_0xe077('0x54')])||!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')][_0xe077('0x55')])){utils['info'](util[_0xe077('0xb')](_0xe077('0x53'),_0x53131[_0xe077('0x9')],!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')]['xmd-queue'])?_0xe077('0x54'):'xmcs-queue',_0x53131[_0xe077('0x4b')]));channels[_0x53131[_0xe077('0x9')]][_0xe077('0x56')]=_0xe077('0x57');channels[_0x53131['uniqueid']][_0xe077('0x58')]=_0x53131[_0xe077('0x4b')];channels[_0x53131[_0xe077('0x9')]][_0xe077('0xc')]=!![];}if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')][_0xe077('0x59')])){utils[_0xe077('0x27')](util[_0xe077('0xb')](_0xe077('0x5a'),_0x53131[_0xe077('0x9')],_0x53131[_0xe077('0x4b')]));channels[_0x53131['uniqueid']]['ContactId']=_0x53131[_0xe077('0x4b')];}if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')]['xmd-cdrtype'])){utils['info'](util[_0xe077('0xb')](_0xe077('0x5b'),_0x53131[_0xe077('0x9')],_0x53131[_0xe077('0x4b')]));channels[_0x53131[_0xe077('0x9')]][_0xe077('0x5c')]=_0x53131['value'];}if(!_[_0xe077('0x25')](_0x53131[_0xe077('0x4a')][_0xe077('0x5d')])){utils[_0xe077('0x27')](util[_0xe077('0xb')](_0xe077('0x5e'),_0x53131[_0xe077('0x9')],_0x53131[_0xe077('0x4b')]));channels[_0x53131['uniqueid']]['routeid']=_0x53131[_0xe077('0x4b')];}if(!_[_0xe077('0x25')](_0x53131['variable']['sipcallid'])){utils[_0xe077('0x27')](util[_0xe077('0xb')](_0xe077('0x5f'),_0x53131[_0xe077('0x9')],_0x53131['value']));channels[_0x53131[_0xe077('0x9')]]['sipcallid']=_0x53131[_0xe077('0x4b')];}}}catch(_0x3d38ea){utils[_0xe077('0x22')](util[_0xe077('0xb')](_0xe077('0x49'),_0x53131['uniqueid']),_0x3d38ea);}};exports['newexten']=function(_0x18fd47){try{if(!_[_0xe077('0x25')](channels[_0x18fd47[_0xe077('0x9')]])){utils[_0xe077('0x19')](util['format'](_0xe077('0x60'),_0x18fd47[_0xe077('0x9')]),_0x18fd47);utils['info'](util[_0xe077('0xb')](_0xe077('0x61'),_0x18fd47['uniqueid'],_0x18fd47['application'],_0x18fd47[_0xe077('0x62')]));if(_0x18fd47[_0xe077('0x63')]['toLowerCase']()=='set'&&_[_0xe077('0x64')](_0x18fd47[_0xe077('0x62')][_0xe077('0x65')](),_0xe077('0x66'))){var _0xcd762b=_0x18fd47[_0xe077('0x62')][_0xe077('0x67')]('=');var _0x4b01c3=_0xcd762b[0x0][_0xe077('0x68')](_0xcd762b[0x0][_0xe077('0x69')]('(')+0x1,_0xcd762b[0x0]['lastIndexOf'](')'));var _0x1e7312=_0xcd762b[0x1];channels[_0x18fd47[_0xe077('0x9')]][_0x4b01c3]=_0x1e7312;}if(!_[_0xe077('0x6a')]([_0xe077('0x2f'),'noop',_0xe077('0x6b'),_0xe077('0x6c'),_0xe077('0x6d')],_0x18fd47[_0xe077('0x63')][_0xe077('0x65')]())){channels[_0x18fd47[_0xe077('0x9')]]['lastapplication']=_0x18fd47[_0xe077('0x63')];channels[_0x18fd47[_0xe077('0x9')]][_0xe077('0x58')]=_0x18fd47[_0xe077('0x62')];}}}catch(_0x3879f6){utils['error'](util[_0xe077('0xb')](_0xe077('0x60'),_0x18fd47[_0xe077('0x9')]),_0x3879f6);}};