Built motion from commit 3c2ce842.|2.6.31
[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 _0xb0db=['recordingFormat','none','com','destcalleridname','destcalleridnum','[OUTBOUND]','unmanaged','toUpperCase','request-promise','md5','util','./util','moment','ioredis','bluebird','../../../../config/logger','zoho','redis','defaults','emit','debug','length','forEach','includes','string','idField','toString','variable','variableName','type','customVariable','Variable','name','toLowerCase','indexOf','split','isNil','access_token','expires_in','zone','https://accounts.zoho.com','https://accounts.zoho.com.au','https://accounts.zoho.eu','/oauth/v2/token','refreshToken','clientId','refresh_token','add','seconds','catch','error','Failing\x20creating\x20the\x20access_token','stack','Search\x20user','GET','format','Zoho-oauthtoken\x20','then','isArrayLikeObject','findIndex','info','Agent\x20found!','Using\x20the\x20admin\x20account!','users','profile','Administrator','user','The\x20failing\x20result\x20is','stringify','Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20','data','enduserType','POST','https://www.zohoapis.','/crm/v2/','startCase','moduleCreate','role','first_name','last_name','SUCCESS','details','CREATE\x20ERROR','moduleSearch','contact_lead','uri','Contacts','/crm/v2/Leads/search?criteria=((Phone:equals:','nothing','contact','/crm/v2/Contacts/search?criteria=((Phone:equals:','lead','Leads','Owner','administrator','Subject','getString','Subjects','Descriptions','Full_Name','First_Name','Last_Name','What_Id','$se_module','talktime','Call_Duration','utc','mm:ss','answertime','endtime','YYYY-MM-DDTHH:mm:ss','diff','starttime','lastevent','called','Call_Result','Called','complete','connect','Answered','rejected','Rejected','abandoned','Abandoned','timeout','Timeout','outbound','agentcalledAt','Call_Type','Fields','code','err','log','host','serverUrl','monitor_format','[QUEUE]','Recording\x20is\x20enabled!','recordingURL','/api/voice/recordings/','/downloads?type=uniqueid&token=','uniqueid','zoho.eu','email','The\x20User\x20ID\x20is:','calleridname','calleridnum','Inbound','The\x20Call\x20ID\x20is:','Displaying\x20call\x20to\x20agent\x20in\x20a\x20new\x20tab...','user:%s','trigger:browser:url','https://crm.','/crm/EntityInfo.do?module=Calls&id=','stripTrailingSlash'];(function(_0x3cb152,_0x57eb54){var _0x4f54c3=function(_0x273a45){while(--_0x273a45){_0x3cb152['push'](_0x3cb152['shift']());}};_0x4f54c3(++_0x57eb54);}(_0xb0db,0xa3));var _0xbb0d=function(_0x46ee98,_0xb0d78c){_0x46ee98=_0x46ee98-0x0;var _0x6fad51=_0xb0db[_0x46ee98];return _0x6fad51;};'use strict';var _=require('lodash');var rp=require(_0xbb0d('0x0'));var md5=require(_0xbb0d('0x1'));var util=require(_0xbb0d('0x2'));var intUtil=require(_0xbb0d('0x3'));var moment=require(_0xbb0d('0x4'));var Redis=require(_0xbb0d('0x5'));var BPromise=require(_0xbb0d('0x6'));var config=require('../../../../config/environment');var logger=require(_0xbb0d('0x7'))(_0xbb0d('0x8'));config[_0xbb0d('0x9')]=_[_0xbb0d('0xa')](config[_0xbb0d('0x9')],{'host':'localhost','port':0x18eb});var io=require('socket.io-emitter')(new Redis(config['redis']));function emit(_0x50cb7e,_0x2d2ff7,_0x2bccd2){io['to'](_0x50cb7e)[_0xbb0d('0xb')](_0x2d2ff7,_0x2bccd2);}function request(_0x5d8ba2){logger[_0xbb0d('0xc')]('[HTTP]',JSON['stringify'](_0x5d8ba2));return rp(_0x5d8ba2);}function getCustomFields(_0x17d5ae,_0xcaebec){var _0x55a820={};if(_0x17d5ae[_0xbb0d('0xd')]>0x0){_[_0xbb0d('0xe')](_0x17d5ae,function(_0xddbc47){if(_[_0xbb0d('0xf')]([_0xbb0d('0x10'),'picklist'],_0xddbc47['type'])&&_0xddbc47['idField']){_0x55a820[_0xddbc47[_0xbb0d('0x11')]]=_0xddbc47['content'][_0xbb0d('0x12')]();}else if(_0xddbc47['type']===_0xbb0d('0x13')&&_0xddbc47['variableName']&&_0xddbc47['idField']&&_0xcaebec[_0xddbc47[_0xbb0d('0x14')]]){_0x55a820[_0xddbc47[_0xbb0d('0x11')]]=_0xcaebec[_0xddbc47[_0xbb0d('0x14')]][_0xbb0d('0x12')]();}else if(_0xddbc47[_0xbb0d('0x15')]===_0xbb0d('0x16')&&_0xddbc47[_0xbb0d('0x17')]&&_0xddbc47[_0xbb0d('0x17')]['name']&&_0xddbc47['idField']&&_0xcaebec[_0xddbc47[_0xbb0d('0x17')][_0xbb0d('0x18')]['toLowerCase']()]){_0x55a820[_0xddbc47[_0xbb0d('0x11')]]=_0xcaebec[_0xddbc47[_0xbb0d('0x17')][_0xbb0d('0x18')][_0xbb0d('0x19')]()]['toString']();}});}return _0x55a820;}function getName(_0x3f28c5){if(_0x3f28c5[_0xbb0d('0x1a')]('\x20')>0x0){var _0x9c13a=_0x3f28c5[_0xbb0d('0x1b')](/ (.+)/);if(_0x9c13a[0x1]){return _0x9c13a;}}return[_0x3f28c5,_0x3f28c5];}var accountsTokens={};function getAccessToken(_0x270169){return new Promise(function(_0x19761e,_0x1d113e){if(!_['isNil'](accountsTokens[_0x270169['id']])&&!_[_0xbb0d('0x1c')](accountsTokens[_0x270169['id']][_0xbb0d('0x1d')])){if(moment()['isBefore'](accountsTokens[_0x270169['id']][_0xbb0d('0x1e')])){_0x19761e(accountsTokens[_0x270169['id']][_0xbb0d('0x1d')]);}}var _0x3e0c44;switch(_0x270169[_0xbb0d('0x1f')]){case'US':_0x3e0c44=_0xbb0d('0x20');break;case'AU':_0x3e0c44=_0xbb0d('0x21');break;case'EU':_0x3e0c44='https://accounts.zoho.eu';break;case'IN':_0x3e0c44='https://accounts.zoho.in';break;case'CN':_0x3e0c44='https://accounts.zoho.com.cn';break;default:_0x3e0c44=_0xbb0d('0x22');break;}var _0x5af9ed={'method':'POST','uri':_0x3e0c44+_0xbb0d('0x23'),'qs':{'refresh_token':_0x270169[_0xbb0d('0x24')],'client_id':_0x270169[_0xbb0d('0x25')],'client_secret':_0x270169['clientSecret'],'grant_type':_0xbb0d('0x26')},'json':!![]};return rp(_0x5af9ed)['then'](function(_0x1cfff2){accountsTokens[_0x270169['id']]={'access_token':_0x1cfff2[_0xbb0d('0x1d')],'expires_in':moment()[_0xbb0d('0x27')](_0x1cfff2[_0xbb0d('0x1e')],_0xbb0d('0x28'))};_0x19761e(_0x1cfff2[_0xbb0d('0x1d')]);})[_0xbb0d('0x29')](function(_0x44e436){logger[_0xbb0d('0x2a')](_0xbb0d('0x2b'),_0x44e436[_0xbb0d('0x2c')]);_0x1d113e(_0x44e436);});});}function getUser(_0x20fe83,_0x14adbe,_0x2278e3,_0x57b26f){logger['info'](_0xbb0d('0x2d'));return request({'method':_0xbb0d('0x2e'),'uri':util[_0xbb0d('0x2f')]('https://www.zohoapis.%s/crm/v2/users',_0x14adbe),'qs':{'type':'ActiveUsers'},'headers':{'Authorization':_0xbb0d('0x30')+_0x20fe83},'json':!![]})[_0xbb0d('0x31')](function(_0x3b5d57){if(_0x3b5d57['users']){var _0x30e208=-0x1;if(_[_0xbb0d('0x32')](_0x3b5d57['users'])){if(!_['isNil'](_0x57b26f)){_0x30e208=_[_0xbb0d('0x33')](_0x3b5d57['users'],function(_0x56579d){return _0x56579d['email']===_0x57b26f;});}if(_0x30e208>=0x0){logger[_0xbb0d('0x34')](_0xbb0d('0x35'));}else{logger[_0xbb0d('0x34')](_0xbb0d('0x36'));_0x30e208=_[_0xbb0d('0x33')](_0x3b5d57[_0xbb0d('0x37')],function(_0x1622df){return _0x1622df[_0xbb0d('0x38')][_0xbb0d('0x18')]===_0xbb0d('0x39');});}return _0x3b5d57[_0xbb0d('0x37')][_0x30e208];}else{if(_0x3b5d57[_0xbb0d('0x3a')]['profile'][_0xbb0d('0x18')]==='Administrator'){logger[_0xbb0d('0x34')](_0xbb0d('0x36'));user=_0x3b5d57[_0xbb0d('0x3a')];return user;}else{logger[_0xbb0d('0x2a')](_0xbb0d('0x3b'),JSON[_0xbb0d('0x3c')](_0x3b5d57));throw new Error(_0xbb0d('0x3d')+JSON[_0xbb0d('0x3c')](_0x3b5d57));}}}else{logger['error'](_0xbb0d('0x3b'),JSON[_0xbb0d('0x3c')](_0x3b5d57));throw new Error('Unable\x20to\x20retrieve\x20zoho\x20account\x20users:\x20'+JSON[_0xbb0d('0x3c')](_0x3b5d57));}})[_0xbb0d('0x29')](function(_0x455ccb){console[_0xbb0d('0x2a')](_0x455ccb);});}function getZohoUser(_0x14f0bd,_0x3f0d09){return new BPromise(function(_0x46e903,_0x57d3cd){request(_0x14f0bd)[_0xbb0d('0x31')](function(_0x309168){var _0x5b1c36=null;if(_0x309168){_0x5b1c36=_0x309168[_0xbb0d('0x3e')][0x0];_0x5b1c36[_0xbb0d('0x3f')]=_0x3f0d09;}_0x46e903(_0x5b1c36);})[_0xbb0d('0x29')](function(_0x1dbcc2){_0x57d3cd(_0x1dbcc2);});});}function createEndUser(_0x5ad1a4,_0x40c964,_0x23c580,_0x5e4164,_0x36c3a2,_0x47c1ec){var _0x23c580=getName(_0x23c580);return request({'method':_0xbb0d('0x40'),'uri':_0xbb0d('0x41')+_0x40c964+_0xbb0d('0x42')+_[_0xbb0d('0x43')](_0x47c1ec[_0xbb0d('0x44')])+'s','body':{'data':[{'Last_Name':_0x23c580[0x1],'First_Name':_0x23c580[0x0],'Phone':_0x5e4164,'Owner':{'name':!_['isNil'](_0x36c3a2['role']['name'])?_0x36c3a2[_0xbb0d('0x45')]['name']:!_['isNil'](_0x36c3a2['first_name'])?_0x36c3a2[_0xbb0d('0x46')]+'\x20'+_0x36c3a2[_0xbb0d('0x47')]:_0x36c3a2[_0xbb0d('0x47')],'id':_0x36c3a2['id']}}]},'headers':{'Authorization':_0xbb0d('0x30')+_0x5ad1a4},'json':!![]})[_0xbb0d('0x31')](function(_0x24d054){if(_0x24d054&&_0x24d054[_0xbb0d('0x3e')][0x0]['code']===_0xbb0d('0x48')){var _0x261990=_0x24d054[_0xbb0d('0x3e')][0x0][_0xbb0d('0x49')];_0x261990[_0xbb0d('0x3f')]=_[_0xbb0d('0x43')](_0x47c1ec[_0xbb0d('0x44')])+'s';return _0x261990;}logger[_0xbb0d('0x2a')](_0xbb0d('0x3b'),JSON[_0xbb0d('0x3c')](data));throw new Error('Error:\x20'+JSON[_0xbb0d('0x3c')](data));})['catch'](function(_0x1d22f7){console['log'](_0xbb0d('0x4a'),_0x1d22f7);});}function getEndUser(_0x1d89f2,_0xa3cf26,_0x2e8762,_0x107808,_0x492658,_0x1340fd,_0x948a40){var _0x130e10={'method':'GET','uri':'','headers':{'Authorization':_0xbb0d('0x30')+_0x1d89f2},'json':!![]};switch(_0x948a40[_0xbb0d('0x4b')]){case _0xbb0d('0x4c'):_0x130e10[_0xbb0d('0x4d')]=_0xbb0d('0x41')+_0xa3cf26+'/crm/v2/Contacts/search?criteria=((Phone:equals:'+_0x492658+'))';return getZohoUser(_0x130e10,_0xbb0d('0x4e'))['then'](function(_0x18cd24){if(_0x18cd24)return _0x18cd24;_0x130e10[_0xbb0d('0x4d')]='https://www.zohoapis.'+_0xa3cf26+_0xbb0d('0x4f')+_0x492658+'))';return getZohoUser(_0x130e10,'Leads')[_0xbb0d('0x31')](function(_0x26819d){if(_0x26819d)return _0x26819d;if(_0x948a40[_0xbb0d('0x44')]!=_0xbb0d('0x50')){return createEndUser(_0x1d89f2,_0xa3cf26,_0x107808,_0x492658,_0x1340fd,_0x948a40);}else{return{};}});});break;case _0xbb0d('0x51'):_0x130e10[_0xbb0d('0x4d')]=_0xbb0d('0x41')+_0xa3cf26+_0xbb0d('0x52')+_0x492658+'))';return getZohoUser(_0x130e10,'Contacts')[_0xbb0d('0x31')](function(_0x34a7a5){if(_0x34a7a5)return _0x34a7a5;if(_0x948a40['moduleCreate']!='nothing'){return createEndUser(_0x1d89f2,_0xa3cf26,_0x107808,_0x492658,_0x1340fd,_0x948a40);}else{return{};}});break;case _0xbb0d('0x53'):_0x130e10[_0xbb0d('0x4d')]=_0xbb0d('0x41')+_0xa3cf26+_0xbb0d('0x4f')+_0x492658+'))';return getZohoUser(_0x130e10,_0xbb0d('0x54'))[_0xbb0d('0x31')](function(_0x22a985){if(_0x22a985)return _0x22a985;if(_0x948a40['moduleCreate']!=_0xbb0d('0x50')){return createEndUser(_0x1d89f2,_0xa3cf26,_0x107808,_0x492658,_0x1340fd,_0x948a40);}else{return{};}});break;}}function getCall(_0x452387,_0x20f728,_0x1225e1,_0x30b547,_0x28d41e,_0x41e1b0,_0x375d55,_0xba2015){logger[_0xbb0d('0x34')]('Creating\x20new\x20call...');var _0x5ea223={};_0x5ea223[_0xbb0d('0x55')]={'name':!_[_0xbb0d('0x1c')](_0x30b547[_0xbb0d('0x45')]['name'])&&!_['isNil'](_0x30b547[_0xbb0d('0x38')][_0xbb0d('0x18')])&&_0x30b547['profile']['name']===_0xbb0d('0x56')?_0x30b547[_0xbb0d('0x45')]['name']:!_['isNil'](_0x30b547[_0xbb0d('0x46')])?_0x30b547[_0xbb0d('0x46')]+'\x20'+_0x30b547[_0xbb0d('0x47')]:_0x30b547[_0xbb0d('0x47')],'id':_0x30b547['id']};_0x5ea223[_0xbb0d('0x57')]=intUtil[_0xbb0d('0x58')](_0x41e1b0[_0xbb0d('0x59')],_0x375d55,'\x20');_0x5ea223['Description']=intUtil[_0xbb0d('0x58')](_0x41e1b0[_0xbb0d('0x5a')],_0x375d55,'\x0a');if(_0x28d41e[_0xbb0d('0x3f')]===_0xbb0d('0x4e')){_0x5ea223['Who_Id']={'name':!_[_0xbb0d('0x1c')](_0x28d41e[_0xbb0d('0x5b')])?_0x28d41e[_0xbb0d('0x5b')]:!_['isNil'](_0x28d41e['First_Name'])?_0x28d41e[_0xbb0d('0x5c')]+'\x20'+_0x28d41e['Last_Name']:_0x28d41e[_0xbb0d('0x5d')],'id':_0x28d41e['id']};}if(_0x28d41e[_0xbb0d('0x3f')]===_0xbb0d('0x54')){_0x5ea223[_0xbb0d('0x5e')]={'name':!_['isNil'](_0x28d41e[_0xbb0d('0x5b')])?_0x28d41e[_0xbb0d('0x5b')]:!_[_0xbb0d('0x1c')](_0x28d41e[_0xbb0d('0x5c')])?_0x28d41e[_0xbb0d('0x5c')]+'\x20'+_0x28d41e[_0xbb0d('0x5d')]:_0x28d41e[_0xbb0d('0x5d')],'id':_0x28d41e['id']};_0x5ea223[_0xbb0d('0x5f')]=_[_0xbb0d('0x43')](_0x28d41e[_0xbb0d('0x3f')]);}if(_0x375d55[_0xbb0d('0x60')]){_0x5ea223[_0xbb0d('0x61')]=moment[_0xbb0d('0x62')](parseInt(_0x375d55[_0xbb0d('0x60')])*0x3e8)[_0xbb0d('0x2f')](_0xbb0d('0x63'));}else if(_0x375d55[_0xbb0d('0x64')]&&_0x375d55['endtime']){_0x5ea223[_0xbb0d('0x61')]=moment[_0xbb0d('0x62')](moment(_0x375d55[_0xbb0d('0x65')],_0xbb0d('0x66'))[_0xbb0d('0x67')](moment(_0x375d55[_0xbb0d('0x68')],'YYYY-MM-DDTHH:mm:ss')))[_0xbb0d('0x2f')](_0xbb0d('0x63'));}switch(_0x375d55[_0xbb0d('0x69')]){case _0xbb0d('0x6a'):_0x5ea223[_0xbb0d('0x6b')]=_0xbb0d('0x6c');break;case _0xbb0d('0x6d'):case _0xbb0d('0x6e'):_0x5ea223[_0xbb0d('0x6b')]=_0xbb0d('0x6f');break;case _0xbb0d('0x70'):_0x5ea223[_0xbb0d('0x6b')]=_0xbb0d('0x71');break;case _0xbb0d('0x72'):_0x5ea223[_0xbb0d('0x6b')]=_0xbb0d('0x73');break;case _0xbb0d('0x74'):_0x5ea223['Call_Result']=_0xbb0d('0x75');default:}_0x5ea223['Call_Start_Time']=(_0xba2015===_0xbb0d('0x76')?moment(_0x375d55[_0xbb0d('0x68')])[_0xbb0d('0x2f')](_0xbb0d('0x66')):moment(_0x375d55[_0xbb0d('0x77')])[_0xbb0d('0x2f')](_0xbb0d('0x66')))||moment()[_0xbb0d('0x2f')](_0xbb0d('0x66'));_0x5ea223[_0xbb0d('0x78')]=_0xba2015||'Inbound';_0x5ea223=_['merge'](_0x5ea223,getCustomFields(_0x41e1b0[_0xbb0d('0x79')],_0x375d55));return request({'method':_0xbb0d('0x40'),'uri':_0xbb0d('0x41')+_0x20f728+'/crm/v2/Calls','headers':{'Authorization':_0xbb0d('0x30')+_0x452387},'body':{'data':[_0x5ea223]},'json':!![]})[_0xbb0d('0x31')](function(_0x5e5c72){if(_0x5e5c72&&_0x5e5c72[_0xbb0d('0x3e')][0x0][_0xbb0d('0x7a')]===_0xbb0d('0x48')){logger['info']('Call\x20created!');return{'id':_0x5e5c72[_0xbb0d('0x3e')][0x0][_0xbb0d('0x49')]['id']};}})[_0xbb0d('0x29')](function(_0x2573f6){logger['info'](_0xbb0d('0x7b'),_0x2573f6[_0xbb0d('0x2c')]);console[_0xbb0d('0x7c')](_0xbb0d('0x7b'),_0x2573f6);});}exports['queue']=function(_0x4f5541,_0x5d66fa,_0x1f7978,_0x402488,_0x3476d3,_0x5565e6){var _0x14e05e,_0x4565ea,_0x51a99a;_0x5565e6[_0xbb0d('0x7d')]=intUtil['stripTrailingSlash'](_0x5565e6[_0xbb0d('0x7d')]);_0x5565e6[_0xbb0d('0x7e')]=intUtil['stripTrailingSlash'](_0x5565e6[_0xbb0d('0x7e')]);if(_0x3476d3&&_0x3476d3[_0xbb0d('0x7f')]){logger[_0xbb0d('0x34')](_0xbb0d('0x80'),_0xbb0d('0x81'));_0x5d66fa[_0xbb0d('0x82')]=_0x5565e6['serverUrl']+_0xbb0d('0x83')+_0x5d66fa['uniqueid']+_0xbb0d('0x84')+md5(_0x5d66fa[_0xbb0d('0x85')]);}else{_0x5d66fa[_0xbb0d('0x82')]='';}var _0x5e9e4d=_0x5565e6['host']===_0xbb0d('0x86')?'eu':'com';return getAccessToken(_0x5565e6)[_0xbb0d('0x31')](function(_0x5dac67){_0x51a99a=_0x5dac67;return getUser(_0x51a99a,_0x5e9e4d,_0x5565e6,_0x402488[_0xbb0d('0x87')]);})[_0xbb0d('0x31')](function(_0x550c54){_0x14e05e=_0x550c54;logger['info'](_0xbb0d('0x88'),_0x14e05e['id']);return getEndUser(_0x51a99a,_0x5e9e4d,_0x5565e6,_0x5d66fa[_0xbb0d('0x89')],_0x5d66fa[_0xbb0d('0x8a')],_0x14e05e,_0x1f7978);})[_0xbb0d('0x31')](function(_0x1faae4){_0x4565ea=_0x1faae4;return getCall(_0x51a99a,_0x5e9e4d,_0x5565e6,_0x14e05e,_0x4565ea,_0x1f7978,_0x5d66fa,_0xbb0d('0x8b'));})[_0xbb0d('0x31')](function(_0x49a45b){if(_0x49a45b){logger[_0xbb0d('0x34')](_0xbb0d('0x8c'),_0x49a45b['id']);logger[_0xbb0d('0x34')](_0xbb0d('0x80'),_0xbb0d('0x8d'));emit(util[_0xbb0d('0x2f')](_0xbb0d('0x8e'),_0x402488[_0xbb0d('0x18')]),_0xbb0d('0x8f'),{'uri':_0xbb0d('0x90')+_0x5565e6[_0xbb0d('0x7d')]+_0xbb0d('0x91')+_0x49a45b['id']});}})[_0xbb0d('0x29')](function(_0x305ee1){logger['error'](_0xbb0d('0x80'),JSON[_0xbb0d('0x3c')](_0x305ee1));});};exports[_0xbb0d('0x76')]=function(_0xb342df,_0xb0ad20,_0x5d3bf5,_0x1b7ce5,_0x31c806,_0x16161d,_0x387af2){var _0x1ff77c,_0x3339e7,_0x84ab16;_0x16161d[_0xbb0d('0x7d')]=intUtil[_0xbb0d('0x92')](_0x16161d[_0xbb0d('0x7d')]);_0x16161d[_0xbb0d('0x7e')]=intUtil['stripTrailingSlash'](_0x16161d[_0xbb0d('0x7e')]);if(_0x387af2&&_0x387af2['recordingFormat']&&_0x387af2[_0xbb0d('0x93')]!==_0xbb0d('0x94')){logger['info']('[OUTBOUND]','Recording\x20is\x20enabled!');_0xb0ad20[_0xbb0d('0x82')]=_0x16161d[_0xbb0d('0x7e')]+_0xbb0d('0x83')+_0xb0ad20[_0xbb0d('0x85')]+_0xbb0d('0x84')+md5(_0xb0ad20[_0xbb0d('0x85')]);}var _0x4fdc66=_0x16161d[_0xbb0d('0x7d')]===_0xbb0d('0x86')?'eu':_0xbb0d('0x95');return getAccessToken(_0x16161d)[_0xbb0d('0x31')](function(_0x3339d4){_0x84ab16=_0x3339d4;return getUser(_0x84ab16,_0x4fdc66,_0x16161d,_0x1b7ce5[_0xbb0d('0x87')]);})['then'](function(_0x12de1d){_0x1ff77c=_0x12de1d;logger[_0xbb0d('0x34')](_0xbb0d('0x88'),_0x1ff77c['id']);return getEndUser(_0x84ab16,_0x4fdc66,_0x16161d,_0xb0ad20[_0xbb0d('0x96')],_0xb0ad20[_0xbb0d('0x97')],_0x1ff77c,_0x5d3bf5);})[_0xbb0d('0x31')](function(_0x5d5999){_0x3339e7=_0x5d5999;return getCall(_0x84ab16,_0x4fdc66,_0x16161d,_0x1ff77c,_0x3339e7,_0x5d3bf5,_0xb0ad20,'Outbound');})[_0xbb0d('0x31')](function(_0x44ffb5){if(_0x44ffb5){logger[_0xbb0d('0x34')](_0xbb0d('0x8c'),_0x44ffb5['id']);logger[_0xbb0d('0x34')](_0xbb0d('0x98'),_0xbb0d('0x8d'));emit(util[_0xbb0d('0x2f')]('user:%s',_0x1b7ce5[_0xbb0d('0x18')]),_0xbb0d('0x8f'),{'uri':_0xbb0d('0x90')+_0x16161d[_0xbb0d('0x7d')]+_0xbb0d('0x91')+_0x44ffb5['id']});}})[_0xbb0d('0x29')](function(_0x10bb16){logger[_0xbb0d('0x2a')](_0xbb0d('0x98'),JSON[_0xbb0d('0x3c')](_0x10bb16));});};exports[_0xbb0d('0x99')]=function(_0x515b0d,_0x366396,_0x1d7fe6,_0x39ade7,_0x59c4a6,_0x16e0ba){var _0x49c4bd,_0x16eb0f,_0x69f145;_0x16e0ba[_0xbb0d('0x7d')]=intUtil[_0xbb0d('0x92')](_0x16e0ba['host']);_0x16e0ba[_0xbb0d('0x7e')]=intUtil[_0xbb0d('0x92')](_0x16e0ba[_0xbb0d('0x7e')]);if(_0x59c4a6&&_0x59c4a6['monitor_format']){logger[_0xbb0d('0x34')]('['+_0x366396[_0xbb0d('0x69')][_0xbb0d('0x9a')]()+']',_0xbb0d('0x81'));_0x366396[_0xbb0d('0x82')]=_0x16e0ba[_0xbb0d('0x7e')]+_0xbb0d('0x83')+_0x366396['uniqueid']+_0xbb0d('0x84')+md5(_0x366396[_0xbb0d('0x85')]);}else{_0x366396[_0xbb0d('0x82')]='';}var _0x1293a7=_0x16e0ba[_0xbb0d('0x7d')]===_0xbb0d('0x86')?'eu':_0xbb0d('0x95');return getAccessToken(_0x16e0ba)[_0xbb0d('0x31')](function(_0x52160e){_0x69f145=_0x52160e;return getUser(_0x69f145,_0x1293a7,_0x16e0ba);})['then'](function(_0x59ede3){_0x49c4bd=_0x59ede3;logger['info'](_0xbb0d('0x88'),_0x49c4bd['id']);return getEndUser(_0x69f145,_0x1293a7,_0x16e0ba,_0x366396[_0xbb0d('0x89')],_0x366396[_0xbb0d('0x8a')],_0x49c4bd,_0x1d7fe6);})[_0xbb0d('0x31')](function(_0x89c69e){_0x16eb0f=_0x89c69e;return getCall(_0x69f145,_0x1293a7,_0x16e0ba,_0x49c4bd,_0x16eb0f,_0x1d7fe6,_0x366396,'Inbound');})[_0xbb0d('0x31')](function(_0x3a1e20){if(_0x3a1e20){logger[_0xbb0d('0x34')]('The\x20Call\x20ID\x20is:',_0x3a1e20['id']);}})[_0xbb0d('0x29')](function(_0x3482ea){logger[_0xbb0d('0x2a')]('['+_0x366396[_0xbb0d('0x69')][_0xbb0d('0x9a')]()+']',JSON[_0xbb0d('0x3c')](_0x3482ea));});};