784223b805cbc30e502cf6054519b198e4cd22ea
[motion2.git] / server / services / ami / trigger / integration / zoho.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 _0x11d3=['isBefore','https://accounts.zoho.com','https://accounts.zoho.com.au','https://accounts.zoho.eu','https://accounts.zoho.in','https://accounts.zoho.com.cn','POST','/oauth/v2/token','refreshToken','clientSecret','then','add','seconds','catch','error','Failing\x20creating\x20the\x20access_token','Search\x20user','GET','https://www.zohoapis.%s/crm/v2/users','Zoho-oauthtoken\x20','users','isArrayLikeObject','email','info','Using\x20the\x20admin\x20account!','findIndex','profile','Administrator','user','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','The\x20failing\x20result\x20is','data','https://www.zohoapis.','/crm/v2/','startCase','role','first_name','last_name','SUCCESS','details','enduserType','moduleCreate','log','CREATE\x20ERROR','moduleSearch','contact_lead','/crm/v2/Contacts/search?criteria=((Phone:equals:','Contacts','uri','/crm/v2/Leads/search?criteria=((Phone:equals:','Leads','nothing','lead','Creating\x20new\x20call...','Owner','administrator','Subject','getString','Subjects','Descriptions','Who_Id','Full_Name','First_Name','Last_Name','What_Id','$se_module','talktime','format','mm:ss','answertime','Call_Duration','endtime','YYYY-MM-DDTHH:mm:ss','starttime','complete','connect','Call_Result','rejected','Rejected','abandoned','Abandoned','timeout','Call_Start_Time','outbound','agentcalledAt','Inbound','merge','/crm/v2/Calls','code','Call\x20created!','err','stack','queue','host','serverUrl','stripTrailingSlash','monitor_format','[QUEUE]','Recording\x20is\x20enabled!','recordingURL','/api/voice/recordings/','uniqueid','zoho.eu','com','The\x20User\x20ID\x20is:','calleridname','none','[OUTBOUND]','destcalleridname','destcalleridnum','Outbound','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','trigger:browser:url','https://crm.','/crm/EntityInfo.do?module=Calls&id=','unmanaged','lastevent','toUpperCase','calleridnum','lodash','request-promise','md5','util','./util','bluebird','../../../../config/environment','../../../../config/logger','zoho','redis','defaults','localhost','socket.io-emitter','emit','debug','[HTTP]','stringify','length','forEach','type','string','idField','content','toString','variable','variableName','customVariable','Variable','toLowerCase','name','indexOf','split','isNil','access_token'];(function(_0x1130bd,_0x6ad605){var _0x106f41=function(_0x1d82bc){while(--_0x1d82bc){_0x1130bd['push'](_0x1130bd['shift']());}};_0x106f41(++_0x6ad605);}(_0x11d3,0x1ac));var _0x311d=function(_0x6b6b99,_0x254b9d){_0x6b6b99=_0x6b6b99-0x0;var _0x15fb7e=_0x11d3[_0x6b6b99];return _0x15fb7e;};'use strict';var _=require(_0x311d('0x0'));var rp=require(_0x311d('0x1'));var md5=require(_0x311d('0x2'));var util=require(_0x311d('0x3'));var intUtil=require(_0x311d('0x4'));var moment=require('moment');var Redis=require('ioredis');var BPromise=require(_0x311d('0x5'));var config=require(_0x311d('0x6'));var logger=require(_0x311d('0x7'))(_0x311d('0x8'));config[_0x311d('0x9')]=_[_0x311d('0xa')](config[_0x311d('0x9')],{'host':_0x311d('0xb'),'port':0x18eb});var io=require(_0x311d('0xc'))(new Redis(config['redis']));function emit(_0x1917f5,_0x23fbb9,_0x4402c1){io['to'](_0x1917f5)[_0x311d('0xd')](_0x23fbb9,_0x4402c1);}function request(_0x572bf4){logger[_0x311d('0xe')](_0x311d('0xf'),JSON[_0x311d('0x10')](_0x572bf4));return rp(_0x572bf4);}function getCustomFields(_0x4232dd,_0x5bb5ce){var _0x458f1c={};if(_0x4232dd[_0x311d('0x11')]>0x0){_[_0x311d('0x12')](_0x4232dd,function(_0x15a4dd){if(_0x15a4dd[_0x311d('0x13')]===_0x311d('0x14')&&_0x15a4dd[_0x311d('0x15')]){_0x458f1c[_0x15a4dd[_0x311d('0x15')]]=_0x15a4dd[_0x311d('0x16')][_0x311d('0x17')]();}else if(_0x15a4dd[_0x311d('0x13')]===_0x311d('0x18')&&_0x15a4dd[_0x311d('0x19')]&&_0x15a4dd[_0x311d('0x15')]&&_0x5bb5ce[_0x15a4dd['variableName']]){_0x458f1c[_0x15a4dd[_0x311d('0x15')]]=_0x5bb5ce[_0x15a4dd[_0x311d('0x19')]]['toString']();}else if(_0x15a4dd[_0x311d('0x13')]===_0x311d('0x1a')&&_0x15a4dd['Variable']&&_0x15a4dd[_0x311d('0x1b')]['name']&&_0x15a4dd[_0x311d('0x15')]&&_0x5bb5ce[_0x15a4dd[_0x311d('0x1b')]['name'][_0x311d('0x1c')]()]){_0x458f1c[_0x15a4dd[_0x311d('0x15')]]=_0x5bb5ce[_0x15a4dd[_0x311d('0x1b')][_0x311d('0x1d')][_0x311d('0x1c')]()][_0x311d('0x17')]();}});}return _0x458f1c;}function getName(_0x234a42){if(_0x234a42[_0x311d('0x1e')]('\x20')>0x0){var _0x40403f=_0x234a42[_0x311d('0x1f')](/ (.+)/);if(_0x40403f[0x1]){return _0x40403f;}}return[_0x234a42,_0x234a42];}var accountsTokens={};function getAccessToken(_0x1b4175){return new Promise(function(_0x397700,_0x5021cb){if(!_[_0x311d('0x20')](accountsTokens[_0x1b4175['id']])&&!_[_0x311d('0x20')](accountsTokens[_0x1b4175['id']][_0x311d('0x21')])){if(moment()[_0x311d('0x22')](accountsTokens[_0x1b4175['id']]['expires_in'])){_0x397700(accountsTokens[_0x1b4175['id']]['access_token']);}}var _0x5c3033;switch(_0x1b4175['zone']){case'US':_0x5c3033=_0x311d('0x23');break;case'AU':_0x5c3033=_0x311d('0x24');break;case'EU':_0x5c3033=_0x311d('0x25');break;case'IN':_0x5c3033=_0x311d('0x26');break;case'CN':_0x5c3033=_0x311d('0x27');break;default:_0x5c3033=_0x311d('0x25');break;}var _0x4182dc={'method':_0x311d('0x28'),'uri':_0x5c3033+_0x311d('0x29'),'qs':{'refresh_token':_0x1b4175[_0x311d('0x2a')],'client_id':_0x1b4175['clientId'],'client_secret':_0x1b4175[_0x311d('0x2b')],'grant_type':'refresh_token'},'json':!![]};return rp(_0x4182dc)[_0x311d('0x2c')](function(_0x2fa8ad){accountsTokens[_0x1b4175['id']]={'access_token':_0x2fa8ad['access_token'],'expires_in':moment()[_0x311d('0x2d')](_0x2fa8ad['expires_in'],_0x311d('0x2e'))};_0x397700(_0x2fa8ad[_0x311d('0x21')]);})[_0x311d('0x2f')](function(_0x740861){logger[_0x311d('0x30')](_0x311d('0x31'),_0x740861['stack']);_0x5021cb(_0x740861);});});}function getUser(_0x1f7464,_0x1473a3,_0x5afbbb,_0x2bfc25){logger['info'](_0x311d('0x32'));return request({'method':_0x311d('0x33'),'uri':util['format'](_0x311d('0x34'),_0x1473a3),'qs':{'type':'ActiveUsers'},'headers':{'Authorization':_0x311d('0x35')+_0x1f7464},'json':!![]})[_0x311d('0x2c')](function(_0x5ab125){if(_0x5ab125[_0x311d('0x36')]){var _0xfd5a7c=-0x1;if(_[_0x311d('0x37')](_0x5ab125['users'])){if(!_[_0x311d('0x20')](_0x2bfc25)){_0xfd5a7c=_['findIndex'](_0x5ab125[_0x311d('0x36')],function(_0x1c2ec5){return _0x1c2ec5[_0x311d('0x38')]===_0x2bfc25;});}if(_0xfd5a7c>=0x0){logger[_0x311d('0x39')]('Agent\x20found!');}else{logger[_0x311d('0x39')](_0x311d('0x3a'));_0xfd5a7c=_[_0x311d('0x3b')](_0x5ab125['users'],function(_0x1bcbd3){return _0x1bcbd3[_0x311d('0x3c')][_0x311d('0x1d')]===_0x311d('0x3d');});}return _0x5ab125[_0x311d('0x36')][_0xfd5a7c];}else{if(_0x5ab125[_0x311d('0x3e')][_0x311d('0x3c')][_0x311d('0x1d')]===_0x311d('0x3d')){logger[_0x311d('0x39')](_0x311d('0x3a'));user=_0x5ab125[_0x311d('0x3e')];return user;}else{logger[_0x311d('0x30')]('The\x20failing\x20result\x20is',JSON[_0x311d('0x10')](_0x5ab125));throw new Error(_0x311d('0x3f')+JSON['stringify'](_0x5ab125));}}}else{logger[_0x311d('0x30')](_0x311d('0x40'),JSON[_0x311d('0x10')](_0x5ab125));throw new Error(_0x311d('0x3f')+JSON[_0x311d('0x10')](_0x5ab125));}})[_0x311d('0x2f')](function(_0x5e6533){console['error'](_0x5e6533);});}function getZohoUser(_0x58ecbc,_0x2b278b){return new BPromise(function(_0x46784b,_0x427a03){request(_0x58ecbc)[_0x311d('0x2c')](function(_0x553c01){var _0x434c27=null;if(_0x553c01){_0x434c27=_0x553c01[_0x311d('0x41')][0x0];_0x434c27['enduserType']=_0x2b278b;}_0x46784b(_0x434c27);})[_0x311d('0x2f')](function(_0x265b85){_0x427a03(_0x265b85);});});}function createEndUser(_0x3f4407,_0x4b24f6,_0x55d440,_0x1b090e,_0x16812f,_0x34f828){var _0x55d440=getName(_0x55d440);return request({'method':_0x311d('0x28'),'uri':_0x311d('0x42')+_0x4b24f6+_0x311d('0x43')+_[_0x311d('0x44')](_0x34f828['moduleCreate'])+'s','body':{'data':[{'Last_Name':_0x55d440[0x1],'First_Name':_0x55d440[0x0],'Phone':_0x1b090e,'Owner':{'name':!_['isNil'](_0x16812f[_0x311d('0x45')][_0x311d('0x1d')])?_0x16812f[_0x311d('0x45')][_0x311d('0x1d')]:!_[_0x311d('0x20')](_0x16812f[_0x311d('0x46')])?_0x16812f[_0x311d('0x46')]+'\x20'+_0x16812f[_0x311d('0x47')]:_0x16812f[_0x311d('0x47')],'id':_0x16812f['id']}}]},'headers':{'Authorization':_0x311d('0x35')+_0x3f4407},'json':!![]})[_0x311d('0x2c')](function(_0x107973){if(_0x107973&&_0x107973[_0x311d('0x41')][0x0]['code']===_0x311d('0x48')){var _0x48f52c=_0x107973[_0x311d('0x41')][0x0][_0x311d('0x49')];_0x48f52c[_0x311d('0x4a')]=_[_0x311d('0x44')](_0x34f828[_0x311d('0x4b')])+'s';return _0x48f52c;}logger[_0x311d('0x30')]('The\x20failing\x20result\x20is',JSON['stringify'](data));throw new Error('Error:\x20'+JSON[_0x311d('0x10')](data));})[_0x311d('0x2f')](function(_0x64ef1b){console[_0x311d('0x4c')](_0x311d('0x4d'),_0x64ef1b);});}function getEndUser(_0x5ceb45,_0x10880e,_0x155cb5,_0x5bce0d,_0x484a90,_0x5ba0b2,_0x58323f){var _0x4b1302={'method':'GET','uri':'','headers':{'Authorization':_0x311d('0x35')+_0x5ceb45},'json':!![]};switch(_0x58323f[_0x311d('0x4e')]){case _0x311d('0x4f'):_0x4b1302['uri']=_0x311d('0x42')+_0x10880e+_0x311d('0x50')+_0x484a90+'))';return getZohoUser(_0x4b1302,_0x311d('0x51'))[_0x311d('0x2c')](function(_0x14beef){if(_0x14beef)return _0x14beef;_0x4b1302[_0x311d('0x52')]=_0x311d('0x42')+_0x10880e+_0x311d('0x53')+_0x484a90+'))';return getZohoUser(_0x4b1302,_0x311d('0x54'))[_0x311d('0x2c')](function(_0x397242){if(_0x397242)return _0x397242;if(_0x58323f[_0x311d('0x4b')]!=_0x311d('0x55')){return createEndUser(_0x5ceb45,_0x10880e,_0x5bce0d,_0x484a90,_0x5ba0b2,_0x58323f);}else{return{};}});});break;case'contact':_0x4b1302['uri']=_0x311d('0x42')+_0x10880e+'/crm/v2/Contacts/search?criteria=((Phone:equals:'+_0x484a90+'))';return getZohoUser(_0x4b1302,'Contacts')[_0x311d('0x2c')](function(_0xdf81bb){if(_0xdf81bb)return _0xdf81bb;if(_0x58323f[_0x311d('0x4b')]!=_0x311d('0x55')){return createEndUser(_0x5ceb45,_0x10880e,_0x5bce0d,_0x484a90,_0x5ba0b2,_0x58323f);}else{return{};}});break;case _0x311d('0x56'):_0x4b1302[_0x311d('0x52')]='https://www.zohoapis.'+_0x10880e+_0x311d('0x53')+_0x484a90+'))';return getZohoUser(_0x4b1302,'Leads')[_0x311d('0x2c')](function(_0x33f565){if(_0x33f565)return _0x33f565;if(_0x58323f[_0x311d('0x4b')]!=_0x311d('0x55')){return createEndUser(_0x5ceb45,_0x10880e,_0x5bce0d,_0x484a90,_0x5ba0b2,_0x58323f);}else{return{};}});break;}}function getCall(_0x3e69bf,_0x1709b3,_0x29352d,_0x1707ca,_0x1de750,_0x266d5a,_0x49c3b1,_0x4ee3ef){logger[_0x311d('0x39')](_0x311d('0x57'));var _0xf5c0fe={};_0xf5c0fe[_0x311d('0x58')]={'name':!_[_0x311d('0x20')](_0x1707ca[_0x311d('0x45')]['name'])&&!_['isNil'](_0x1707ca[_0x311d('0x3c')][_0x311d('0x1d')])&&_0x1707ca[_0x311d('0x3c')][_0x311d('0x1d')]===_0x311d('0x59')?_0x1707ca[_0x311d('0x45')]['name']:!_['isNil'](_0x1707ca[_0x311d('0x46')])?_0x1707ca[_0x311d('0x46')]+'\x20'+_0x1707ca['last_name']:_0x1707ca[_0x311d('0x47')],'id':_0x1707ca['id']};_0xf5c0fe[_0x311d('0x5a')]=intUtil[_0x311d('0x5b')](_0x266d5a[_0x311d('0x5c')],_0x49c3b1,'\x20');_0xf5c0fe['Description']=intUtil['getString'](_0x266d5a[_0x311d('0x5d')],_0x49c3b1,'\x0a');if(_0x1de750[_0x311d('0x4a')]==='Contacts'){_0xf5c0fe[_0x311d('0x5e')]={'name':!_[_0x311d('0x20')](_0x1de750[_0x311d('0x5f')])?_0x1de750['Full_Name']:!_[_0x311d('0x20')](_0x1de750[_0x311d('0x60')])?_0x1de750['First_Name']+'\x20'+_0x1de750[_0x311d('0x61')]:_0x1de750[_0x311d('0x61')],'id':_0x1de750['id']};}if(_0x1de750[_0x311d('0x4a')]===_0x311d('0x54')){_0xf5c0fe[_0x311d('0x62')]={'name':!_[_0x311d('0x20')](_0x1de750[_0x311d('0x5f')])?_0x1de750['Full_Name']:!_[_0x311d('0x20')](_0x1de750[_0x311d('0x60')])?_0x1de750['First_Name']+'\x20'+_0x1de750[_0x311d('0x61')]:_0x1de750[_0x311d('0x61')],'id':_0x1de750['id']};_0xf5c0fe[_0x311d('0x63')]=_[_0x311d('0x44')](_0x1de750['enduserType']);}if(_0x49c3b1[_0x311d('0x64')]){_0xf5c0fe['Call_Duration']=moment['utc'](parseInt(_0x49c3b1[_0x311d('0x64')])*0x3e8)[_0x311d('0x65')](_0x311d('0x66'));}else if(_0x49c3b1[_0x311d('0x67')]&&_0x49c3b1['endtime']){_0xf5c0fe[_0x311d('0x68')]=moment['utc'](moment(_0x49c3b1[_0x311d('0x69')],_0x311d('0x6a'))['diff'](moment(_0x49c3b1[_0x311d('0x6b')],_0x311d('0x6a'))))[_0x311d('0x65')]('mm:ss');}switch(_0x49c3b1['lastevent']){case'called':_0xf5c0fe['Call_Result']='Called';break;case _0x311d('0x6c'):case _0x311d('0x6d'):_0xf5c0fe[_0x311d('0x6e')]='Answered';break;case _0x311d('0x6f'):_0xf5c0fe[_0x311d('0x6e')]=_0x311d('0x70');break;case _0x311d('0x71'):_0xf5c0fe[_0x311d('0x6e')]=_0x311d('0x72');break;case _0x311d('0x73'):_0xf5c0fe[_0x311d('0x6e')]='Timeout';default:}_0xf5c0fe[_0x311d('0x74')]=(_0x4ee3ef===_0x311d('0x75')?moment(_0x49c3b1[_0x311d('0x6b')])[_0x311d('0x65')](_0x311d('0x6a')):moment(_0x49c3b1[_0x311d('0x76')])['format'](_0x311d('0x6a')))||moment()[_0x311d('0x65')]('YYYY-MM-DDTHH:mm:ss');_0xf5c0fe['Call_Type']=_0x4ee3ef||_0x311d('0x77');_0xf5c0fe=_[_0x311d('0x78')](_0xf5c0fe,getCustomFields(_0x266d5a['Fields'],_0x49c3b1));return request({'method':_0x311d('0x28'),'uri':_0x311d('0x42')+_0x1709b3+_0x311d('0x79'),'headers':{'Authorization':'Zoho-oauthtoken\x20'+_0x3e69bf},'body':{'data':[_0xf5c0fe]},'json':!![]})[_0x311d('0x2c')](function(_0x176000){if(_0x176000&&_0x176000[_0x311d('0x41')][0x0][_0x311d('0x7a')]===_0x311d('0x48')){logger[_0x311d('0x39')](_0x311d('0x7b'));return{'id':_0x176000[_0x311d('0x41')][0x0][_0x311d('0x49')]['id']};}})[_0x311d('0x2f')](function(_0x5442c2){logger[_0x311d('0x39')](_0x311d('0x7c'),_0x5442c2[_0x311d('0x7d')]);console[_0x311d('0x4c')](_0x311d('0x7c'),_0x5442c2);});}exports[_0x311d('0x7e')]=function(_0x503108,_0x18f700,_0x22e1fb,_0x5ea76b,_0x5e2808,_0x19bda3){var _0x25691a,_0x53cd38,_0x208659;_0x19bda3['host']=intUtil['stripTrailingSlash'](_0x19bda3[_0x311d('0x7f')]);_0x19bda3[_0x311d('0x80')]=intUtil[_0x311d('0x81')](_0x19bda3['serverUrl']);if(_0x5e2808&&_0x5e2808[_0x311d('0x82')]){logger[_0x311d('0x39')](_0x311d('0x83'),_0x311d('0x84'));_0x18f700[_0x311d('0x85')]=_0x19bda3[_0x311d('0x80')]+_0x311d('0x86')+_0x18f700[_0x311d('0x87')]+'/downloads?type=uniqueid&token='+md5(_0x18f700['uniqueid']);}else{_0x18f700['recordingURL']='';}var _0x5a45b3=_0x19bda3['host']===_0x311d('0x88')?'eu':_0x311d('0x89');return getAccessToken(_0x19bda3)['then'](function(_0x5f1ad0){_0x208659=_0x5f1ad0;return getUser(_0x208659,_0x5a45b3,_0x19bda3,_0x5ea76b[_0x311d('0x38')]);})[_0x311d('0x2c')](function(_0x1b0a60){_0x25691a=_0x1b0a60;logger[_0x311d('0x39')](_0x311d('0x8a'),_0x25691a['id']);return getEndUser(_0x208659,_0x5a45b3,_0x19bda3,_0x18f700[_0x311d('0x8b')],_0x18f700['calleridnum'],_0x25691a,_0x22e1fb);})[_0x311d('0x2c')](function(_0x40c8f2){_0x53cd38=_0x40c8f2;return getCall(_0x208659,_0x5a45b3,_0x19bda3,_0x25691a,_0x53cd38,_0x22e1fb,_0x18f700,_0x311d('0x77'));})[_0x311d('0x2c')](function(_0x124f77){if(_0x124f77){logger[_0x311d('0x39')]('The\x20Call\x20ID\x20is:',_0x124f77['id']);logger[_0x311d('0x39')](_0x311d('0x83'),'Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...');emit(util[_0x311d('0x65')]('user:%s',_0x5ea76b[_0x311d('0x1d')]),'trigger:browser:url',{'uri':'https://crm.'+_0x19bda3[_0x311d('0x7f')]+'/crm/EntityInfo.do?module=Calls&id='+_0x124f77['id']});}})['catch'](function(_0x1f9e59){logger[_0x311d('0x30')]('[QUEUE]',JSON['stringify'](_0x1f9e59));});};exports[_0x311d('0x75')]=function(_0x1d524c,_0x3304de,_0x411055,_0x98da2,_0x3dbe4f,_0x4c1dd9,_0x12a061){var _0x150e5f,_0x1de97b,_0x32a3a6;_0x4c1dd9[_0x311d('0x7f')]=intUtil[_0x311d('0x81')](_0x4c1dd9['host']);_0x4c1dd9['serverUrl']=intUtil[_0x311d('0x81')](_0x4c1dd9['serverUrl']);if(_0x12a061&&_0x12a061['recordingFormat']&&_0x12a061['recordingFormat']!==_0x311d('0x8c')){logger[_0x311d('0x39')](_0x311d('0x8d'),_0x311d('0x84'));_0x3304de[_0x311d('0x85')]=_0x4c1dd9[_0x311d('0x80')]+_0x311d('0x86')+_0x3304de[_0x311d('0x87')]+'/downloads?type=uniqueid&token='+md5(_0x3304de['uniqueid']);}var _0x458e9f=_0x4c1dd9[_0x311d('0x7f')]===_0x311d('0x88')?'eu':_0x311d('0x89');return getAccessToken(_0x4c1dd9)[_0x311d('0x2c')](function(_0x2f72a9){_0x32a3a6=_0x2f72a9;return getUser(_0x32a3a6,_0x458e9f,_0x4c1dd9,_0x98da2['email']);})['then'](function(_0x481f42){_0x150e5f=_0x481f42;logger['info'](_0x311d('0x8a'),_0x150e5f['id']);return getEndUser(_0x32a3a6,_0x458e9f,_0x4c1dd9,_0x3304de[_0x311d('0x8e')],_0x3304de[_0x311d('0x8f')],_0x150e5f,_0x411055);})[_0x311d('0x2c')](function(_0x328814){_0x1de97b=_0x328814;return getCall(_0x32a3a6,_0x458e9f,_0x4c1dd9,_0x150e5f,_0x1de97b,_0x411055,_0x3304de,_0x311d('0x90'));})[_0x311d('0x2c')](function(_0x3daddf){if(_0x3daddf){logger['info'](_0x311d('0x91'),_0x3daddf['id']);logger[_0x311d('0x39')](_0x311d('0x8d'),_0x311d('0x92'));emit(util['format']('user:%s',_0x98da2[_0x311d('0x1d')]),_0x311d('0x93'),{'uri':_0x311d('0x94')+_0x4c1dd9[_0x311d('0x7f')]+_0x311d('0x95')+_0x3daddf['id']});}})[_0x311d('0x2f')](function(_0x25ea3b){logger['error']('[OUTBOUND]',JSON[_0x311d('0x10')](_0x25ea3b));});};exports[_0x311d('0x96')]=function(_0x4ae43a,_0x1804c3,_0x3d6950,_0x4a8544,_0x5617cb,_0x18c8b1){var _0x21709f,_0x15784d,_0x3eaf9c;_0x18c8b1[_0x311d('0x7f')]=intUtil[_0x311d('0x81')](_0x18c8b1['host']);_0x18c8b1[_0x311d('0x80')]=intUtil[_0x311d('0x81')](_0x18c8b1[_0x311d('0x80')]);if(_0x5617cb&&_0x5617cb['monitor_format']){logger[_0x311d('0x39')]('['+_0x1804c3[_0x311d('0x97')][_0x311d('0x98')]()+']',_0x311d('0x84'));_0x1804c3[_0x311d('0x85')]=_0x18c8b1[_0x311d('0x80')]+'/api/voice/recordings/'+_0x1804c3['uniqueid']+'/downloads?type=uniqueid&token='+md5(_0x1804c3[_0x311d('0x87')]);}else{_0x1804c3['recordingURL']='';}var _0x89df2d=_0x18c8b1[_0x311d('0x7f')]===_0x311d('0x88')?'eu':'com';return getAccessToken(_0x18c8b1)[_0x311d('0x2c')](function(_0x48533b){_0x3eaf9c=_0x48533b;return getUser(_0x3eaf9c,_0x89df2d,_0x18c8b1);})[_0x311d('0x2c')](function(_0x3f65c2){_0x21709f=_0x3f65c2;logger[_0x311d('0x39')](_0x311d('0x8a'),_0x21709f['id']);return getEndUser(_0x3eaf9c,_0x89df2d,_0x18c8b1,_0x1804c3[_0x311d('0x8b')],_0x1804c3[_0x311d('0x99')],_0x21709f,_0x3d6950);})[_0x311d('0x2c')](function(_0x55e3df){_0x15784d=_0x55e3df;return getCall(_0x3eaf9c,_0x89df2d,_0x18c8b1,_0x21709f,_0x15784d,_0x3d6950,_0x1804c3,'Inbound');})[_0x311d('0x2c')](function(_0xd204cf){if(_0xd204cf){logger[_0x311d('0x39')](_0x311d('0x91'),_0xd204cf['id']);}})[_0x311d('0x2f')](function(_0x480bb7){logger['error']('['+_0x1804c3[_0x311d('0x97')][_0x311d('0x98')]()+']',JSON[_0x311d('0x10')](_0x480bb7));});};